• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

QT控件 ——:QTextEdit 显示数据和设置居 和 程序崩溃处理方式已解决

武飞扬头像
乐亦_Lee
帮助1

QT控件 ——之QTextEdit控件 清空、显示居中 和 程序崩溃处理方式【已解决】

一、显示数据

注:tEd_Time是一个用QTextEdit 定义的控件
1、清空操作:

  • 使用clear()函数
    ui->tEd_Time->clear();

2、添加并显示数据:

  • 使用append()函数
    ui->tEd_Time->append(Date);

二、设置居中

  • 使用setAlignment(Qt::AlignCenter);
    ui->tEd_Time->append(Date);
    ui->tEd_Time->setAlignment(Qt::AlignCenter);            //水平居中
    ui->tEd_Time->append(Time);
    ui->tEd_Time->setAlignment(Qt::AlignCenter);            //水平居中

重点: 设置文本居中时,每次添加文本后,都需要对新文本进行设定。

同时有博主反应:

设置居中不管用,经测试发现QTextEdit的setPlainText、setText等函数会导致对齐重设为左对齐,需要在这些函数之后重新设置文字居中即可

三、调用 clear()函数 导致的程序崩溃

一些博主解答内容如下:

程序的基本调用流程是,在一个业务处理线程中,通过调用QTextEdit::append()方法输出提示信息,从而引发程序崩溃。
程序运行时的错误提示如下:
QObject::connect: Cannot queue arguments of type ‘QTextCursor’
(Make sure ‘QTextCursor’ is registered using qRegisterMetaType().)
经过进一步检查发现原因是Qt中带参数的信号如果在线程中被发送,那么必须放入队列里面。
由于QTextEdit 自带的库,故将业务线程业务中的直接调用QTextEdit::append()改为触发自定义信号,通过信号槽机制的槽函数来调用QTextEdit::append(),以规避在线程中直接调用的问题。

我的理解就是:QTextEdit 的一些函数,影响了线程。带参数的信号在线程中传送时,是需要放到队列中的。所以,解决思路就是:
将对QTextEdit 插件进行的操作通过信号和槽的方式进行触发,从而达到规避在线程中直接调用的问题。

具体实现方式如下:

//信号和槽的连接
connect(this, SIGNAL(ManualTimeSig(QString, QString)), this, SLOT(DateTimeSet(QString, QString)));
//槽函数的实现
void frmMain::DateTimeSet(QString Date, QString Time)
{
    ui->tEd_Time->clear();
//    ui->tEd_Time->append(QDateTime::fromTime_t(Info_OperateSet.Info_Main.time).toString(DATETIME_FORMAT_));
    ui->tEd_Time->append(Date);
    ui->tEd_Time->setAlignment(Qt::AlignCenter);            //水平居中
    ui->tEd_Time->append(Time);
    ui->tEd_Time->setAlignment(Qt::AlignCenter);            //水平居中
}
==【注】==
      1、定义的信号有两个QString参数
      2、槽函数的实现主要是将QTextEdit 内容清空后,重新添加新的数据,并将数据进行居中显示

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhgcaeba
系列文章
更多 icon
同类精品
更多 icon
继续加载