因需要网上查了很多,在前人经验上总结一下利用CEDIT控件来输出日志的方法:
1、先要将CEDIT控件属性设为“多行”
2、增大CEDIT控件本身的最大字数限制
m_prlog.LimitText(0x99999999);//m_prlog是CEDIT绑定的控制对象
3、用于输出日志的函数如下,需要保留几行的日志自己定
void CTextDlg::ShowEditLog(CString m_str)
{
int lines=m_prlog.GetLineCount();//m_prlog是绑定CEDIT控件的对象
if(lines>1000)//如果输出日志超过1000行,则删第一行
{
CString tmp;
char tmpstr[100];//定义一个大于你程序输出日志一行可能最大字数的字符数组
m_prlog.GetWindowText(tmpstr,100);//只取前100个字符
tmp=tmpstr;
int it1=tmp.Find("\r\n")+2;//查找第一行的回车换行位置
m_prlog.SetSel(0,it1);//选择要删除的首行
m_prlog.ReplaceSel("");//用空串替换掉首行
}
CTime time = CTime::GetCurrentTime();
CString sTime = time.Format(_T("%H:%M:%S "));
m_str = sTime + m_str + L"\r\n";//每行输出日志结尾加上换行回车符
int iTextLen = m_prlog.GetWindowTextLength();
m_prlog.SetSel(iTextLen, iTextLen, FALSE);//移动光标到最后
m_prlog.SetFocus(); //移动光标到最后
m_prlog.ReplaceSel(m_str); //在光标的位置加入最新的输出日志行
m_prlog.LineScroll(m_prlog.GetLineCount()); //滚动到最下面
}