您好,登錄后才能下訂單哦!
(1)用鼠標(biāo)框選一個(gè)矩形,把圖放大到這個(gè)矩形
QChartView::setRubberBand(QChartView::RectangleRubberBand);//XY方向同時(shí)放大到鼠標(biāo)畫出的矩形大?。ㄒ部梢栽O(shè)置為只放大X軸或Y軸)
(2)setRubberBand函數(shù)同時(shí)也能使鼠標(biāo)右鍵,具備縮小圖的功能。
QChart::scroll(-10, 5);//整體平移(-10, 5),兩個(gè)參數(shù)分別為Δx和Δy
QChart::zoomIn(x,y,width,height);//縮放到指定的矩形
QChart::zoom(0.9) //整體縮放,參數(shù)為放縮系數(shù),<1代表縮小,>1代表放大
QChart::zoomReset() //把所有做過的zoomIn、zoomOut、zoom全部撤銷
原理就是,通過設(shè)置X/Y軸的范圍來實(shí)現(xiàn)平移和縮放。
例如,當(dāng)前顯示X的顯示范圍為[20, 50],如果我們把X軸的顯示范圍擴(kuò)大到[0, 80],這樣做的效果就是顯示的圖形變小了,也就實(shí)現(xiàn)了縮放。
例如,當(dāng)前顯示X的顯示范圍為[0, 30],如果我們把X軸的顯示范圍擴(kuò)大到[10, 40],這樣做的效果就是顯示的圖形左移了,也就實(shí)現(xiàn)了平移。
示例代碼:
QValueAxis *axisX = dynamic_cast<QValueAxis*>(Chart->axisX(pLineSeries));//
qreal cur_x_min = axisX->min();
qreal cur_x_max = axisX->max();
axisX->setRange(cur_x_min + 20, cur_x_max + 20);//圖形向左平移20(為什么+代表左移?仔細(xì)想想就明白了)
放縮與平移的示例代碼同理
運(yùn)行效果如下:
.h文件代碼
#ifndef QTCHARTDEMOZOOM_H_38020FA5_FC74_4395_A807_61BF924D2F06 #define QTCHARTDEMOZOOM_H_38020FA5_FC74_4395_A807_61BF924D2F06 #include <QtCharts/QChartView> using namespace QtCharts; class QtChartDemoZoom : public QChartView { Q_OBJECT public: QtChartDemoZoom(QWidget* pParent = nullptr); ~QtChartDemoZoom(); protected: virtual void mouseMoveEvent(QMouseEvent *pEvent) override; virtual void mousePressEvent(QMouseEvent *pEvent) override; virtual void mouseReleaseEvent(QMouseEvent *pEvent) override; virtual void wheelEvent(QWheelEvent *pEvent) override; private: bool m_bMiddleButtonPressed; QPoint m_oPrePos; }; #endif //QTCHARTDEMOZOOM_H_38020FA5_FC74_4395_A807_61BF924D2F06
.cpp文件代碼
#include <QLineSeries> QtChartDemoZoom::QtChartDemoZoom(QWidget* pParent /*= nullptr*/) : QChartView(pParent) , m_bMiddleButtonPressed(false) , m_oPrePos(0, 0) { QLineSeries *pLineServies = new QLineSeries(); for (int i = 0; i < 100; ++i) { pLineServies->append(i, qrand() % 10); } this->chart()->addSeries(pLineServies); this->chart()->createDefaultAxes(); } QtChartDemoZoom::~QtChartDemoZoom() { } void QtChartDemoZoom::mouseMoveEvent(QMouseEvent *pEvent) { if (m_bMiddleButtonPressed) { QPoint oDeltaPos = pEvent->pos() - m_oPrePos; this->chart()->scroll(-oDeltaPos.x(), oDeltaPos.y()); m_oPrePos = pEvent->pos(); } __super::mouseMoveEvent(pEvent); } void QtChartDemoZoom::mousePressEvent(QMouseEvent *pEvent) { if (pEvent->button() == Qt::MiddleButton) { m_bMiddleButtonPressed = true; m_oPrePos = pEvent->pos(); this->setCursor(Qt::OpenHandCursor); } __super::mousePressEvent(pEvent); } void QtChartDemoZoom::mouseReleaseEvent(QMouseEvent *pEvent) { if (pEvent->button() == Qt::MiddleButton) { m_bMiddleButtonPressed = false; this->setCursor(Qt::ArrowCursor); } __super::mouseReleaseEvent(pEvent); } void QtChartDemoZoom::wheelEvent(QWheelEvent *pEvent) { qreal rVal = std::pow(0.999, pEvent->delta()); // 設(shè)置比例 // 1. 讀取視圖基本信息 QRectF oPlotAreaRect = this->chart()->plotArea(); QPointF oCenterPoint = oPlotAreaRect.center(); // 2. 水平調(diào)整 oPlotAreaRect.setWidth(oPlotAreaRect.width() * rVal); // 3. 豎直調(diào)整 oPlotAreaRect.setHeight(oPlotAreaRect.height() * rVal); // 4.1 計(jì)算視點(diǎn),視點(diǎn)不變,圍繞中心縮放 //QPointF oNewCenterPoint(oCenterPoint); // 4.2 計(jì)算視點(diǎn),讓鼠標(biāo)點(diǎn)擊的位置移動(dòng)到窗口中心 //QPointF oNewCenterPoint(pEvent->pos()); // 4.3 計(jì)算視點(diǎn),讓鼠標(biāo)點(diǎn)擊的位置盡量保持不動(dòng)(等比換算,存在一點(diǎn)誤差) QPointF oNewCenterPoint(2 * oCenterPoint - pEvent->pos() - (oCenterPoint - pEvent->pos()) / rVal); // 5. 設(shè)置視點(diǎn) oPlotAreaRect.moveCenter(oNewCenterPoint); // 6. 提交縮放調(diào)整 this->chart()->zoomIn(oPlotAreaRect); __super::wheelEvent(pEvent); }
本文講解了Qt曲線圖表模塊QChart庫縮放/平移詳細(xì)方法與實(shí)例,更多關(guān)于Qt曲線圖表模塊QChart庫的知識(shí)請(qǐng)查看下面的相關(guān)鏈接
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。