例項QT程式 —— Qt自繪製小時鐘
目錄
1.簡介
本文主要介紹瞭如何在控制元件中自定義繪製圖形,重點內容包含
- 如何繪製秒針;
- 如何繪製數字。
本文還有動態效果圖、重點講解和原始碼,讀者們可以方便檢視學習和交流。
回目錄
2.效果圖
3.重點講解
1)如何繪製秒針
通過遞迴地方式依次遍歷控制元件佈局中包含的所有子佈局、子控制元件的方式來獲取指定控制元件及其子控制元件的物件資訊(物件名稱、物件型別名稱)。
“秒針”指標的繪製座標點
static const QPoint secondHand[3] = {
QPoint(7, 8),
QPoint(-7, 8),
QPoint(0, -80)
};
繪製秒針:
p->rotate(6.0 * time.second());
p->drawConvexPolygon(secondHand, 3);
以下是“秒針”指標的截圖資訊:
“秒針”指標
2)如何繪製數字
先定義繪製字型大小,迴圈依次通過 QPainter::drawText 繪製刻度上的字型:
QFont font = p->font();
font.setPixelSize(10);
p->setFont(font);
for (int i = 0; i < 12; ++i) {
p->drawLine(88, 0, 96, 0);
p->rotate(30.0);
int nNum = i + 4;
if( nNum > 12 ){
nNum -= 12;
}
p->drawText(75, 0, QString::number(nNum));
}
4.原始碼
注:本文參考Qt Demo程式修改。
main.cpp
#include <QtGui>
#include "rasterwindow.h"
//! [5]
class AnalogClockWindow : public RasterWindow
{
public:
AnalogClockWindow();
protected:
void timerEvent(QTimerEvent *) override;
void render(QPainter *p) override;
private:
int m_timerId;
};
//! [5]
//! [6]
AnalogClockWindow::AnalogClockWindow()
{
setTitle("Analog Clock");
resize(200, 200);
m_timerId = startTimer(1000);
}
//! [6]
//! [7]
void AnalogClockWindow::timerEvent(QTimerEvent *event)
{
if (event->timerId() == m_timerId)
renderLater();
}
//! [7]
//! [1] //! [14]
void AnalogClockWindow::render(QPainter *p)
{
//! [14]
//! [8]
static const QPoint hourHand[3] = {
QPoint(7, 8),
QPoint(-7, 8),
QPoint(0, -40)
};
static const QPoint minuteHand[3] = {
QPoint(7, 8),
QPoint(-7, 8),
QPoint(0, -70)
};
static const QPoint secondHand[3] = {
QPoint(7, 8),
QPoint(-7, 8),
QPoint(0, -80)
};
QColor hourColor(127, 0, 127);
QColor minuteColor(0, 127, 127, 191);
// QColor secondColor(0, 255, 255, 0);
QColor secondColor(Qt::red);
//! [8]
//! [9]
p->setRenderHint(QPainter::Antialiasing);
//! [9] //! [10]
p->translate(width() / 2, height() / 2);
int side = qMin(width(), height());
p->scale(side / 200.0, side / 200.0);
//! [1] //! [10]
//! [11]
p->setPen(Qt::NoPen);
p->setBrush(hourColor);
//! [11]
//! [2]
QTime time = QTime::currentTime();
p->save();
qreal nReal = 30.0 * ((time.hour() + time.minute() / 60.0));
p->rotate(nReal);
p->drawConvexPolygon(hourHand, 3); // 繪製
p->restore();
//! [2]
//! [12] // 繪製 時針 刻度
p->setPen(hourColor);
QFont font = p->font();
font.setPixelSize(10);
p->setFont(font);
// p->rotate(-nReal);
qDebug() << "nReal" << nReal;
for (int i = 0; i < 12; ++i) {
p->drawLine(88, 0, 96, 0);
p->rotate(30.0);
int nNum = i + 4;
if( nNum > 12 ){
nNum -= 12;
}
p->drawText(75, 0, QString::number(nNum));
}
// const QRect rectangle = QRect(75, 88, 10, 10);
// p->drawText(rectangle, Qt::AlignCenter, QString::number(12));
//! [12] //! [13]
p->setPen(Qt::NoPen);
p->setBrush(minuteColor);
//! [13]
//! [3]
p->save();
p->rotate(6.0 * (time.minute() + time.second() / 60.0));
p->drawConvexPolygon(minuteHand, 3);
p->restore();
//! [3]
//! [4] // 繪製 分/秒針 刻度
p->setPen(minuteColor);
p->setFont(QFont("Arial", 30));
for (int j = 0; j < 60; ++j) {
if ((j % 5) != 0){
p->drawLine(92, 0, 96, 0);
}else{
// p->drawText(rect(), Qt::AlignCenter, "Qt");
// p->drawText(85, 0, QString::number(j/5));
}
p->rotate(6.0);
}
p->setPen(Qt::NoPen);
p->setBrush(secondColor);
//! [3]
p->save();
p->rotate(6.0 * time.second());
p->drawConvexPolygon(secondHand, 3);
p->restore();
//! [3]
//! [4]
p->setPen(secondColor);
//! [4]
}
int main(int argc, char **argv)
{
QGuiApplication app(argc, argv);
AnalogClockWindow clock;
clock.show();
return app.exec();
}
加油,向未來!GO~
Come on!
相關文章
- 例項QT程式 —— Qt單例不規則介面程式QT單例
- Qt繪圖淺析與例項QT繪圖
- canvas繪製圓形鐘錶程式碼例項Canvas
- QT OPENGL 與 shader 繪製展示視訊程式碼例項 OPenGL直接顯示YUV資料QT
- QT繪製簡易錶盤QT
- 基於QT錄製PCM音訊例項詳細QT音訊
- canvas繪製扇形程式碼例項Canvas
- qt之點的繪製示例demoQT
- canvas繪製網格程式碼例項Canvas
- css繪製圓形程式碼例項CSS
- Qt繪製自定義箭頭圖元QT
- Qt 介面美化教程 QSS QML Qt自繪方式優缺點對比QT
- QT時鐘控制元件顯示QT控制元件
- canvas繪製機器貓程式碼例項Canvas
- canvas繪製拋物線程式碼例項Canvas線程
- SVG拖動繪製矩形程式碼例項SVG
- canvas繪製箭頭效果程式碼例項Canvas
- C/C++ QT QChart 繪製元件應用C++QT元件
- vlc qt player 播放器開發例項QT播放器
- 如何自學qt(12)——簡單的繪圖QT繪圖
- UML類圖繪製例項
- QT風格(QStyle):繪製一個自定義QComboBoxQT
- Qt5雙緩衝機制與例項QT
- CSS 繪製一個時鐘CSS
- E-R圖繪製例項
- 資料流圖繪製例項
- QT Creator/QT Designer佈局自適應QT
- Python例項:僅繪製圖例而不繪製實際的圖形Python
- Qt5MV自定義模型與例項淺析QT模型
- Qt自定義訊號槽的使用淺析+例項QT
- C++ Qt開發:Charts折線圖繪製詳解C++QT
- 3分鐘教會你如何釋出Qt程式QT
- Qt 獲取程式編譯時間QT編譯
- Qt:Qt自適應高解析度螢幕QT
- CSS3繪製太極圖程式碼例項詳解CSSS3
- C++ Qt開發:Charts繪製各類圖表詳解C++QT
- 用GDI+旋轉多邊形來繪製一個時鐘摸擬小程式
- Qt大型工程開發技術選型Part3:Qt呼叫C#編寫的COM元件例項QTC#元件