qt qchart学习

Qt Charts主要由QChartView、QChart、QLegend图例、坐标轴(由QAbstractAxis子类实现)、**数据源(由QAbstractSeries子类实现)**等组成

使用QChart的前期准备

1. Qt5.9及以上版本;

2. .pro文件中添加QT += charts

3. 在使用QChart的各个控件之前,引用头文件并必须先声明一个命名空间。如

#include <QtCharts>
using namespace QtCharts; 
或者是
#include <QtCharts>
QT_CHARTS_USE_NAMESPACE 

QChartView

QChartView是QGraphicsView子类,相当于是显示图表的视图。

常用函数

  1. void setChart(QChart *chart); 设置图表。新图表的所有权被传递给图表视图,并且先前图表的所有权被释放。

  1. void setRubberBand(const QChartView::RubberBands &rubberBand) 设置橡皮筋标志

QChart

QChart是QGraphicsItem的子类,相当于是显示图表的图形项。

常用函数

//与序列相关的函数

  1. void addSeries(QAbstractSeries *series); //添加序列

  1. void removeSeries(QAbstractSeries *series);

  1. void removeAllSeries();

  1. QList<QAbstractSeries *> series() const; //获取序列

//与坐标轴相关的函数

  1. void setAxisX(QAbstractAxis *axis, QAbstractSeries *series = Q_NULLPTR);//过时了

  1. void setAxisY(QAbstractAxis *axis, QAbstractSeries *series = Q_NULLPTR);

  1. QAbstractAxis *axisX(QAbstractSeries *series = Q_NULLPTR) const;//过时了

  1. QAbstractAxis *axisY(QAbstractSeries *series = Q_NULLPTR) const;

  1. void addAxis(QAbstractAxis *axis, Qt::Alignment alignment);// 添加坐标轴。现在主要用这个函数

  1. void removeAxis(QAbstractAxis *axis);

  1. QList<QAbstractAxis*> axes(Qt::Orientations orientation = Qt::Horizontal|Qt::Vertical, QAbstractSeries *series = Q_NULLPTR) const; //获取坐标轴

//与图例相关的函数

  1. QLegend *legend() const; 获取图例,图例对象无法创建或删除,但可以通过 QChart 类引用。

序列(QAbstractSeries)

QAbstractSeries 类是所有 Qt 图表曲线的基类。通常,使用曲线类型特定的继承类而不是基类。也是数据源。

可以控制(序列是否显示序列、序列线条的颜色、画笔、画刷、透明度);序列(数据点的可见度、添加插入删除清除数据点);(数据点标签的可见性、颜色、字体、格式)

enum QAbstractSeries::SeriesType:此枚举描述了曲线的类型。
SeriesTypeLine:折线图。
SeriesTypeArea:面积图。
SeriesTypeBar:垂直条形图。
SeriesTypeStackedBar:垂直堆积条形图。
SeriesTypePercentBar:垂直百分比条形图。
SeriesTypePie:饼图。
SeriesTypeScatter:散点图。
SeriesTypeSpline:样条图。
SeriesTypeHorizontalBar:水平条形图。
SeriesTypeHorizontalStackedBar:水平堆积条形图。
SeriesTypeHorizontalPercentBar:水平百分比条形图。
SeriesTypeBoxPlot:箱线图。
SeriesTypeCandlestick:烛台图。

QAbstractBarSeries派生出柱状图、百分比图、堆叠图等。

常用的函数:

//与坐标轴相关

  1. bool attachAxis(QAbstractAxis *axis); //序列和坐标轴关联

  1. bool detachAxis(QAbstractAxis *axis);

  1. QList<QAbstractAxis*> attachedAxes();//获取坐标轴

//与QChart相关

  1. QChart *chart() const;

//与添加删除操作相关

  1. void append(const QList<QPointF> &points); //折线图等的序列数据添加

  1. QXYSeries &operator << (const QPointF &point);//折线图等的序列数据添加

  1. void replace(int index, const QPointF &newPoint);

  1. void remove(const QPointF &point);

  1. void insert(int index, const QPointF &point);

  1. void clear();

坐标轴(QAbstractAxis)

折线图一般用QValueAxis数值坐标轴,或者是QLogValueAxis对数坐标轴。柱状图横坐标通常用文字,如QBarCategoryAxis类别坐标轴。

每个轴的元素(比如轴线,标题,标签,网格线,阴影,可见性)都是可以控制的。

常用函数

图例(QLegend)

