Qt之日志输出窗口

    继上节所讲,Qt可以很容易的将一些日志信息保存到文件中,那么日志信息如何输出到窗口呢?
    用过VS或者其他IDE的童鞋对日志输出到窗口应该都很熟悉,开发者可以打开一个输出窗口很清晰的查看一些日志信息。

例如VS,如下:

代码如下:
**********log_browser.cpp**********

#include "log_browser.h"

LogBrowser::LogBrowser(QWidget *parent)
: QWidget(parent)
{
this->resize(400, 300);
is_finished = false;

browser = new QTextBrowser();
start_button = new QPushButton();
clear_button = new QPushButton();

start_button->setText("start");
clear_button->setText("clear");

QHBoxLayout *button_layout = new QHBoxLayout();
button_layout->addStretch();
button_layout->addWidget(start_button);
button_layout->addWidget(clear_button);
button_layout->setSpacing(10);
button_layout->setContentsMargins(0, 0, 10, 10);

QVBoxLayout *main_layout = new QVBoxLayout();
main_layout->addWidget(browser);
main_layout->addLayout(button_layout);
main_layout->setSpacing(10);
main_layout->setContentsMargins(0, 0, 0, 0);

this->setLayout(main_layout);
connect(start_button, &QPushButton::clicked, this, &LogBrowser::start);
connect(clear_button, &QPushButton::clicked, browser, &QTextBrowser::clear);
}

LogBrowser::~LogBrowser()
{

}

void LogBrowser::outputMessage(QtMsgType type, const QMessageLogContext &context, const QString &msg)
{
QString message;
switch(type)
{
case QtDebugMsg:
message = QString("Debug:");
break;

case QtWarningMsg:
message = QString("Warning:");
break;

case QtCriticalMsg:
message = QString("Critical:");
break;

case QtFatalMsg:
message = QString("Fatal:");
}

browser->append(message.append(msg));
}

void LogBrowser::start()
{
if(!is_finished)
{
for(int i=0; i<1000000; i++)
{
QCoreApplication::processEvents(); 
qDebug()<<QString("This is a Qt log browser").append(QString::number(i, 10));
}
is_finished = true;
}
}

void LogBrowser::closeEvent(QCloseEvent *event)
{
QMessageBox::StandardButton answer = QMessageBox::question(
this,
tr("Close Log Browser?"),
tr("Do you really want to close the log browser?"),
QMessageBox::Yes | QMessageBox::No
);
if (answer == QMessageBox::Yes)
event->accept();
else
event->ignore();
}

void LogBrowser::keyPressEvent(QKeyEvent *event)
{
event->ignore();
}

**********main.cpp**********

#include "log_browser.h"
#include
#include

QPointer log_broswer;

void outputMessage(QtMsgType type, const QMessageLogContext &context, const QString &msg)
{
if(log_broswer)
log_broswer->outputMessage(type, context, msg);
}

int main(int argc, char *argv[])
{
QApplication a(argc, argv);
log_broswer = new LogBrowser();
log_broswer->show();
qInstallMessageHandler(outputMessage);

return a.exec();
}

效果如下:

注:
    技术在于交流、沟通,转载请注明出处并保持作品的完整性。
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将Qt的工作台输出改到Qt界面输出,可以使用QTextEdit控件来显示输出信息。首先,需要在主窗口类中创建一个QTextEdit对象,用于显示输出信息。然后,使用qInstallMessageHandler函数来自定义消息处理流程,将输出信息重定向到QTextEdit控件中。 在主窗口类的构造函数中,创建一个QTextEdit对象,并设置其属性和大小。然后,使用qInstallMessageHandler函数来设置自定义的消息处理函数。在消息处理函数中,将输出信息追加到QTextEdit控件中。 以下是示例代码: ```cpp // 在主窗口类中定义一个QTextEdit对象 QTextEdit *debugEdit; // 自定义消息处理函数 void outputMessage(QtMsgType type, const QMessageLogContext &context, const QString &msg) { // 根据消息类型设置输出格式 QString output; switch (type) { case QtDebugMsg: output = QString("Debug: %1").arg(msg); break; case QtWarningMsg: output = QString("Warning: %1").arg(msg); break; case QtCriticalMsg: output = QString("Critical: %1").arg(msg); break; case QtFatalMsg: output = QString("Fatal: %1").arg(msg); break; default: break; } // 将输出信息追加到QTextEdit控件中 debugEdit->append(output); } // 在主窗口类的构造函数中设置QTextEdit控件和消息处理函数 MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent) { // 创建QTextEdit对象 debugEdit = new QTextEdit(); debugEdit->setWindowTitle("调试窗口"); debugEdit->resize(500, 300); debugEdit->setAttribute(Qt::WA_QuitOnClose, false); debugEdit->hide(); // 设置自定义的消息处理函数 qInstallMessageHandler(outputMessage); } ``` 通过以上代码,你可以将Qt的工作台输出改到Qt界面输出,将输出信息显示QTextEdit控件中。 #### 引用[.reference_title] - *1* *3* [QT 日志输出至控制台、控件、文件](https://blog.csdn.net/weixin_49569127/article/details/123201370)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [QT 学习笔记(六)](https://blog.csdn.net/weixin_45891612/article/details/128087543)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值