在柱状图添加标签_Qt Charts中百分比柱状图的绘制

本文介绍了如何在Qt环境下使用Qt Charts库绘制百分比柱状图,并详细讲解了iniPercentBar和buildPercentBarO两个关键函数,用于初始化图表和根据统计数据构建图形。图形中,数学、语文、英语三个数据集以等高柱状形式展示,每个柱子显示各自所占的百分比,提供了一种直观的数据表示方式。
摘要由CSDN通过智能技术生成

点击上方“Qt学视觉”,选择“星标”公众号重磅干货,第一时间送达

共同学习共同进步

1、百分比柱状图的绘制

     绘制百分比柱状图的界面如下图所示。图中有数学、语文、英语3个数据集,3个数据集 的数据来源是按分数统计的结果,3个数据集叠加显示,显示效果类似于叠加柱状图,但是每个 柱子的3个数据的和是相同的,等于学生总人数,所以,所有的柱子是等髙度的。显示标签时, 显示的是每段所占的百分比。 

230f080fac210dd2c6675ad1a7a783f1.png

    iniPercentBar()用于图表的初始化,buildPercentBarO函数用于根据统计数据绘制百分比柱状图,其代码如下:

void QGuiCharts::iniPercentBar(){    //百分比柱状图初始化    QChart* chart = new QChart();    chart->setTitle("PercentBar 演示");    chart->setAnimationOptions(QChart::SeriesAnimations);    ui.chartViewPercentBar->setChart(chart);    ui.chartViewPercentBar->setRenderHint(QPainter::Antialiasing);}void QGuiCharts::buildPercentBar(){    //绘制百分比柱状图    QChart* chart = ui.chartViewPercentBar->chart();    chart->removeAllSeries();    chart->removeAxis(chart->axisX());    chart->removeAxis(chart->axisY());    //创建数据集    QBarSet* setMath = new QBarSet(theModel->horizontalHeaderItem(colNoMath)->text());    QBarSet* setChinese = new QBarSet(theModel->horizontalHeaderItem(colNoChinese)->text());    QBarSet* setEnglish = new QBarSet(theModel->horizontalHeaderItem(colNoEnglish)->text());    QTreeWidgetItem* item; //节点    QStringList categories;    for (int i = 0; i <= 4; i++)    {//从分数段统计数据表里获取数据,添加到数据集        item = ui.treeWidget->topLevelItem(i);        categories << item->text(0);//用作横坐标的标签        setMath->append(item->text(colNoMath).toFloat());        setChinese->append(item->text(colNoChinese).toFloat());        setEnglish->append(item->text(colNoEnglish).toFloat());    }    QPercentBarSeries* series = new QPercentBarSeries(); //序列    series->append(setMath);    series->append(setChinese);    series->append(setEnglish);    series->setLabelsVisible(true);//显示百分比//    series->setLabelsFormat("@value人");    chart->addSeries(series);    QBarCategoryAxis* axisX = new QBarCategoryAxis(); //横坐标    axisX->append(categories);    chart->setAxisX(axisX, series);    axisX->setRange(categories.at(0), categories.at(categories.count() - 1));    QValueAxis* axisY = new QValueAxis;//纵坐标    axisY->setRange(0, 100);    axisY->setTitleText("百分比");    axisY->setTickCount(6);    axisY->setLabelFormat("%.1f"); //标签格式    chart->setAxisY(axisY, series);    chart->legend()->setVisible(true);    chart->legend()->setAlignment(Qt::AlignRight); //AlignBottom}

    绘制百分比柱状图也需要先创建QBarSet数据集,这里创建了 3个数据集,从统计数据表里 分别获取3门课各个分数段的人数。绘制百分比柱状图使用QPercemBarSeries类的序列,添加数据集,设置X和K轴的坐标轴即 可。若显示数据标签,显示的是某个分数段内某门课的人数的百分比。

85815fec46474985b86df647f313c9de.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值