【Qt】QChart折线图

引言

Qt绘图(Qt Charts)基于Qt的Graphics View架构,其核心组件是QChartViewQChart

  • QChartView是显示图标的视图,基类为QGraphicsView
  • QChart的基类是QGraphicsltem
    可以看作是视图和数据分离,即ViewModel

QChartView

QChartView 是一个独立的小部件,继承于 QGraphicsView 类。它可以直接在用户界面中显示图表。这使得在应用程序中集成图表变得简单,而无需复杂的图形场景设置。

QChart

QChart是继承于QGraphicsWidget,可以在QGraphicsScene上显示,用来管理图表中的数据、图例、坐标轴等。

示例

// .h
#ifndef __WIDGET_H__
#define __WIDGET_H__

#include <QtWidgets/QWidget>

class Widget : public QWidget
{
public:
	Widget();
	~Widget();

public:
	void createLineSeries(const std::pair<QString, std::vector<int>>& pair);

private:
	class Impl;
	std::unique_ptr<Impl> impl_;
};

#endif // __WIDGET_H__

// .cpp
#include "Widget.h"

#include <QtCharts/QLineSeries>
#include <QtCharts/QChartView>
#include <QtCharts/QChart>
#include <QtCharts/QValueAxis>

#include <QVBoxLayout>

#include <algorithm>
#include <vector>

QT_CHARTS_USE_NAMESPACE

class Widget::Impl
{
public:
	Impl();
	~Impl() = default;

public:
	QChart *chart_ = nullptr;
};

Widget::Widget()
	:QWidget(),
	impl_(std::make_unique<Impl>())
{
	setFixedSize(1700, 800);
	setWindowTitle(u8"亮度对比折线图");
	//创建图表框架
	
	QVBoxLayout *lay = new QVBoxLayout;
	setLayout(lay);

	impl_->chart_ = new QChart();
	impl_->chart_->legend()->setAlignment(Qt::AlignRight);

	QChartView *charView = new QChartView(this);
	charView->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
	charView->setChart(impl_->chart_);

	lay->addWidget(charView);
}

Widget::~Widget()
{
}

void Widget::createLineSeries(const std::pair<QString, std::vector<int>> &pair)
{
	QLineSeries *series = new QLineSeries();
	
	series->setName(pair.first);

	for (int i = 0, sz = pair.second.size(); i < sz; i++)
	{
		series->append(i, pair.second[i]);
	}

	impl_->chart_->addSeries(series);
	//impl_->chart_->createDefaultAxes();
	QValueAxis *axisY = new QValueAxis;
	axisY->setRange(50, 200);
	axisY->setTitleText(u8"像素值");
	axisY->setLabelFormat("%i");
	impl_->chart_->addAxis(axisY, Qt::AlignLeft);

	QValueAxis *axisX = new QValueAxis;
	axisX->setRange(0, pair.second.size());
	axisX->setTitleText(u8"序号");
	axisX->setLabelFormat("%i");
	impl_->chart_->addAxis(axisX, Qt::AlignBottom);

	series->attachAxis(axisX);
	series->attachAxis(axisY);

	auto allAxisX = impl_->chart_->axes(Qt::Horizontal);
	auto allAxisY = impl_->chart_->axes(Qt::Vertical);

	for (const auto it : allAxisX)
	{
		it->hide();
	}

	for (const auto it : allAxisY)
	{
		it->hide();
	}

	(*allAxisX.begin())->show();
	(*allAxisY.begin())->show();

	update();
}

Widget::Impl::Impl()
{
}

在这里插入图片描述

参考文章

  1. Qt(十三)QChart绘制折线图_qt折线图-CSDN博客
  2. C++ Qt开发:Charts折线图绘制详解_qt折线图-CSDN博客
  3. QT之QCharts的使用(绘制折线图)_qt qcharts折线图-CSDN博客
  4. 学习Qt Charts-创建一个简单的折线图 - 哈拎 - 博客园 (cnblogs.com)
  5. Qt类 | QChartView类详解-CSDN博客
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
qchart 折线图拖拽是指在 qchart(Qt 图表库的一部分)中,可以通过拖拽操作来实现对折线图的交互操作。 对于折线图的拖拽,主要包括以下两种情况: 1. 拖拽坐标轴:可以通过拖拽坐标轴来改变坐标轴的显示范围,从而实现对折线图的局部放大或缩小功能。例如,通过拖拽坐标轴上的刻度线或坐标轴边框,用户可以改变坐标轴的显示范围,观察感兴趣的数据部分。 2. 拖拽数据点:可以通过拖拽折线图中的数据点来实现数据的交互操作。例如,用户可以通过拖拽某个数据点,将其移动到另一个位置,从而改变该数据点的数值。这对于其他依赖于该数据点的计算或分析非常有用。 在实现折线图的拖拽功能时,可以借助 Qt 中的拖放机制来实现。通过监听鼠标事件,在拖拽开始时获取拖拽起始点的坐标,然后根据鼠标移动的距离和方向,计算出需要移动的距离。在拖拽过程中,实时更新折线图的显示效果,从而实现拖拽的交互效果。 同时,为了提高用户体验,可以通过改变鼠标指针的样式或显示拖拽操作的辅助线,来提示用户当前的拖拽状态和效果。 总之,qchart 折线图拖拽是通过拖拽操作来改变折线图的显示范围或交换数据点的功能。这种交互式的操作方式可以增强用户对折线图的自定义和可视化分析能力,提升用户体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值