QDebug 信息输出到控件

简介: QDebug 信息输出到控件

qDebug中打印的信息,输出到界面的控件plainTextEdit中;

头文件:

    static ZynqSlaveInfo *m_mainWin;
    static void setText(QString str);

cpp文件:

#include <QMutex>
#include <QDateTime>
void myMsgOutput(QtMsgType type, const QMessageLogContext &context, const QString& msg);
ZynqSlaveInfo *ZynqSlaveInfo::m_mainWin = nullptr;
ZynqSlaveInfo::ZynqSlaveInfo(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::ZynqSlaveInfo)
{
    ui->setupUi(this);
    InitSlaveInfo();
}
ZynqSlaveInfo::~ZynqSlaveInfo()
{
    delete ui;
}
void ZynqSlaveInfo::InitSlaveInfo()
{
    m_mainWin = this;
    qInstallMessageHandler(myMsgOutput);
}
void ZynqSlaveInfo::setText(QString str)
{
    m_mainWin->ui->plainTextEdit_logShow->insertPlainText(str);
    m_mainWin->ui->plainTextEdit_logShow->insertPlainText("\n");
}
void myMsgOutput(QtMsgType type, const QMessageLogContext &context, const QString& msg)
{
    static QMutex mutex;
    Q_UNUSED(type);
    Q_UNUSED(context);
    mutex.lock();
#if 0
    QString time=QDateTime::currentDateTime().toString(QString("[ yyyy-MM-dd HH:mm:ss:zzz ]"));
    QString mmsg;
    switch(type)
    {
    case QtDebugMsg:
        mmsg=QString("%1: Debug:\t%2 (file:%3, line:%4, func: %5)").arg(time).arg(msg).arg(QString(context.file)).arg(context.line).arg(QString(context.function));
        break;
    case QtInfoMsg:
        mmsg=QString("%1: Info:\t%2 (file:%3, line:%4, func: %5)").arg(time).arg(msg).arg(QString(context.file)).arg(context.line).arg(QString(context.function));
        break;
    case QtWarningMsg:
        mmsg=QString("%1: Warning:\t%2 (file:%3, line:%4, func: %5)").arg(time).arg(msg).arg(QString(context.file)).arg(context.line).arg(QString(context.function));
        break;
    case QtCriticalMsg:
        mmsg=QString("%1: Critical:\t%2 (file:%3, line:%4, func: %5)").arg(time).arg(msg).arg(QString(context.file)).arg(context.line).arg(QString(context.function));
        break;
    case QtFatalMsg:
        mmsg=QString("%1: Fatal:\t%2 (file:%3, line:%4, func: %5)").arg(time).arg(msg).arg(QString(context.file)).arg(context.line).arg(QString(context.function));
        abort();
    }
    /*QFile file("debug.txt");
    file.open(QIODevice::ReadWrite | QIODevice::Append);
    QTextStream stream(&file);
    stream << mmsg << "\r\n";
    file.flush();
    file.close();*/
#endif
    ZynqSlaveInfo::setText(msg);
    mutex.unlock();
}
相关文章
|
Linux Python Windows
为Python打包创建一个世外桃源,解决打包太大且启动慢的问题
首先是我用的是Anaconda的集成环境,由于Anaconda或者自己搭建的环境里内置了很多库,而且在日常的开发中又安装很多开发所需要的其他库,打包的时候就把很多不必要的模块打包进去,导致打包出来的文件过于臃肿.打开慢由于运行需要加载这些环境,由于加载的库过多导致耗时过长,而且Python是一门解释型语言,本身运行效率上也稍慢,所以能够明显体会到启动时的漫长等待 我们写代码就是为了高效,怎么能受得了打开慢且占资源的东西呢,那如何能解决这个问题呢?
2187 1
|
11月前
|
敏捷开发 数据可视化 数据挖掘
告别手工报表!家电巨头“简化工作方式”背后的数字化思考
企业管理中手工填报耗时低效问题突出。钉钉宜搭通过低代码开发,实现自动化流程,解放人工操作;Quick BI 提供智能数据分析与可视化,助力管理者实时掌握经营动态,提升决策效率。两者结合成为企业数字化提效的热门选择。
315 22
|
5月前
|
SQL 人工智能 Rust
Java 开发中Stream的toMap与Map 使用技巧
本文深入解析了 Java 中 `toMap()` 方法的三大问题:重复键抛出异常、`null` 值带来的风险以及并行流中的性能陷阱,并提供了多种替代方案,如使用 `groupingBy`、`toConcurrentMap` 及自定义收集器,帮助开发者更安全高效地进行数据处理。
252 0
|
API UED
【Qt 学习笔记】Qt窗口 | 状态栏 | QStatusBar的使用及说明
【Qt 学习笔记】Qt窗口 | 状态栏 | QStatusBar的使用及说明
2333 4
|
编解码 开发者 UED
Qt布局实战:实现高效、美观的GUI应用程序
Qt布局实战:实现高效、美观的GUI应用程序
2136 2
|
Linux 网络安全 芯片
linux系统中详解u-boot之网络移植与调试
linux系统中详解u-boot之网络移植与调试
2446 0
|
网络协议 网络安全 API
Qt 网络编程之美:探索 URL、HTTP、服务发现与请求响应
Qt 网络编程之美:探索 URL、HTTP、服务发现与请求响应
1592 1
【C++】C++封装成DLL并调用(初学者快速入门)
【C++】C++封装成DLL并调用(初学者快速入门)
|
消息中间件 Linux API
跨进程通信设计:Qt 进程间通讯类全面解析
跨进程通信设计:Qt 进程间通讯类全面解析
1199 0