QCustomPlot QCPColorMap 颜色图尺寸大小

本文档介绍如何解决在使用QCustomPlot的QCPColorMap显示剖面图时,由于比例不正确导致的图像畸变问题。通过设置颜色图的尺寸和坐标轴范围,确保图像比例正确。同时,文章还展示了如何添加和配置QCPColorScale色条,以及调整其显示样式。
摘要由CSDN通过智能技术生成

在使用QCPColorMap来显示剖面图时,在使用了色条QCPColorScale之后,发现剖面图的宽度和高度的比例不对,导致看起来有畸变。这篇文章主要是为了能够设置颜色图的尺寸,使得图像的比例看起来是正确的。

// ui.ImageWidget为QCustomPlot 
ui.ImageWidget->addGraph();
// 创建一个矩形区域,将颜色图放在里面
QCPAxisRect* axisRect = ui.ImageWidget->axisRect(0);
axisRect->setupFullAxesBox(true);
m_pColorMap = new QCPColorMap(axisRect->axis(QCPAxis::atBottom), axisRect->axis(QCPAxis::atLeft));
// 设置矩形区域的尺寸(即为颜色图的大小),单位为像素点
axisRect->setMaximumSize(200, 200); // 最大尺寸
axisRect->setMinimumSize(200, 200); // 最小尺寸

m_pColorMap->data()->setSize(200, 200);
m_pColorMap->data()->setRange(QCPRange(0200), QCPRange(0200));//setRange是设置X轴以及Y轴的范围

colorScale = new QCPColorScale(ui.ImageWidget);  // 构造一个色条
colorScale->setType(QCPAxis::atRight);   // 水平显示atLeft,atRight,atTop,atBottom
colorScale->setDataRange(QCPRange(0, 1024));  //设置色条的数值最大最小
m_pColorMap->setColorScale(colorScale);
colorScale->setBarWidth(5);  // 设置色条的宽度(像素点)
// 设置qcustomplot的布局,颜色图在左边,色条在右边
ui.ImageWidget->plotLayout()->addElement(0, 0, axisRect); 
ui.ImageWidget->plotLayout()->addElement(0, 1, colorScale); 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值