Qml写日志

大家都知道通过Q_INVOKABLE可以让qml直接访问c++类的接口函数.

void outputMessage(QtMsgType type, const QMessageLogContext &context, const QString &msg)
{
    static QMutex mutex;
    mutex.lock();

    QString text;
    switch(type)
    {
    case QtDebugMsg:
        text = QString("Debug:");
        break;

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

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

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

    QString message = "";
    if (context.file != nullptr)
    {
        QString context_info = QString("File:(%1) Line:(%2)").arg(QString(context.file)).arg(context.line);
        QString current_date_time = QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss ddd");
        QString current_date = QString("(%1)").arg(current_date_time);
        message = QString("%1 %2 %3 %4").arg(text).arg(context_info).arg(msg).arg(current_date);
    }
    else
    {
        message = msg;
    }

    QFile file("log.txt");
    file.open(QIODevice::WriteOnly | QIODevice::Append);
    QTextStream text_stream(&file);
    text_stream << message << "\r\n";
    file.flush();
    file.close();

    mutex.unlock();
}

QmlLog4Qml::QmlLog4Qml()
{
    qInstallMessageHandler(outputMessage);
}

void QmlLog4Qml::qDebug_Info(int type, QString strInfo)
{
    QMessageLogContext context;
    context.file = nullptr;
    outputMessage((QtMsgType)type, context, strInfo);
}

在这里插入图片描述

需要完整代码请访问QtQuickExamples

联系方式:

作者郑天佐
QQ278969898
主页http://www.camelstudio.cn
邮箱camelsoft@163.com
博客http://blog.csdn.net/zhengtianzuo06
githubhttps://github.com/zhengtianzuo
QQ群199672080

在这里插入图片描述

觉得分享的内容还不错, 就请作者喝杯咖啡吧~~

QML中,可以通过使用console对象来输出日志信息。console对象提供了一系列方法,可以输出不同类型的日志信息,例如: 1. log(message):输出一般信息。 2. info(message):输出信息提示。 3. warn(message):输出警告信息。 4. error(message):输出错误信息。 示例代码如下: ```qml console.log("This is a log message."); // 输出一般信息 console.info("This is an info message."); // 输出信息提示 console.warn("This is a warning message."); // 输出警告信息 console.error("This is an error message."); // 输出错误信息 ``` 在QML中,console对象默认是禁用的,需要在程序启动时启用它。可以通过在main.qml文件中添加以下代码启用console对象: ```qml import QtQuick 2.0 Item { Component.onCompleted: { if (Qt.platform.os === "android") { // 在Android平台上,使用Qt Android Extras库中的方法启用console对象 var androidExtras = Qt.androidExtras; if (androidExtras) { var androidConfig = androidExtras.qtAndroidConfig(); androidConfig.setApplicationName("MyApp"); androidConfig.setDebuggingEnabled(true); } } else { // 在其他平台上,使用Qt QPA Platform Integration库中的方法启用console对象 var qpa = Qt.platform.plugin; if (qpa) { var qpaConfig = qpa.debug; qpaConfig.enabled = true; qpaConfig.level = "debug"; } } } } ``` 在上述示例中,通过检测当前平台,使用不同的方法启用console对象,并设置其级别为debug。在启用console对象后,可以在控制台中查看输出的日志信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhengtianzuo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值