Qt浅谈之四十四动态显示日志(QGraphicsItem)

2024-03-11 10:18

本文主要是介绍Qt浅谈之四十四动态显示日志(QGraphicsItem),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、简介

 

        在QGraphicsItem中使用QGraphicsItemAnimation和QTimeLine来实现动画的显示。其中的数据都是测试数据,仅为显示动画效果。

 

二、详解

1、部分代码

(1)LogMessagesItem.h

#ifndef _LOGMESSAGEITEM_H_
#define _LOGMESSAGEITEM_H_
#include <QtGui>
#include <QtCore>
#include "clusterpagenumber.h"
#include "calendarselected.h"class LogContentItem;
class LogMessagesItem : public QObject, public QGraphicsItem
{Q_OBJECT
public:explicit LogMessagesItem(QGraphicsItem *parent = 0);QRectF boundingRect() const;void setSize(const int width, const int height);protected:void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget);bool eventFilter(QObject *obj, QEvent *event);private:void getLogContents();void showLogs();void hideLogItem();private:int _width;int _height;int totalLogs;int totalPageNumber;int currentPageNumber;ClusterPageNumber *pageNumber;CalendarSelected *calendar;QList<LogContentItem *>logItem;QGraphicsRectItem *rectItem;bool leftToRight;private slots:void slotCalendarFinish();void slotLogPageChange(int index);
};class LogContentItem : public QGraphicsItem
{
public:explicit LogContentItem(QGraphicsItem *parent = 0);~LogContentItem();QRectF boundingRect() const;void setData(const QList<QString> &data);protected:void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget);
private:QGraphicsTextItem *timeText;QGraphicsTextItem *typeText;QGraphicsTextItem *stateText;QGraphicsTextItem *describeText;
};
#endif

(2)LogMessagesItem.cpp

