qt_painter画家

本文介绍了如何在Qt中使用QPainter进行抗锯齿绘图,并展示了移动画家原点坐标的方法。通过实例演示了如何改进图形绘制质量和布局技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 简单demo:

在这里插入图片描述

代码:

widget.h

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>

namespace Ui {
class Widget;
}

class Widget : public QWidget
{
    Q_OBJECT

public:
    explicit Widget(QWidget *parent = nullptr);
    ~Widget();

    void paintEvent(QPaintEvent*);
private:
    Ui::Widget *ui;
};

#endif // WIDGET_H

widget.c

#include "widget.h"
#include "ui_widget.h"
#include <QPainter>
Widget::Widget(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::Widget)
{
    ui->setupUi(this);
}

void Widget::paintEvent(QPaintEvent *){
    QPainter painter(this);
    QPen pen(QColor(255,0,0));
    QBrush brush(Qt::cyan);
    brush.setStyle(Qt::Dense7Pattern);
    pen.setWidth(3);
    pen.setStyle(Qt::DotLine);
    painter.setPen(pen);
    painter.setBrush(brush);
    painter.drawLine(QPoint(0,0),QPoint(100,100));
    painter.drawEllipse(QPoint(100,100),50,50);
    painter.drawRect(QRect(20,20,50,50));
    painter.drawText(QRect(10,200,150,50),"hello world");
}
Widget::~Widget()
{
    delete ui;
}

2. 抗锯齿设置

在这里插入图片描述

    QPainter painter(this);
    painter.drawEllipse(QPoint(100,50),50,50);
    painter.setRenderHint(QPainter::Antialiasing);
    painter.drawEllipse(QPoint(200,50),50,50);

3. 移动画家的原点坐标

在这里插入图片描述

    painter.drawRect(QRect(20,20,50,50));
    painter.translate(100,0);
    painter.drawRect(QRect(20,20,50,50));
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值