为什么这些代码行没有按预期运行?

Raf*_*ari 1 .net c# mysql richtextbox

我正在创建一个聊天应用程序,我想在Bold中显示名称.首次加载表单时,我RichTextBox使用这些代码行在控件上显示数据库中的历史记录对话,我想以粗体显示名称:

以下是使这成为可能的所有代码:

string strProvider = "Data Source=" + srv_host + ";Database=" + srv_db + ";User ID=" + srv_user + ";Password=" + srv_pass;
        MySqlConnection myConn = new MySqlConnection(strProvider);
        try
        {
            myConn.Open();
            string strCmd = "SELECT * FROM comments WHERE task_id=@task_id AND ((from_usr=@from AND to_usr=@to) OR (from_usr=@to AND to_usr=@from)) ORDER BY at_time ASC";
            MySqlCommand myCmd = new MySqlCommand(strCmd, myConn);
            myCmd.Parameters.AddWithValue("from", frm_usr);
            myCmd.Parameters.AddWithValue("to", to_usr);
            myCmd.Parameters.AddWithValue("task_id", tid);
            myCmd.ExecuteNonQuery(); // execute now

            MySqlDataReader dr = myCmd.ExecuteReader();

            while (dr.Read())
            {
                string text = dr.GetValue(1).ToString() + ": " + dr.GetValue(6) + Environment.NewLine;
                richTextBox1.AppendText(text);
                richTextBox1.SelectionStart = 0;
                richTextBox1.SelectionLength = dr.GetValue(1).ToString().Length;
                richTextBox1.SelectionFont = new Font(richTextBox1.Font,FontStyle.Bold);
            }

            myConn.Dispose();
        }


        catch (Exception E) { MessageBox.Show(E.Message); }
Run Code Online (Sandbox Code Playgroud)

这些代码行不能按预期工作:

 while (dr.Read())
            {
                string text = dr.GetValue(1).ToString() + ": " + dr.GetValue(6) + Environment.NewLine;
                richTextBox1.AppendText(text);
                richTextBox1.SelectionStart = 0;
                richTextBox1.SelectionLength = dr.GetValue(1).ToString().Length;
                richTextBox1.SelectionFont = new Font(richTextBox1.Font,FontStyle.Bold);
            }
Run Code Online (Sandbox Code Playgroud)

编辑:
dr.GetValue(1).ToString()保存用户的全名
dr.GetValue(6).ToString()保留消息

上面代码的问题是它只显示粗体中的第一个名称,但其他行不受影响.看图像在此输入图像描述
有人可以告诉我代码无效的原因.我无法弄清楚错误在哪里.
谢谢

nic*_*k_w 5

您在这里遇到的问题richTextBox1.SelectionStart是始终为零,这意味着格式化只会应用于文本框中的第一行.

尝试将此设置为richTextBox1.SelectionStart = richTextBox1.TextLength.

编辑:

尝试将其设置为

richTextBox1.SelectionStart = richTextBox1.TextLength - text.Length;
Run Code Online (Sandbox Code Playgroud)

编辑2:

我认为Invalid Argument事件是由使用引起的Environment.NewLine.如果我使用"\n",代码工作正常.问题是Environment.NewLine当然是\r\n在Windows上,但richtextBox1似乎忽略了\r.这导致在richTextBox1.TextLength - text.Length第一次迭代中为-1.