提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:鲍佳佳|2021-04-22 11:34:34.490|阅读 460 次
概述:本示例说明如何使用通过QPieSeries API创建饼图分解图。
# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>
相关链接:
Qt是一个跨平台框架,通常用作图形工具包,它不仅创建CLI应用程序中非常有用。而且它也可以在三种主要的台式机操作系统以及移动操作系统(如Symbian,Nokia Belle,Meego Harmattan,MeeGo或BB10)以及嵌入式设备,Android(Necessitas)和iOS的端口上运行。现在我们为你提供了免费的试用版。
饼状图细分示例
本示例说明如何使用通过QPieSeries API创建饼图分解图。
运行示例
要从Qt Creator运行示例,请打开“欢迎”模式,然后从“example”中选择example。有关更多信息,请访问构建和运行示例。
创建饼状图分解图
让我们从为图表定义一些数据开始。
// Graph is based on data of 'Total consumption of energy increased by 10 per cent in 2010' // Statistics Finland, 13 December 2011 // //www.stat.fi/til/ekul/2010/ekul_2010_2011-12-13_tie_001_en.html QPieSeries *series1 = new QPieSeries(); series1->setName("Fossil fuels"); series1->append("Oil", 353295); series1->append("Coal", 188500); series1->append("Natural gas", 148680); series1->append("Peat", 94545); QPieSeries *series2 = new QPieSeries(); series2->setName("Renewables"); series2->append("Wood fuels", 319663); series2->append("Hydro power", 45875); series2->append("Wind power", 1060); QPieSeries *series3 = new QPieSeries(); series3->setName("Others"); series3->append("Nuclear energy", 238789); series3->append("Import energy", 37802); series3->append("Other", 32441);
然后,我们创建一个图表,在其中添加数据。请注意,这是我们自己从QChart衍生的图表。
DonutBreakdownChart *donutBreakdown = new DonutBreakdownChart(); donutBreakdown->setAnimationOptions(QChart::AllAnimations); donutBreakdown->setTitle(("Total consumption of energy in Finland 2010"); donutBreakdown->legend()()->setAlignment((Qt::AlignRight);); donutBreakdown->addBreakdownSeries(series1(series1, Qt::red);); donutBreakdown->addBreakdownSeries(series2(series2, Qt::darkGreen);); donutBreakdown->addBreakdownSeries(series3(series3, Qt::darkBlue););
我们自己的图表以这样的方式工作:我们在构造函数中创建一个主系列,然后创建一个主系列,该主系列汇总了细分系列提供的数据。这是中心的饼图。
DonutBreakdownChart::DonutBreakdownChart((QGraphicsItem *parent, Qt::WindowFlags wFlags) wFlags) : : QChart(QChart::ChartTypeCartesian, parent, wFlags)) {{ // create the series for main center pie m_mainSeries = new QPieSeries(); m_mainSeries->setPieSize((0.7); QChart::addSeries(m_mainSeries);(m_mainSeries); }}
添加故障序列后,数据将用于在主序列中创建一个切片,而故障序列本身将用于创建定位的甜甜圈的一部分,以使其与主序列中的相应切片对齐。
void DonutBreakdownChartDonutBreakdownChart::addBreakdownSeries((QPieSeries *breakdownSeries, QColor color)) {{ QFont font(("Arial", 8); // add breakdown series as a slice to center pie MainSlice MainSlice *mainSlice = new MainSlice(breakdownSeries);MainSlice(breakdownSeries); mainSlice->setName(breakdownSeries(breakdownSeries->name());()); mainSlice->setValue(breakdownSeries(breakdownSeries->sum());()); m_mainSeries->append(mainSlice);(mainSlice); // customize the slice mainSlice->setBrush(color);(color); mainSlice->setLabelVisible();(); mainSlice->setLabelColor((Qt::white);); mainSlice->setLabelPosition((QPieSlice::LabelInsideHorizontal);); mainSlice->setLabelFont(font);(font); // position and customize the breakdown series breakdownSeries->setPieSize((0.8); breakdownSeries->setHoleSize((0.7); breakdownSeries->setLabelsVisible(); (); const auto slices = breakdownSeries->slices(); (); for ((QPieSlice *slice : slices) {: slices) { color = color.lighter((115); slice->setBrush(color);(color); slice->setLabelFont(font);(font); }} // add the series to the chart QChart::addSeries(breakdownSeries);(breakdownSeries); // recalculate breakdown donut segments recalculateAngles();(); // update customize legend markers updateLegendMarkers();(); }}
这是如何计算饼图段的起始角度和终止角度的方法。
void DonutBreakdownChartDonutBreakdownChart::recalculateAngles()() {{ qreal angle = 0; const auto slices = m_mainSeries->slices(); (); for ((QPieSlice *slice : slices) { : slices) { QPieSeries *breakdownSeries = qobject_cast<MainSlice *>(slice)slice)->breakdownSeries();(); breakdownSeries->setPieStartAngle(angle);(angle); angle += slice->percentage() () * 360.0; // full pie is 360.0 breakdownSeries->setPieEndAngle(angle);(angle); }} }}
图例标记是自定义的,以显示细分百分比。主级别切片的标记被隐藏。
void DonutBreakdownChartDonutBreakdownChart::updateLegendMarkers()() {{ // go through all markers const auto allseries = series(); (); for ((QAbstractSeries *series : allseries) { : allseries) { const auto markers = legend()()->markers(series); (series); for ((QLegendMarker *marker : markers) { : markers) { QPieLegendMarker *pieMarker = qobject_cast<QPieLegendMarker *>(marker); marker); if (series (series == m_mainSeries) { ) { // hide markers from main series pieMarker->setVisible((false); } } else { { // modify markers from breakdown series pieMarker->setLabel((QString("%1 %2%") .arg(pieMarker(pieMarker->slice()()->label()) ()) .arg(pieMarker(pieMarker->slice()()->percentage() () * 100, 0, 'f', 2)); pieMarker->setFont((QFont("Arial", 8)); }} }} }} }}
相反,主级别切片会在标签上显示百分比。
MainSlice::MainSlice((QPieSeries *breakdownSeries, QObject *parent)) : : QPieSlice(parent)parent), m_breakdownSeries(breakdownSeries)(breakdownSeries) {{ connect((this, &MainSlice::percentageChanged, this, &MainSlice::updateLabel);); }} void MainSliceMainSlice::updateLabel()() {{ this->setLabel((QString("%1 %2%").arg(m_name)(m_name).arg(percentage() (percentage() * 100, 0, 'f', 2)); }}
现在我们已经定义了图表,我们终于可以创建一个QChartView并显示该图表。
QMainWindow window; ; QChartView *chartView = new QChartView(donutBreakdown);donutBreakdown); chartView->setRenderHint((QPainter::Antialiasing);); window.setCentralWidget(chartView);(chartView); window.resize((800, 500); window.show();();
====================================================
想要了解或购买Qt正版授权的朋友,欢迎
Qt技术交流群现已开通,QQ搜索群号“765444821”或者扫描下方二维码即可加入
Qt组件推荐:
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@pclwef.cn
文章转载自:本文探讨 SQL Server 中 NULL 和空值之间的区别,并讨论如何有效地处理它们。
Unity 是一款功能极其丰富的游戏引擎,允许开发人员将各种媒体集成到他们的项目中。但是,它缺少最令人兴奋的功能之一 - 将 Web 内容(例如 HTML、CSS 和 JavaScript)直接渲染到 3D 场景中的纹理上的能力。在本文中,我们将介绍如何使用 DotNetBrowser 在 Unity3D 中将 Web 内容渲染为纹理。
DevExpress v24.2帮助文档正式发布上线了,请按版本按需下载~
本教程将向您展示如何用MyEclipse构建一个Web项目,欢迎下载最新版IDE体验!
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@pclwef.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