Qt 日誌界面類

1 UI界面文件爲QTablewidget函數

2 和spdlog結合使用ui

3 頭文件this

#ifndef _SIMLOGWIDGET_H_
#define _SIMLOGWIDGET_H_

#include <QtWidgets/QWidget>
#include "ui_simlog.h"



//日誌等級
enum LogLevel
{
    KLogTrace = 0,
    KLogDebug,
    KLogInfo,
    KLogWarn,
    KLogErr,
    KLogCritical,
};



class  LogWidget : public QWidget
{
    Q_OBJECT

public:
    static LogWidget& Instance();
    void Log(LogLevel level, std::string data,bool writefile = false);
private:
    LogWidget(QWidget *parent = Q_NULLPTR);
    Ui::SimLogClass ui;

    int level_;
};

//writefile表示是否寫入文件,默認不寫文件
void LOGUI(LogLevel level, std::string data, bool writefile = false);

#endif //_SIMLOGWIDGET_H_

4 cpp文件spa

#include "simlogwidget.h"

#include <QDateTime>
#include <QDebug>
#include <QString>
#include "simlog.h"

void LOGUI(LogLevel level, std::string data, bool writefile)
{
    LogWidget::Instance().Log(level, data, writefile);
}

LogWidget::LogWidget(QWidget *parent): QWidget(parent)
{
    ui.setupUi(this);
    //設置表格最後一列自適應拉伸
    ui.log_widget_->setColumnWidth(0, 220);
    ui.log_widget_->setColumnWidth(1, 70);
    ui.log_widget_->horizontalHeader()->setStretchLastSection(true);
    //設置表格禁止編輯
    ui.log_widget_->setEditTriggers(QAbstractItemView::NoEditTriggers);
    //設置單擊選擇一行
    ui.log_widget_->setSelectionBehavior(QAbstractItemView::SelectRows);
    //設置只能選擇一行,不能多行選中
    ui.log_widget_->setSelectionMode(QAbstractItemView::SingleSelection);

}

LogWidget& LogWidget::Instance()
{
    static LogWidget *logwidget=new LogWidget;
    return *logwidget;
}


void LogWidget::Log(LogLevel level, std::string data,bool writefile)
{
    QString s_level;

    if (level == KLogTrace)
    {
        if (writefile)
            LTrace(data);
        s_level = "trace";
    }
    else if (level == KLogDebug)
    {
        if (writefile)
            LDebug(data);
        s_level = "debug";
    }
    else if (level == KLogInfo)
    {
        if (writefile)
            LInfo(data);
        s_level = "info";
    }
    else if (level == KLogWarn)
    {
        if (writefile)
            LWarn(data);
        s_level = "warn";
    }
    else if (level == KLogErr)
    {
        if (writefile)
            if (writefile)
                LError(data);
        s_level = "error";
    }
    else if (level == KLogCritical)
    {
        if (writefile)
            LCritical(data);
        s_level = "critical";
    }

    QDateTime current_date_time = QDateTime::currentDateTime();
    QString current_date = current_date_time.toString("yyyy-MM-dd hh:mm::ss.zzz");

    int row_count = ui.log_widget_->rowCount();
    ui.log_widget_->insertRow(row_count);
    QTableWidgetItem *item_time = new QTableWidgetItem(current_date);
    QTableWidgetItem *item_level = new QTableWidgetItem(s_level);
    QTableWidgetItem *item_data = new QTableWidgetItem(QString::fromStdString(data));
    ui.log_widget_->setItem(row_count, 0, item_time);
    ui.log_widget_->setItem(row_count, 1, item_level);
    ui.log_widget_->setItem(row_count, 2, item_data);


}

5 使用方法debug

(1)包含頭文件日誌

(2)調用函數,以下:code

    for (int i = 0; i < 100; i++)
    {
        LOGUI(KLogDebug, "infomessage");
        LOGUI(KLogInfo, "errormessage");
    }

6 日誌格式爲:時間-日誌類別-日誌信息orm

相關文章
相關標籤/搜索