图例(Legend)是对图表上显示的序列的示例说明,一般是有线条颜色和文字说明。QLegend是封装了图例控制功能的类,可以为每个序列设置图例中的文字,可以控制图例显示在图表的上、下、左、右不同位置。

图例对象无法创建或删除,但可以通过 QChart 类引用。如在QChart类调用legend函数得到图例指针。QLegend *legend() const;

enum MarkerShape { MarkerShapeDefault, MarkerShapeRectangle, MarkerShapeCircle, MarkerShapeFromSeries }

enum QLegend::MarkerShape:此枚举描述了渲染图例标记项时使用的形状。

MarkerShapeDefault:仅 QLegendMarker 项目支持此值。

MarkerShapeRectangle:矩形标记。

MarkerShapeCircle:圆形标记。

MarkerShapeRotatedRectangle:旋转的矩形标记。

MarkerShapeTriangle:三角形标记。

MarkerShapeStar:星形标记。

MarkerShapePentagon:五角形标记。

MarkerShapeFromSeries:标记形状由曲线决定。在散点曲线的情况下,图例标记看起来像一个散点,并且与该点的大小相同。对于直线或样条曲线,图例标记看起来像直线的一小段。对于其他曲线类型,显示矩形标记。

常用函数

  1. void setAlignment(Qt::Alignment alignment);图例与图表对齐方式

//与图例标记相关

  1. QList <QLegendMarker*> markers(QAbstractSeries *series = Q_NULLPTR) const; //返回图例中的标记列表

  1. void setShowToolTips(bool show);是否tip提示

图例标记(QLegendMarker)

对于图例还有一个类QLegendMarker,可以为每个序列的图例生成一个类似于QCheckBox的组件,在图例上单击序列的标记,可以控制序列是否显示。

图例标记由图标颜色标签组成:

图标颜色对应于用于绘制图表的颜色。

标签显示曲线的名称(或饼图的切片标签或条形图的条形集的标签)。

QLegendMarker 类是一个抽象类,可用于访问图例中的标记。是 QAreaLegendMarker、QBarLegendMarker、QBoxPlotLegendMarker、QCCandlestickLegendMarker、QPieLegendMarker、QXYLegendMarker 的父类。

enum QLegendMarker::LegendMarkerType:图例标记对象的类型。

LegendMarkerTypeArea:区域图的图例标记。

LegendMarkerTypeBar:条形图的图例标记。

LegendMarkerTypePie:饼图的图例标记。

LegendMarkerTypeXY曲线、样条线或散点图的图例标记。

LegendMarkerTypeBoxPlot:箱型图的图例标记。

LegendMarkerTypeCandlestick:烛台图的图例标记。

常用函数

  1. void setLabelBrush(const QBrush &brush); 标签的画刷

  1. void setBrush(const QBrush &brush);图标颜色画刷

  1. virtual LegendMarkerType type() = 0;

//与序列相关的函数

  1. virtual QAbstractSeries* series() = 0;

信号

  1. void clicked(); //用于点击图例标记的信号槽处理。

  1. void hovered(bool status);

   foreach (QLegendMarker* marker, chart->legend()->markers()) {
        QObject::disconnect(marker, SIGNAL(clicked()), this, SLOT(on_LegendMarkerClicked()));
        QObject::connect(marker, SIGNAL(clicked()), this, SLOT(on_LegendMarkerClicked()));
    }

void MainWindow::on_LegendMarkerClicked()
{
    QLegendMarker* marker = qobject_cast<QLegendMarker*> (sender());

    switch (marker->type())
    {
        case QLegendMarker::LegendMarkerTypeXY:
        {
            marker->series()->setVisible(!marker->series()->isVisible());
            marker->setVisible(true);
            qreal alpha = 1.0;
            if (!marker->series()->isVisible())
                alpha = 0.5;

            QColor color;
            QBrush brush = marker->labelBrush();
            color = brush.color();
            color.setAlphaF(alpha);
            brush.setColor(color);
            marker->setLabelBrush(brush);

            brush = marker->brush();
            color = brush.color();
            color.setAlphaF(alpha);
            brush.setColor(color);
            marker->setBrush(brush);

            QPen pen = marker->pen();
            color = pen.color();
            color.setAlphaF(alpha);
            pen.setColor(color);
            marker->setPen(pen);
            break;
        }
        default:
            break;
    }


}

常用的序列和坐标组合

  1. 折线图和数值坐标轴

QlineSeries 和QValueAxis

  1. 柱状图和横坐标类别坐标轴、纵坐标数值坐标轴

QBarSeries 、QBarSet (用于创建柱状图的数据集)和QBarCategoryAxis 、QValueAxis

  1. 饼状图 没有坐标轴

