前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Qt官方示例-图表缩放

Qt官方示例-图表缩放

作者头像
Qt君
发布2020-07-02 15:00:04
1.9K0
发布2020-07-02 15:00:04
举报
文章被收录于专栏:跟Qt君学编程跟Qt君学编程

该示例显示了使用QRubberBand创建自定义的缩放效果,以及如何使用触摸手势进行平移和缩放。

  图表缩放基于QChart类的zoomzoomInzoomOut实现。

自定义缩放效果

  首先,我们创建一个包含一些示例数据的线系列。

代码语言:javascript
复制
QLineSeries *series = new QLineSeries();
for (int i = 0; i < 500; i++) {
    QPointF p((qreal) i, qSin(M_PI / 50 * i) * 100);
    p.ry() += QRandomGenerator::global()->bounded(20);
    *series << p;
}

  然后,我们通过从QChartView派生创建自定义图表视图:

代码语言:javascript
复制
class ChartView : public QChartView

  我们重写覆盖了鼠标和按键的事件处理:

代码语言:javascript
复制
protected:
    bool viewportEvent(QEvent *event);
    void mousePressEvent(QMouseEvent *event);
    void mouseMoveEvent(QMouseEvent *event);
    void mouseReleaseEvent(QMouseEvent *event);
    void keyPressEvent(QKeyEvent *event);

  然后,我们为鼠标和按键事件实现自定义逻辑。例如,按"+"键将放大,而按"-"键将缩小。

代码语言:javascript
复制
void ChartView::keyPressEvent(QKeyEvent *event)
{
    switch (event->key()) {
    case Qt::Key_Plus:
        chart()->zoomIn();
        break;
    case Qt::Key_Minus:
        chart()->zoomOut();
        break;

  我们还创建了自己的QChart:

代码语言:javascript
复制
class Chart : public QChart

  处理手势的代码:

代码语言:javascript
复制
bool Chart::sceneEvent(QEvent *event)
{
    if (event->type() == QEvent::Gesture)
        return gestureEvent(static_cast<QGestureEvent *>(event));
    return QChart::event(event);
}

bool Chart::gestureEvent(QGestureEvent *event)
{
    if (QGesture *gesture = event->gesture(Qt::PanGesture)) {
        QPanGesture *pan = static_cast<QPanGesture *>(gesture);
        QChart::scroll(-(pan->delta().x()), pan->delta().y());
    }

    if (QGesture *gesture = event->gesture(Qt::PinchGesture)) {
        QPinchGesture *pinch = static_cast<QPinchGesture *>(gesture);
        if (pinch->changeFlags() & QPinchGesture::ScaleFactorChanged)
            QChart::zoom(pinch->scaleFactor());
    }

    return true;
}

  需要注意的是,你将需要同时对QMainWindow和QChart调用grabGesture()。

关于更多

  • QtCreator软件可以找到:
  • 或在以下Qt安装目录找到:
代码语言:javascript
复制
C:\Qt\{你的Qt版本}\Examples\{你的Qt版本}\charts\zoomlinechart
  • 相关链接
代码语言:javascript
复制
https://doc.qt.io/qt-5/qtcharts-zoomlinechart-example.html
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-06-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Qt君 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 自定义缩放效果
  • 关于更多
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档