您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
#include "mainwindow.h" #include "ui_mainwindow.h" #include <QLinearGradient> #include <QRadialGradient> MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow) { ui->setupUi(this); this->resize(800, 480); } void MainWindow::paintEvent(QPaintEvent *event) { //画直线 QPainter painter(this); painter.setPen(Qt::red); //设置画笔为颜色 painter.drawLine(50, 50, 600, 400); //(50, 50)为初始坐标,(600, 400)为最终坐标 //绘制矩形 QRect为矩形类,QLinearGradient为呈线性梯度的渐变颜色类,线性渐变 // QLinearGradient linear(rect().topLeft(), rect().bottomLeft()); //rect矩形的左上角坐标、右下角坐标,作为渐变颜色的方向 // linear.setColorAt(0, Qt::red); // linear.setColorAt(0.5, Qt::green); // linear.setColorAt(1, Qt::blue); //设置红、绿、蓝变化 // painter.setPen(Qt::gray); //设定画笔颜色,到时侯就是边框颜色 // painter.setBrush(linear); //设置画笔,到时候就是区域颜色 // painter.drawRect(QRect(0, 30, this->width(), this->height()-30)); //设置绘制区域 画矩形,左上角横纵坐标、矩形宽度和高度 //绘制矩形 辐射渐变 // QRadialGradient radialGradient(310,110,100,310,110);//创建了一个QRadialGradient对象实例,参数分别为中心坐标,半径长度和焦点坐标,如果需要对称那么中心坐标和焦点坐标要一致 // radialGradient.setColorAt(0, Qt::green); // //radialGradient.setColorAt(0.2,Qt::white); // radialGradient.setColorAt(0.4,Qt::blue); // //radialGradient.setColorAt(0.6,Qt::red); // radialGradient.setColorAt(1.0,Qt::yellow); // painter.setBrush(QBrush(radialGradient)); // painter.drawEllipse(210,10,200,200);//在相应的坐标画出来 //绘制矩形 弧度渐变 // QConicalGradient conicalGradient(510,110,0); //创建了一个QConicalGradient对象实例,参数分别为中心坐标和初始角度 // conicalGradient.setColorAt(0,Qt::green); // conicalGradient.setColorAt(0.2,Qt::white); // conicalGradient.setColorAt(0.4,Qt::blue); // conicalGradient.setColorAt(0.6,Qt::red); // conicalGradient.setColorAt(0.8,Qt::yellow); // conicalGradient.setColorAt(1.0,Qt::green); // //设置渐变的颜色和路径比例 // painter.setBrush(QBrush(conicalGradient)); // painter.drawEllipse(410,10,200,200);//在相应的坐标画出来 //绘制折线 painter.setPen(Qt::red); static const QPointF points[4] = {QPointF(0, 30), QPointF(0, this->height()-1), QPointF(this->width()-1, this->height()-1), QPointF(this->width()-1, 30)}; painter.drawPolyline(points, 4); //由4个点连成的折线 } MainWindow::~MainWindow() { delete ui; }
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。