QPieSeries、QPieSlice(饼图分块,一个饼图有多个分块。有标签label和数值value两部分)。

  1. 堆叠柱状图和横坐标类别坐标轴、纵坐标数值坐标轴

QStackedBarSeries 、QBarSet (用于创建柱状图的数据集)和QBarCategoryAxis 、QValueAxis

  1. 百分比柱状图和横坐标类别坐标轴、纵坐标数值坐标轴

QPercentBarSeries 、QBarSet (用于创建柱状图的数据集)和QBarCategoryAxis 、QValueAxis

  1. 散点图和数值坐标轴

QScatterSeries 和QValueAxis

常用的功能

  1. 获取鼠标在图标的当前坐标位置。

重写QChartView的mouseMoveEvent函数,通过QMouseEvent对象的pos函数获取坐标位置。

  1. 鼠标选择区域放大、恢复大小或者直接按钮放大缩小

重写QChartView的mousePressEvent函数获取起始位置,在mouseReleaseEvent获取结束位置。然后在结束位置和起始位置作为一个新区域,QChart对象调用zoomIn或者zoom函数进行放大或缩小即可。

  1. 通过键盘将图表内容上下左右平移。

重写QChartView的keyPressEvent函数,QChart调用scroll函数进行平移。

上面的3个功能都需要调用setDragMode(QGraphicsView::RubberBandDrag);和setMouseTracking(true);

setDragMode:设置视图组件鼠标拖动选择为橡皮框形式。

setMouseTracking:允许鼠标跟踪状态,这样才能进去mouseMoveEvent。

  • 3
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Qt QChart是一个用于绘制图表的模块,可以用于绘制各种类型的图表,包括曲线图。要实现曲线的拖动,可以按照以下步骤进行操作: 1. 创建一个QChart对象,并添加一个QLineSeries对象作为曲线的数据源。通过添加点坐标的方式,将数据添加到QLineSeries中。 2. 创建一个QChartView对象,并将QChart对象设置为其图表。这样可以将图表显示在窗口上。 3. 为QChartView对象添加一个QScatterSeries对象作为鼠标拖动的曲线。该QScatterSeries对象中的数据为空。 4. 重写QChartView对象的mousePressEvent和mouseMoveEvent事件处理函数,在鼠标按下和鼠标移动时获取鼠标的坐标。 5. 在mousePressEvent事件处理函数中,判断鼠标是否在曲线上。可以通过调用QChart对象的mapToValue函数将鼠标坐标转换为图表上的坐标,然后判断该坐标是否在QLineSeries中。 6. 在mouseMoveEvent事件处理函数中,判断之前鼠标是否按下,若是,则将拖动的鼠标坐标同样转换为图表上的坐标,并更新QScatterSeries对象的数据。这样可以实现曲线的拖动效果。 7. 最后,将QChartView对象添加到窗口中,并显示窗口。 通过以上步骤,可以实现Qt QChart曲线的拖动效果。 ### 回答2: 在Qt QChart中,要实现曲线的拖动效果,可以通过以下步骤进行操作: 首先,创建一个QT图表视图,并将其设置为可拖动模式。可以通过设置setRubberBand()函数来实现这一点,例如: chartView->setRubberBand(QChartView::RectangleRubberBand); 其次,创建曲线数据并将其添加到图表中。可以使用QLineSeries类来表示曲线,例如: QLineSeries *series = new QLineSeries(); series->append(0, 0); series->append(1, 1); series->append(2, 2); ... chart->addSeries(series); 然后,将图表视图与图表进行绑定,以实现拖动效果: chartView->setChart(chart); 最后,通过实现图表视图的mousePressEvent()、mouseMoveEvent()和mouseReleaseEvent()函数,可以跟踪鼠标事件并更新曲线的位置。例如,在mouseMoveEvent()函数中,可以根据鼠标的移动距离来计算并更新曲线的坐标,实现曲线的拖动效果: void ChartView::mouseMoveEvent(QMouseEvent *event) { if (event->buttons() & Qt::LeftButton) { QPoint diff = event->pos() - m_lastMousePos; chart()->scroll(diff.x(), diff.y()); } m_lastMousePos = event->pos(); } 这样,当鼠标在图表视图上按下并拖动时,就可以实现曲线的拖动效果了。注意,在此过程中,m_lastMousePos用于记录鼠标上一次的位置,以便计算鼠标移动的距离。 以上是使用Qt QChart实现曲线拖动的基本步骤,希望对你有帮助。如需更多详细信息,请参考Qt官方文档或相关教程。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值