#include "LogMessagesItem.h"
#define MAXLOGSRPERPAGE 4LogMessagesItem::LogMessagesItem(QGraphicsItem *parent): QGraphicsItem(parent), totalLogs(0), totalPageNumber(1), currentPageNumber(1), leftToRight(true)
{_width = 633;_height = 437;logItem.clear();setFiltersChildEvents(true);calendar = new CalendarSelected;QGraphicsProxyWidget *calendarProxy = new QGraphicsProxyWidget(this);calendarProxy->setWidget(calendar);calendarProxy->setPos(10, 10);calendarProxy->show();calendarProxy->setZValue(1);connect(calendar, SIGNAL(finish()), this, SLOT(slotCalendarFinish()));pageNumber = new ClusterPageNumber;//pageNumber->setBackgroundColor(QColor("#FF0000"));pageNumber->resize(248, 18);pageNumber->setTitle(tr("合计日志条数"), 0);pageNumber->setCurrentAndTotalPage(1, 10);QGraphicsProxyWidget *pageNumberProxy = new QGraphicsProxyWidget(this);pageNumberProxy->setWidget(pageNumber);pageNumberProxy->setPos(633 - 248 -10, 437 - 35);pageNumberProxy->show();connect(pageNumber, SIGNAL(currentPageChanged(int)), this, SLOT(slotLogPageChange(int)));QGraphicsTextItem *title = new QGraphicsTextItem(this);title->setDefaultTextColor(QColor("#666666"));title->setFont(QFont("arial", 10, QFont::Normal));title->setPlainText(tr("按状态:"));title->setPos(460, 10);QComboBox *logListBox = new QComboBox;logListBox->resize(100, 23);logListBox->setStyleSheet("QComboBox{border:1px solid #d7d7d7; border-radius: 3px; padding: 1px 18px 1px 3px;} ""QComboBox:editable{ background: white; }""QComboBox:!editable{ background: #fbfbfb; color:#666666}""QComboBox::drop-down{ subcontrol-origin: padding; subcontrol-position: top right; width: 22px; border-left-width: 1px; border-left-color: #c9c9c9; border-left-style: solid; /* just a single line */ border-top-right-radius: 3px; /* same radius as the QComboBox */ border-bottom-right-radius: 3px; }""QComboBox::down-arrow { image: url(:/resources/images/input_drop_down.png); }""QComboBox::down-arrow:on { /* shift the arrow when popup is open */ top: 1px; left: 1px;}""QComboBox QAbstractItemView::item{max-width: 30px;min-height: 20px}");QListView *listView = new QListView;listView->setStyleSheet("QListView{font-size: 11px}"" QListView::item:!selected{color: #19649f}""QListView::item:selected:active{background-color: #1275c3}""QListView::item:selected{color: white}");logListBox->setView(listView);logListBox->addItem(tr("所有日志"));logListBox->addItem(tr("错误日志"));logListBox->addItem(tr("警告日志"));QGraphicsProxyWidget *listBoxrProxy = new QGraphicsProxyWidget(this);listBoxrProxy->setWidget(logListBox);listBoxrProxy->setPos(522, 12);listBoxrProxy->setZValue(1);listBoxrProxy->show();rectItem = new QGraphicsRectItem(QRectF(0, 0, 610, 85*4), this);rectItem->setPos(12, 45);rectItem->setPen(Qt::NoPen);rectItem->setFlag(QGraphicsItem::ItemClipsChildrenToShape,true);getLogContents();
}QRectF LogMessagesItem::boundingRect() const
{return QRectF(0,0, _width, _height);
}void LogMessagesItem::setSize(const int width, const int height)
{_width = width;_height = height;
}void LogMessagesItem::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget)
{
}bool LogMessagesItem::eventFilter(QObject *obj, QEvent *event)
{if (obj != calendar && event->type() == QEvent::MouseButtonPress) {this->clearFocus();calendar->setHideQDialog();return true;}if (event->type() == QEvent::Hide) {calendar->setHideQDialog();}if (event->type() == QEvent::Show) {}return QObject::eventFilter(obj, event);
}void LogMessagesItem::getLogContents()
{for (int i =0; i < 22; i++) {QList<QString> data;data.append("2015-02-13 12:08:57");data.append("新建系统");data.append("系统创建完毕");data.append(tr("成功创建系统(%1)").arg(i + 1));LogContentItem *contentItem = new LogContentItem(rectItem);contentItem->setData(data);contentItem->hide();logItem.append(contentItem);}
}void LogMessagesItem::showLogs()
{totalLogs = logItem.count();//totalLogs = 22;totalPageNumber = 6;//currentPageNumber = 1;hideLogItem();pageNumber->setTitle(tr("合计日志条数"), 22);pageNumber->setCurrentAndTotalPage(currentPageNumber, 6);LogContentItem *item = NULL;int index = (currentPageNumber - 1)*MAXLOGSRPERPAGE;for(int number = 0; index < totalLogs && index < currentPageNumber*MAXLOGSRPERPAGE; index++, number++) {item = logItem.at(index);item->setPos(0, number*85);item->show();QGraphicsItemAnimation *animation = new QGraphicsItemAnimation(this);animation->setItem(item);QTimeLine *timeLine = new QTimeLine(400);animation->setTimeLine(timeLine);if (leftToRight == true) {animation->setPosAt(0, QPointF( -608, number*85));animation->setPosAt(1, QPointF(0, number*85));}else {animation->setPosAt(0, QPointF( 608, number*85));animation->setPosAt(1, QPointF(0, number*85));}timeLine->start();}
}void LogMessagesItem::hideLogItem()
{for (int index = 0; index < logItem.count(); index++) {if (logItem.at(index)) {logItem.at(index)->hide();}}
}void LogMessagesItem::slotCalendarFinish()
{showLogs();
}void LogMessagesItem::slotLogPageChange(int index)
{if (currentPageNumber < index) {leftToRight = true;}else {leftToRight = false;}currentPageNumber = index;showLogs();
}/*****************************LogContentItem********************************/
LogContentItem::LogContentItem(QGraphicsItem *parent): QGraphicsItem(parent)
{timeText = new QGraphicsTextItem(this);timeText->setDefaultTextColor(QColor("#999999"));timeText->setFont(QFont("arial", 10, QFont::Normal));timeText->setPos(boundingRect().right() - 125, boundingRect().top());typeText = new QGraphicsTextItem(this);typeText->setDefaultTextColor(QColor("#666666"));typeText->setFont(QFont("arial", 10, QFont::Normal));typeText->setPos(boundingRect().left() + 15, boundingRect().top() + 10);stateText = new QGraphicsTextItem(this);stateText->setDefaultTextColor(QColor("#666666"));stateText->setFont(QFont("arial", 10, QFont::Normal));stateText->setPos(boundingRect().left() + 15, boundingRect().top() + 30);describeText = new QGraphicsTextItem(this);describeText->setDefaultTextColor(QColor("#666666"));describeText->setFont(QFont("arial", 10, QFont::Normal));describeText->setPos(boundingRect().left() + 15, boundingRect().top() + 50);
}LogContentItem::~LogContentItem()
{
}QRectF LogContentItem::boundingRect() const
{return QRectF(0, 0, 608, 80);
}void LogContentItem::setData(const QList<QString> &data)
{timeText->setPlainText(data.at(0));typeText->setPlainText(QObject::tr("类型:%1").arg(data.at(1)));stateText->setPlainText(QObject::tr("状态:%1").arg(data.at(2)));describeText->setPlainText(QObject::tr("描述:%1").arg(data.at(3)));
}void LogContentItem::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget)
{painter->setPen(QPen(QColor("#BBBBBB")));painter->setBrush(QColor("#FFFFFF"));painter->drawRect(0, 0, 608, 80);
}

(3)LogMessagesView.h

#ifndef LOGMESSAGESVIEW_H
#define LOGMESSAGESVIEW_H#include <QGraphicsView>
#include <QTextCodec>
#include <QtGui>
#include <QtCore>
#include <QDebug>class LogMessagesView : public QGraphicsView
{Q_OBJECTpublic:LogMessagesView(QWidget *parent = 0);~LogMessagesView();protected:void mousePressEvent ( QMouseEvent * event);void mouseMoveEvent(QMouseEvent *event);void mouseReleaseEvent(QMouseEvent *event);private:QPoint dragPosition;bool bPressFlag;
};#endif // LOGMESSAGESVIEW_H

