Qchart 显示柱状图

2024-01-27 03:36
文章标签 显示 柱状图 qchart

本文主要是介绍Qchart 显示柱状图,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 前言
  • 一、添加 QT += charts
  • 二、测试
    • 1.测试1
    • 2.更正
    • 3.效果:
    • 4.在改进一下
  • 总结


前言

提示:这里可以添加本文要记录的大概内容:

项目中用到Qchart 显示柱状图,做个测试记录一下


提示:以下是本篇文章正文内容,下面案例可供参考

一、添加 QT += charts

在pro中添加在这里插入图片描述

QT += charts

二、测试

1.测试1

代码如下(示例):

#include <QtCharts>using namespace QtCharts;// 创建柱状图
QBarSeries *series = new QBarSeries();// 添加数据
series->append(0, 6);
series->append(2, 4);
series->append(3, 8);// 创建图表
QChart *chart = new QChart();
chart->addSeries(series);
chart->createDefaultAxes();// 设置图表标题
chart->setTitle("Simple Bar Chart Example");// 创建图表视图
QChartView *chartView = new QChartView(chart);
chartView->setRenderHint(QPainter::Antialiasing);// 显示图表视图
chartView->show();

问题:

series->append(0, 6);这个代码不能用

在这里插入图片描述
no matching function for call to ‘QtCharts::QBarSeries::append(int, int)’
能用才怪

2.更正

代码如下(示例):

#include "mainwindow.h"#include <QApplication>#include <QtCharts>using namespace QtCharts;int main(int argc, char *argv[])
{QApplication a(argc, argv);MainWindow w;w.show();// 创建柱状图QBarSeries *series = new QBarSeries();QBarSet *set = new QBarSet("Label");*set << 7 <<2<<8; // 这里假设我们有两个类别,索引为0的值是6// 添加数据series->append(set);//  *set << 1 << 2 ; // 这里假设我们有两个类别,索引为0的值是6// series->append(set);//  *set << 2 << 5 ; // 这里假设我们有两个类别,索引为0的值是6// series->append(set);// 创建图表QChart *chart = new QChart();chart->addSeries(series);chart->createDefaultAxes();// 设置图表标题chart->setTitle("Simple Bar Chart Example");// 创建图表视图QChartView *chartView = new QChartView(chart);chartView->setRenderHint(QPainter::Antialiasing);// 显示图表视图chartView->show();return a.exec();
}

3.效果:

在这里插入图片描述

4.在改进一下

#include "mainwindow.h"
#include <QtWidgets/QMainWindow>
#include <QtWidgets/QApplication>
#include <QtCharts/QChartView>
#include <QtCharts/QBarSeries>
#include <QtCharts/QBarSet>
#include <QtCharts/QLegend>
#include <QtCharts/QBarCategoryAxis>using namespace QtCharts;int main(int argc, char *argv[])
{QApplication a(argc, argv);// 创建一个主窗口QMainWindow window;// 创建一个柱状图系列QBarSeries *series = new QBarSeries();// 创建一个条目集合,并添加数据QBarSet *set = new QBarSet("Data");*set << 1 << 2 << 3 << 4 << 5; // 添加5个数据点// 将集合添加到系列中series->append(set);// 创建一个图表QChart *chart = new QChart();chart->addSeries(series); // 将系列添加到图表中chart->setTitle("Simple bar chart example");chart->setAnimationOptions(QChart::SeriesAnimations);// 创建坐标轴QStringList categories;categories << "Jan" << "Feb" << "Mar" << "Apr" << "May";QBarCategoryAxis *axisX = new QBarCategoryAxis();axisX->append(categories);chart->createDefaultAxes();chart->setAxisX(axisX, series);// 添加图例chart->legend()->setVisible(true);chart->legend()->setAlignment(Qt::AlignBottom);// 创建一个图表视图,并将图表设置为视图的中心部件QChartView *chartView = new QChartView(chart);chartView->setRenderHint(QPainter::Antialiasing);// 将图表视图设置为主窗口的中心部件window.setCentralWidget(chartView);// 显示主窗口window.resize(420, 300);window.show();return a.exec();
}

效果
在这里插入图片描述

总结

继续努力

这篇关于Qchart 显示柱状图的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/648947

相关文章

第10章 中断和动态时钟显示

第10章 中断和动态时钟显示 从本章开始,按照书籍的划分,第10章开始就进入保护模式(Protected Mode)部分了,感觉从这里开始难度突然就增加了。 书中介绍了为什么有中断(Interrupt)的设计,中断的几种方式:外部硬件中断、内部中断和软中断。通过中断做了一个会走的时钟和屏幕上输入字符的程序。 我自己理解中断的一些作用: 为了更好的利用处理器的性能。协同快速和慢速设备一起工作

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

利用matlab bar函数绘制较为复杂的柱状图,并在图中进行适当标注

示例代码和结果如下:小疑问:如何自动选择合适的坐标位置对柱状图的数值大小进行标注?😂 clear; close all;x = 1:3;aa=[28.6321521955954 26.2453660695847 21.69102348512086.93747104431360 6.25442246899816 3.342835958564245.51365061796319 4.87

lvgl8.3.6 控件垂直布局 label控件在image控件的下方显示

在使用 LVGL 8.3.6 创建一个垂直布局,其中 label 控件位于 image 控件下方,你可以使用 lv_obj_set_flex_flow 来设置布局为垂直,并确保 label 控件在 image 控件后添加。这里是如何步骤性地实现它的一个基本示例: 创建父容器:首先创建一个容器对象,该对象将作为布局的基础。设置容器为垂直布局:使用 lv_obj_set_flex_flow 设置容器

C# dateTimePicker 显示年月日,时分秒

dateTimePicker默认只显示日期,如果需要显示年月日,时分秒,只需要以下两步: 1.dateTimePicker1.Format = DateTimePickerFormat.Time 2.dateTimePicker1.CustomFormat = yyyy-MM-dd HH:mm:ss Tips:  a. dateTimePicker1.ShowUpDown = t

小程序button控件上下边框的显示和隐藏

问题 想使用button自带的loading图标功能,但又不需要button显示边框线 button控件有一条淡灰色的边框,在控件上了样式 border:none; 无法让button边框隐藏 代码如下: <button class="btn">.btn{border:none; /*一般使用这个就是可以去掉边框了*/} 解决方案 发现button控件有一个伪元素(::after

MFC中Spin Control控件使用,同时数据在Edit Control中显示

实现mfc spin control 上下滚动,只需捕捉spin control 的 UDN_DELTAPOD 消息,如下:  OnDeltaposSpin1(NMHDR *pNMHDR, LRESULT *pResult) {  LPNMUPDOWN pNMUpDown = reinterpret_cast(pNMHDR);  // TODO: 在此添加控件通知处理程序代码    if

微信小程序uniappvue3版本-控制tabbar某一个的显示与隐藏

1. 首先在pages.json中配置tabbar信息 2. 在代码根目录下添加 tabBar 代码文件 直接把微信小程序文档里面的四个文件复制到自己项目中就可以了   3. 根据自己的需求更改index.js文件 首先我这里需要判断什么时候隐藏某一个元素,需要引入接口 然后在切换tabbar时,改变tabbar当前点击的元素 import getList from '../

gazebo 已加载模型但无法显示

目录 写在前面的话问题一:robot_state_publisher 发布机器人信息失败报错一 Error: Error document empty.报错二 .xcaro 文件中有多行注释成功启动 问题二:通过 ros2 启动 gazebo 失败成功启动 问题三:gazebo 崩溃和无法显示模型问题四: 缺少 robot_description 等话题正确的输出 写在前面的话