QT中的二维绘图

基本绘制和填充

在绘图系统中由QPainter来完成具体的绘制操作,QPainter类提供了大量高度优化的函数来完成GUI编程所需要的大部分绘制工作。
QPainter一般在一个部件的重绘事件(Paint Event)的处理函数paintEvent()中进行绘制
1 widget.h文件

protected:
    void paintEvent(QPaintEvent *event);

2 widget.cpp文件

void Widget::paintEvent(QPaintEvent *event)
{
    QPainter painter(this);
    painter.drawLine(QPoint(0, 0), QPoint(100, 100));
}

QPainter中常用图形绘制函数

在这里插入图片描述

使用画笔

创建画笔

QPen pen(Qt::green, 5, Qt::DotLine, Qt::RoundCap, Qt::RoundJoin);

使用画笔

painter.setPen(pen);
QRectF rectangle(70.0, 40.0, 80.0, 60.0);
int startAngle = 30 * 16;
int spanAngle = 120 * 16;

绘制圆弧

painter.drawArc(rectangle, startAngle, spanAngle);

QPen类为QPainter提供了画笔来绘制线条和形状的轮廓,几个参数依次为画笔使用的画刷、线宽、画笔风格、画笔端点风格和画笔连接风格,它们也可以分别使用setBrush()、setWidth()、setStyle()、setCapStyle()和setJoinStyle()等函数来进行设置。

使用画刷

创建画刷

QBrush brush(QColor(0, 0, 255), Qt::Dense4Pattern);

使用画刷

painter.setBrush(brush);

绘制椭圆

painter.drawEllipse(220, 20, 50, 50);

设置纹理

brush.setTexture(QPixmap("../myDrawing/a.png"));

重新使用画刷

painter.setBrush(brush);

定义四个点

static const QPointF points[4] = {
QPointF(270.0, 80.0),
QPointF(290.0, 10.0),
QPointF(350.0, 30.0),
QPointF(390.0, 70.0)
};

使用四个点绘制多边形

painter.drawPolygon(points, 4);
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要在Qt显示二维光谱图像,你可以使用Qt的QCustomPlot库。这个库可以让你在一个QWidget显示图像,并且支持缩放和平移等常见操作。 下面是一个简单的示例代码,用于在Qt显示一个二维光谱图像: ```c++ #include <QApplication> #include "qcustomplot.h" int main(int argc, char *argv[]) { QApplication a(argc, argv); // 创建一个QWidget对象,用于显示图像 QWidget *widget = new QWidget; widget->resize(800, 600); // 创建一个QCustomPlot对象,用于绘制图像 QCustomPlot *customPlot = new QCustomPlot(widget); customPlot->setGeometry(0, 0, 800, 600); // 生成一些测试数据 QVector<double> x(101), y(101), z(101*101); for (int i=0; i<101; ++i) { x[i] = i/50.0 - 1; y[i] = i/50.0 - 1; } for (int i=0; i<101; ++i) { for (int j=0; j<101; ++j) { z[i*101+j] = qCos(qSqrt(x[i]*x[i]+y[j]*y[j]))*qExp(-qSqrt(x[i]*x[i]+y[j]*y[j])/5); } } // 设置图像的颜色映射 QCPColorMap *colorMap = new QCPColorMap(customPlot->xAxis, customPlot->yAxis); colorMap->data()->setSize(101, 101); colorMap->data()->setRange(QCPRange(-1, 1), QCPRange(-1, 1)); for (int i=0; i<101; ++i) { for (int j=0; j<101; ++j) { colorMap->data()->setCell(i, j, z[i*101+j]); } } colorMap->setGradient(QCPColorGradient::gpJet); // 将颜色映射添加到QCustomPlot,并刷新图像 customPlot->addPlottable(colorMap); customPlot->rescaleAxes(); customPlot->replot(); // 将QWidget显示出来 widget->show(); return a.exec(); } ``` 这个例子使用了QCPColorMap来绘制二维光谱图像,并且将它添加到了QCustomPlot。你可以根据自己的需求来修改这个例子的数据和绘图参数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

尘客-追梦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值