Duilib – RichEdit作为日志输出控件,更新日志内容后并自动跳到最后一行
本文作者:StubbornHuang
版权声明:本文为站长原创文章,如果转载请注明原文链接!
原文标题:Duilib – RichEdit作为日志输出控件,更新日志内容后并自动跳到最后一行
原文链接:https://www.stubbornhuang.com/1036/
发布于:2020年12月21日 17:14:34
修改于:2020年12月21日 17:14:34

1 编写界面xml
在界面xml中的需要添加日志显示的位置添加以下代码:
<RichEdit name="RichEdit_Log" text="日志控件" multiline="true" vscrollbar="true" autovscroll="true" readonly="true"/>
设置RichEdit允许多行,文本只读,自动设置垂直滚动条。
2 RichEdit控件更新内容后跳转到最后一行
2.1 bug版本代码
最开始有问题的版本代码如下:
m_RichEditUI->SetText(allLogStr.c_str());
m_RichEditUI->SetTextColor(0xFF000000);
m_RichEditUI->LineDown();
这个写法有个bug,就是程序第一次启动之后,更新日志,当日志越来越多时,RichEdit不会自动跳到最后一行,必须先点击下RichEdit控件,才会正常的跳转到最后一行。
2.2 修改后的代码
在经过很多试验之后,将上述代码进行以下修改:
m_RichEditUI->SetText(allLogStr.c_str());
m_RichEditUI->SetTextColor(0xFF000000);
m_RichEditUI->LineDown();
m_RichEditUI->LineScroll(m_RichEditUI->GetLineCount() - 1);
m_RichEditUI->NeedUpdate();
m_RichEditUI->Invalidate();
加上了:
m_RichEditUI->LineScroll(m_RichEditUI->GetLineCount() - 1);
强制将滚轮设置为最后一行。
然后使用:
m_RichEditUI->NeedUpdate();
m_RichEditUI->Invalidate();
对控件进行强制更新。
最终的效果如下图所示:
当前分类随机文章推荐
- Duilib - 各个控件的消息响应类型 阅读1738次,点赞0次
- Duilib - 点击按钮弹出模态对话框 阅读962次,点赞0次
- Duilib - Label控件文本换行 阅读789次,点赞0次
- Duilib - 字体 阅读2340次,点赞0次
- Duilib - RichEdit和List等控件增加垂直滚动条vscrollbar和水平滚动条hscrollbar 阅读834次,点赞2次
- Duilib - 程序开机自启动 阅读1279次,点赞0次
- Duilib - 使Duilib主窗口前置,但是又不是一直作为最顶层窗口 阅读2238次,点赞2次
- Duilib - CDuiString转换为std::string 阅读1266次,点赞0次
- Duilib - duilib应用程序实现文件可拖拽的功能 阅读1736次,点赞0次
- Duilib - 颜色属性的设置 阅读2418次,点赞1次
全站随机文章推荐
- 简单粗暴:使用pycharm安装对应的Python版本第三方包 阅读3011次,点赞0次
- 深度学习 - 卷积神经网络CNN简介 阅读58次,点赞0次
- Python - argparse命令行参数解析库用法总结 阅读107次,点赞0次
- 资源分享 - ShaderX2 - Introductions and Tutorials with DirectX9.0 英文高清PDF下载 阅读1761次,点赞0次
- WordPress - 获取某个用户发表的评论数量 阅读1411次,点赞0次
- WordPress - 在erphpdown插件中增加在隐藏文章指定位置之后文章内容的付费查看功能 阅读353次,点赞0次
- C++ – 字节数组byte[]或者unsigned char[]与bool的相互转换 阅读424次,点赞0次
- 姿态估计 - COCO-WholeBody数据集骨骼关节keypoint标注对应 阅读1588次,点赞0次
- 资源分享 - Computational Geometry in C, Second Edition 英文高清PDF下载 阅读2111次,点赞1次
- C++ - 使用正则判断字符串是否全是中文 阅读576次,点赞0次
评论
150