一杯清酒邀明月
天下本无事,庸人扰之而烦耳。
posts - 3121,comments - 209,views - 578万

QPlainTextEdit是一个多行文本编辑器,用于显示和编辑多行简单文本。另外,还有一个QTextEdit组件,是一个所见即所得的可以编辑带格式文本的组件,以HTML格式标记符定义文本格式。

实例samp4_6演示QPlainTextEdit的使用,运行界面如下图:

从上一节的代码中,我们已经知道,使用QPlainTextEdit::appendPlainText( QString )函数就可以向PlainTextEdit组件添加一行字符串。

QPlainTextEdit提供cut()、copy()、paste()、undo()、redo()、clear()、selectAll()等标准编辑功能的槽函数,QPlainTextEdit还提供了一个标准的右键快捷菜单。

逐行读取文字内容

如果要将QPlainTextEdit组件中显示的文字读出来,有一个简单的函数toPlainText()可以将全部文字内容输出为一个QString,其定义如下:

QString QPlainTextEdit :: toPlainText()

但是如果要逐行读取QPlainTextEdit组件中的字符串,则稍微麻烦一点。

下面是上图中“文本框内容添加到ComboBox”按钮的响应代码,它将plainTextEdit中的每一行作为一个Item添加到comboBox中:

复制代码
 1 void Widget::on_plainTextEdit_blockCountChanged(int newBlockCount)
 2 {
 3     //plainTextEdit的内容逐行添加为comboBox的项
 4     QTextDocument * doc = ui->plainTextEdit->document();
 5     int cnt = doc->blockCount();//回车符是一个block
 6     QIcon icon("M:/images/icon/aim.ico");
 7     ui->comboBox->clear();
 8     for(int i=0;i<cnt;i++)
 9     {
10         QTextBlock textLine = doc->findBlockByNumber(i);//文本中的一行
11         QString str = textLine.text();
12         ui->comboBox->addItem(icon,str);
13     }
14 }
复制代码

QPlainTextEdit的文字内容以QTextDocument类型存储,函数document()返回这个文档对象的指针。

QTextDocument是内存中的文本对象,以文本Block的方式存储,一个Block就是一个段落,每个段落以回车符结束。

QTextDocument提供一些函数实现对文本内容的读取:

  • int blockCount():获得Block个数(以回车符为间隔);
  • QTextBlock findBlockByNumber( int blockNumber ):读取一个Block,序号从0开始,直到blockCount()-1结束。

一个document有多个Block,从document中读取出的一个Block类型为QTextBlock,通过QTextBlock::text()来获取纯文本Text。

使用QPlainTextEdit自带的快捷菜单

QPlainTextEdit有自带的右键快捷菜单,可以实现常用的编辑功能。在UI设计器里,选择为plainTextEdit的customContextMenuRequested()信号生成槽函数,编写如下的代码,就可以创建并显示QPlainTextEdit的标准快捷菜单:

复制代码
1 void Widget::on_plainTextEdit_customContextMenuRequested(const QPoint &pos)
2 {
3     //创建并显示标准弹出式菜单
4     QMenu* menu=ui->plainTextEdit->createStandardContextMenu();
5     menu->exec(pos);
6 }
复制代码

 

posted on   一杯清酒邀明月  阅读(1109)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程
· .NET 10 首个预览版发布,跨平台开发与性能全面提升
· 《HelloGitHub》第 107 期
· 全程使用 AI 从 0 到 1 写了个小工具
· 从文本到图像:SSE 如何助力 AI 内容实时呈现?(Typescript篇)
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示