日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Qt中的文本绘制

發布時間:2025/4/5 编程问答 17 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Qt中的文本绘制 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

    • 1 Qt中的文本繪制
      • 1.1 文本繪制簡介
      • 1.2 實現文字逐漸變大的效果

1 Qt中的文本繪制

1.1 文本繪制簡介

QPainter擁有繪制文本的能力:

  • drawText(擁有多個重載形式)。
  • 常見調用方式:

文本繪制參數:

  • 字體(QFont)、顏色(QColor):
    • 控制文本大小、風格、顏色等。
  • 坐標(QPoint)、角度(rotate):
    • 文本繪制的位置(對齊該坐標)。
    • 以繪制坐標為圓心順時針旋轉。

文本繪制示例:

簡單文本繪制:
Widget.h:

#ifndef WIDGET_H #define WIDGET_H#include <QtGui/QWidget>class Widget : public QWidget {Q_OBJECT protected:void paintEvent(QPaintEvent *); public:Widget(QWidget *parent = 0);~Widget(); };#endif // WIDGET_H

Widget.cpp:

#include "Widget.h" #include <QPainter>Widget::Widget(QWidget *parent): QWidget(parent) { }void Widget::paintEvent(QPaintEvent *) {QPainter painter(this);painter.save();painter.setPen(Qt::black);painter.setFont(QFont("Arial", 16));painter.rotate(0);painter.drawText(30, 40, "D.T.Software");painter.setPen(Qt::red);painter.setFont(QFont("Comic Sans MS", 20));painter.rotate(20);painter.drawText(30, 40, "D.T.Software");painter.restore();painter.drawText(130, 140, "D.T.Software"); }Widget::~Widget() {}

main.cpp:

#include <QtGui/QApplication> #include "Widget.h"int main(int argc, char *argv[]) {QApplication a(argc, argv);Widget w;w.show();return a.exec(); }

1.2 實現文字逐漸變大的效果

解決方案分析:

  • 在主窗口繪制文本(QWidget)。
  • 將文本中心繪制于窗口中心(width()/2. height()/2)。
  • 動畫效果通過連續控制字體參數完成(QFont)。
  • 通過計時器強行更新文本繪制(QTimer)。
  • 小技巧:

    • 通過QFontMetrics獲取字符串在指定字體下的寬度和高度。


    坐標計算:

    實現如下:

    Widget.h:

    #ifndef WIDGET_H #define WIDGET_H#include <QtGui/QWidget> #include <QTimer>class Widget : public QWidget {Q_OBJECTint m_sizeFactor;QTimer m_timer; protected slots:void onTimeout(); protected:void paintEvent(QPaintEvent *); public:Widget(QWidget *parent = 0);~Widget(); };#endif // WIDGET_H

    Widget.cpp:

    #include "Widget.h" #include <QPainter> #include <QFontMetrics> #include <QFont> #include <QRect>Widget::Widget(QWidget *parent): QWidget(parent) {m_sizeFactor = 0;m_timer.setParent(this);connect(&m_timer, SIGNAL(timeout()), this, SLOT(onTimeout()));m_timer.start(50); }void Widget::onTimeout() {update(); }void Widget::paintEvent(QPaintEvent *) {QPainter painter;const QString text = "D.T.Software";QFont font("Comic Sans MS", 5 + (m_sizeFactor++) % 100);QFontMetrics metrics(font);const int w = metrics.width(text);const int h = metrics.height();QRect rect((width()-w)/2, (height()-h)/2, w, h);painter.begin(this);painter.setPen(Qt::blue);painter.setFont(font);painter.drawText(rect, Qt::AlignCenter, text);painter.end(); }Widget::~Widget() {}

    main.cpp:

    #include <QtGui/QApplication> #include "Widget.h"int main(int argc, char *argv[]) {QApplication a(argc, argv);Widget w;w.show();return a.exec(); }

    參考資料:

  • QT實驗分析教程
  • 總結

    以上是生活随笔為你收集整理的Qt中的文本绘制的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。