二維碼
企資網

掃一掃關注

當前位置: 首頁 » 企資快報 » 體驗 » 正文

用Qt畫一個漂亮預警儀表

放大字體  縮小字體 發布日期:2023-04-09 10:43:29    作者:江煌墩    瀏覽次數:209
導讀

以下是用Qt實現漂亮預警儀表得步驟和代碼:創建一個Qt項目,并添加一個主窗口。在主窗口中添加QGraphicsView控件,用于繪制預警儀表。創建一個QGraphicsScene對象,并將其設置為QGraphicsView得場景。QGraphicsScene

以下是用Qt實現漂亮預警儀表得步驟和代碼:

創建一個Qt項目,并添加一個主窗口。在主窗口中添加QGraphicsView控件,用于繪制預警儀表。創建一個QGraphicsScene對象,并將其設置為QGraphicsView得場景。

QGraphicsScene govscene = new QGraphicsScene(this);ui->graphicsView->setScene(scene);

4.創建一個QGraphicsEllipseItem對象,用于表示預警儀表得外框。

QGraphicsEllipseItem govouterCircle = new QGraphicsEllipseItem(QRectF(-120,-120,240,240));outerCircle->setPen(QPen(Qt::black, 4));scene->addItem(outerCircle);

5.創建一個QGraphicsEllipseItem對象,用于表示預警儀表得中心點。

QGraphicsEllipseItem govcenterCircle = new QGraphicsEllipseItem(QRectF(-15,-15,30,30));centerCircle->setBrush(QBrush(Qt::red));centerCircle->setPen(QPen(Qt::black, 2));centerCircle->setZValue(1);scene->addItem(centerCircle);

6.創建一些QGraphicsLineItem對象,用于表示預警儀表得刻度線。

for (int i = 0; i < 12; i++) { QGraphicsLineItem govline = new QGraphicsLineItem(-100, 0, -80, 0); line->setPen(QPen(Qt::black, 3)); line->setRotation(i gov 30); line->setPos(0, 0); scene->addItem(line);}

7.創建一個QGraphicsPolygonItem對象,用于表示預警儀表得指針。

QPolygonF polygon;polygon << QPointF(-10, 0) << QPointF(0, -120) << QPointF(10, 0);QGraphicsPolygonItem govpointer = new QGraphicsPolygonItem(polygon);pointer->setBrush(QBrush(Qt::red));pointer->setPen(QPen(Qt::black, 2));pointer->setZValue(2);pointer->setPos(0, 0);scene->addItem(pointer);

8.在主窗口得定時器中更新指針得旋轉角度。

void MainWindow::timerEvent(QTimerEvent govevent){ Q_UNUSED(event); int angle = ui->spinBox->value(); QGraphicsItem govitem = ui->graphicsView->scene()->items().at(3); item->setRotation(angle);}

完整得代碼如下:

QT開發交流+貲料君羊:714620761

mainwindow.h

#ifndef MAINWINDOW_H#define MAINWINDOW_H#include <QMainWindow>#include <QGraphicsScene>#include <QGraphicsEllipseItem>#include <QGraphicsPolygonItem>#include <QGraphicsLineItem>QT_BEGIN_NAMESPACEnamespace Ui { class MainWindow; }QT_END_NAMESPACEclass MainWindow : public QMainWindow{ Q_OBJECTpublic: MainWindow(QWidget govparent = nullptr); ~MainWindow();protected: void timerEvent(QTimerEvent govevent);private: Ui::MainWindow govui; QGraphicsScene govscene; QGraphicsEllipseItem govouterCircle; QGraphicsEllipseItem govcenterCircle; QGraphicsPolygonItem govpointer; QList<QGraphicsLineItemgov> lines;};#endif // MAINWINDOW_H

mainwindow.cpp

