Qt-图像绘制控制之QMatrix类

Qt-图像绘制控制之QMatrix类

QMatrix类实现显示图片过程中对图片进行缩放、旋转等一系列二维座标系统的转换动作可以藉由QMatrixsetMatrix()方法设定m11m12m21m22dxdy,或者是直接使用translate()rotate()scale()shear()等方法来直接进行移动、旋转、缩放、扭曲等座标转换。
 以下范例为色彩轮的绘制

#include <QApplication>
#include <QWidget>
#include <QPainter>
#include <QMatrix>

class PainterWidget : public QWidget {
protected:
    void paintEvent(QPaintEvent*);
};

void PainterWidget::paintEvent(QPaintEvent *event) {
    QPainter painter(this);
    QFont font("times", 18, QFont::Bold);
    painter.setFont(font);
    painter.setPen(Qt::black);

    for (int i = 0; i < 36; i++) {                // 進行 36 次旋轉
        QMatrix matrix;
        matrix.translate(250, 250);               // 移動中心至 (250, 250)
        matrix.shear(0.0, 0.3);                   // 扭曲
        matrix.rotate((float) i * 10);            // 每次旋轉 10 度
        painter.setWorldMatrix(matrix);           // 使用這個 QMatrix

        QColor color;
        color.setHsv(i * 10, 255, 255);           // 設定彩虹效果
        painter.setBrush(color);                  // 設定筆刷顏色
        painter.drawRect(70, -10, 80, 10);        // 畫矩形

        QString str;
        str.sprintf("H=%d", i*10);
        painter.drawText(80 + 70 + 5, 0, str);    // 繪製角度文字
    }
}

int main(int argc, char *argv[]) {
    QApplication app(argc, argv);
    
    PainterWidget pWidget;
    pWidget.setWindowTitle("QMatrix");
    pWidget.resize(500, 500);
    pWidget.show();
    
    return app.exec();
}

下图为执行时的参考画面:

  • 8
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值