Qt 计算QTextEdit 行位置 实例

移动开发
本文介绍的是Qt 计算QTextEdit 行位置 实例,在坛子里逛了一圈,发现了这篇文章,给友们分享一下,先来看内容。

Qt 计算QTextEdit 行位置 实例是本文介绍的内容,先来看内容。笔者以前撰写过一篇关于QPlainTextEdit计算和绘制行号的文章, 里面详细讲述了遍历QPlainTextEdit的每一行及其位置的方法。 最近遇到一个问题是要为QTextEdit实现相同的功能。经过实践发现,原理相同但使用的函数略有不同,特此memo,希望对广大qter有用。

如果没有阅读过笔者前文的, 请自行复习: 计算和绘制QPlainTextEdit的行号

针对QTextEdit的代码版本列举如下:

  1. QPainter painter(w);  
  2. QTextBlock block = document()->begin();  
  3. int top = 0;  
  4. QTextCursor cursor(block);  
  5. cursor.setPosition(0);//move to the beginning of the document  
  6. int linenum = 0;  
  7. while(linenum < document()->lineCount())  
  8. {  
  9. for( int i = 0 ; i < block.lineCount(); i ++) { color += 50; color %= 255; QColor pc(color,color,color); 
  10. QTextLine line = block.layout()->lineAt(i);  
  11. painter.fillRect( block.layout()->position().x(), block.layout()->position().y(), line.width(), line.height(), pc);  
  12. qWarning() << linenum << block.layout()->position() << color;  
  13. linenum ++;  
  14. }  
  15. blockblock = block.next();  
  16. if(!block.isValid())  
  17. {  
  18. break;  
  19. }  

其实比较两者, 其相似程度达到95%以上。 只有一点需要提示注意, 那就是QTextLine的位置信息(x、y,rect等)是相对于当前QTextBlock而言, 所以需要按照block的位置信息相应位移才是正确的值。

这篇blog比较简单,仅做memo用。

小结:Qt 计算QTextEdit 行位置 实例的内容介绍完了,希望本文对你有所帮助!

责任编辑:zhaolei 来源: 互联网
相关推荐

2011-07-05 14:46:34

2011-06-27 16:07:49

Qt Designer

2011-06-21 09:33:49

Qt 启动 界面

2011-06-24 14:34:17

Qt 小票 打印

2011-06-13 16:51:19

Qt Socket

2011-06-14 16:45:57

Qt 图标

2011-06-30 16:24:38

Qt TableWidge

2011-06-27 16:37:08

Qt Designer

2011-06-16 17:54:30

Qt Mplayer

2014-08-26 11:46:46

QtAndroid实例教程

2011-06-30 18:15:36

Qt 线程 同步

2011-07-05 15:16:00

QT 进度条

2011-06-30 17:31:32

Qt 多线程 信号

2011-06-30 16:38:07

Qt QTableWidg

2011-06-14 10:52:10

QT QTreeView

2011-06-21 15:11:04

QT 数据库

2011-06-22 17:36:50

QT Linux 串口

2011-06-27 13:32:21

Qt 数据库 QSqlQueryM

2011-07-05 16:08:10

2011-06-29 11:06:12

Qt Qvfb
点赞
收藏

51CTO技术栈公众号