(4)LogMessagesView.cpp

#include "LogMessagesView.h"
#include "LogMessagesItem.h"LogMessagesView::LogMessagesView(QWidget *parent): QGraphicsView(parent), bPressFlag(false)
{QTextCodec *codec = QTextCodec::codecForName("System");QTextCodec::setCodecForLocale(codec);QTextCodec::setCodecForCStrings(codec);QTextCodec::setCodecForTr(codec);int width = 633;int height = 437;setWindowFlags(Qt::Widget |Qt::FramelessWindowHint);//setStyleSheet("background:transparent;border:0px");this->setBackgroundBrush(QBrush(QColor("#EEF7FD")));QGraphicsScene *scene = new QGraphicsScene(this);scene->setSceneRect(-width/2,-height/2,width,height);setSceneRect(2, 2, width - 4, height - 4);setScene(scene);setCacheMode(QGraphicsView::CacheBackground);setViewportUpdateMode(QGraphicsView::BoundingRectViewportUpdate);LogMessagesItem *item = new LogMessagesItem;this->installEventFilter(item);scene->addItem(item);
}LogMessagesView::~LogMessagesView()
{}void LogMessagesView::mousePressEvent ( QMouseEvent * event)
{bPressFlag = true;dragPosition = event->pos();QGraphicsView::mousePressEvent(event);
}void LogMessagesView::mouseMoveEvent(QMouseEvent *event)
{if (bPressFlag) {QPoint relaPos(QCursor::pos() - dragPosition);move(relaPos);}QGraphicsView::mouseMoveEvent(event);
}void LogMessagesView::mouseReleaseEvent(QMouseEvent *event)
{bPressFlag = false;QGraphicsView::mouseReleaseEvent(event);
}

三、总结

(1)因涉及一些项目内容,此处暂不提供源码,请谅解。读者需根据上述思路去完成自己的代码。
(2)可执行程序已上传到CSDN(centos6.6下运行):http://download.csdn.net/detail/taiyang1987912/9436720。
(3)若有问题或建议,请留言,在此感谢!

这篇关于Qt浅谈之四十四动态显示日志(QGraphicsItem)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/797520

相关文章

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

QT Creator配置Kit的实现示例

《QTCreator配置Kit的实现示例》本文主要介绍了使用Qt5.12.12与VS2022时,因MSVC编译器版本不匹配及WindowsSDK缺失导致配置错误的问题解决,感兴趣的可以了解一下... 目录0、背景:qt5.12.12+vs2022一、症状:二、原因:(可以跳过,直奔后面的解决方法)三、解决方

深度剖析SpringBoot日志性能提升的原因与解决

《深度剖析SpringBoot日志性能提升的原因与解决》日志记录本该是辅助工具,却为何成了性能瓶颈,SpringBoot如何用代码彻底破解日志导致的高延迟问题,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言第一章:日志性能陷阱的底层原理1.1 日志级别的“双刃剑”效应1.2 同步日志的“吞吐量杀手”

java -jar example.jar 产生的日志输出到指定文件的方法

《java-jarexample.jar产生的日志输出到指定文件的方法》这篇文章给大家介绍java-jarexample.jar产生的日志输出到指定文件的方法,本文给大家介绍的非常详细,对大家的... 目录怎么让 Java -jar example.jar 产生的日志输出到指定文件一、方法1:使用重定向1、

c++日志库log4cplus快速入门小结

《c++日志库log4cplus快速入门小结》文章浏览阅读1.1w次,点赞9次,收藏44次。本文介绍Log4cplus,一种适用于C++的线程安全日志记录API,提供灵活的日志管理和配置控制。文章涵盖... 目录简介日志等级配置文件使用关于初始化使用示例总结参考资料简介log4j 用于Java,log4c

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按

浅谈MySQL的容量规划

《浅谈MySQL的容量规划》进行MySQL的容量规划是确保数据库能够在当前和未来的负载下顺利运行的重要步骤,容量规划包括评估当前资源使用情况、预测未来增长、调整配置和硬件资源等,感兴趣的可以了解一下... 目录一、评估当前资源使用情况1.1 磁盘空间使用1.2 内存使用1.3 CPU使用1.4 网络带宽二、

nginx配置错误日志的实现步骤

《nginx配置错误日志的实现步骤》配置nginx代理过程中,如果出现错误,需要看日志,可以把nginx日志配置出来,以便快速定位日志问题,下面就来介绍一下nginx配置错误日志的实现步骤,感兴趣的可... 目录前言nginx配置错误日志总结前言在配置nginx代理过程中,如果出现错误,需要看日志,可以把

Qt中实现多线程导出数据功能的四种方式小结

《Qt中实现多线程导出数据功能的四种方式小结》在以往的项目开发中,在很多地方用到了多线程,本文将记录下在Qt开发中用到的多线程技术实现方法,以导出指定范围的数字到txt文件为例,展示多线程不同的实现方... 目录前言导出文件的示例工具类QThreadQObject的moveToThread方法实现多线程QC

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用