#include "mainwindow.h"#include "ui_mainwindow.h"MainWindow::MainWindow(QWidget govparent) : QMainWindow(parent) , ui(new Ui::MainWindow){ ui->setupUi(this); // 創建場景 scene = new QGraphicsScene(this); ui->graphicsView->setScene(scene); // 創建外框 outerCircle = new QGraphicsEllipseItem(QRectF(-120,-120,240,240)); outerCircle->setPen(QPen(Qt::black, 4)); scene->addItem(outerCircle); // 創建中心點 centerCircle = new QGraphicsEllipseItem(QRectF(-15,-15,30,30)); centerCircle->setBrush(QBrush(Qt::red)); centerCircle->setPen(QPen(Qt::black, 2)); centerCircle->setZValue(1); scene->addItem(centerCircle); // 創建指針 QPolygonF polygon; polygon << QPointF(-10, 0) << QPointF(0, -120) << QPointF(10, 0); pointer = new QGraphicsPolygonItem(polygon); pointer->setBrush(QBrush(Qt::red)); pointer->setPen(QPen(Qt::black, 2)); pointer->setZValue(2); pointer->setPos(0, 0); pointer->setRotation(0); scene->addItem(pointer); // 創建刻度線 for (int i = 0; i < 12; i++) { QGraphicsLineItem govline = new QGraphicsLineItem(-100, 0, -80, 0); line->setPen(QPen(Qt::black, 3)); line->setRotation(i gov 30); line->setPos(0, 0); lines.append(line); scene->addItem(line); } // 啟動定時器 startTimer(100);}MainWindow::~MainWindow(){ delete ui;}void MainWindow::timerEvent(QTimerEvent govevent){ Q_UNUSED(event); int angle = ui->spinBox->value(); QGraphicsItem govitem = ui->graphicsView->scene()->items().at(3); pointer->setRotation(angle);}

用Qt畫一個漂亮預警儀表,具有立體感,代碼,描述設計步驟

 
(文/江煌墩)
免責聲明
本文僅代表作發布者:江煌墩個人觀點,本站未對其內容進行核實,請讀者僅做參考,如若文中涉及有違公德、觸犯法律的內容,一經發現,立即刪除,需自行承擔相應責任。涉及到版權或其他問題,請及時聯系我們刪除處理郵件:weilaitui@qq.com。
 

Copyright ? 2016 - 2025 - 企資網 48903.COM All Rights Reserved 粵公網安備 44030702000589號

粵ICP備16078936號

微信

關注
微信

微信二維碼

WAP二維碼

客服

聯系
客服

聯系客服:

在線QQ: 303377504

客服電話: 020-82301567

E_mail郵箱: weilaitui@qq.com

微信公眾號: weishitui

客服001 客服002 客服003

工作時間:

周一至周五: 09:00 - 18:00

反饋

用戶
反饋

主站蜘蛛池模板: 一级看片免费视频| 北条麻妃中文字幕在线观看| 亚洲av无码第一区二区三区| 5g影院天天爽天天| 黑人玩弄漂亮少妇高潮大叫| 精品国产一区二区三区在线 | 一区二区三区在线免费看 | 国产成人久久精品二区三区| 亚洲av无码一区二区乱孑伦as | 天天影视综合网色综合国产| 伊人热热久久原色播放www| JLZZJLZZ全部女高潮| 波多野结衣57分钟办公室| 成人在线观看免费| 国产又色又爽在线观看| 久久国内精品自在自线400部o| 高清国产av一区二区三区| 日本japanese丰满奶水| 国产av无码专区亚洲a∨毛片| 久久综合香蕉国产蜜臀AV| 高清欧美性暴力猛交| 无码人妻少妇久久中文字幕| 又黄又大又爽免费视频| 一区二区三区在线视频播放| 狠狠做深爱婷婷久久综合一区| 国色天香论坛社区在线视频| 国产一级做a爰片在线| 中文亚洲成a人片在线观看| 精品三级66在线播放| 成年性羞羞视频免费观看无限 | bt√天堂资源在线官网| 毛片a级毛片免费观看品善网| 国产精品免费看久久久久| 九一制片厂果冻传媒56| 色眯眯日本道色综合久久| 日韩乱码人妻无码中文字幕| 国产一级特黄aa级特黄裸毛片| 三级韩国床戏3小时合集| 波多野结衣办公室jian情| 国产男女猛烈无遮挡免费视频 | 看全色黄大色大片免费久久 |