柱状图QCPBars

发布于:2025-04-21 ⋅ 阅读:(61) ⋅ 点赞:(0)

一、QCPBars 概述

QCPBars 是 QCustomPlot 中用于绘制柱状图/条形图的类,支持单组或多组柱状图显示,可自定义宽度、颜色和间距等属性。

二、主要属性

属性 类型 描述
width double 柱子的宽度(坐标轴单位)
widthType WidthType 宽度计算方式(坐标单位或像素单位)
barsGroup QCPBarsGroup* 所属的柱状图分组
pen QPen 柱子边框的画笔属性
brush QBrush 柱子填充的画刷属性
name QString 柱状图名称(显示在图例中)
visible bool 是否可见
selectable bool 是否可选择
selected bool 当前是否被选中

三、常用方法

1. 数据相关方法

方法 参数 返回值 描述
setData const QVector<double>& keys, const QVector<double>& values void 设置柱状图数据
setData QSharedPointer<QCPBarsDataContainer> data void 设置数据容器
addData const QVector<double>& keys, const QVector<double>& values void 追加数据
addData double key, double value void 添加单个柱子
dataCount - int 返回柱子数量
data - QSharedPointer<QCPBarsDataContainer> 获取数据容器

2. 样式设置方法

方法 参数 返回值 描述
setWidth double width void 设置柱子宽度
setWidthType WidthType widthType void 设置宽度计算方式
setPen const QPen &pen void 设置边框画笔
setBrush const QBrush &brush void 设置填充画刷
setSelectedPen const QPen &pen void 设置选中状态边框画笔
setSelectedBrush const QBrush &brush void 设置选中状态填充画刷
setBarsGroup QCPBarsGroup *barsGroup void 设置柱状图分组

3. 交互相关方法

方法 参数 返回值 描述
setSelectable QCP::SelectionType selectable void 设置可选择类型
setSelection QCPDataSelection selection void 设置选中柱子
selected - QCPDataSelection 获取选中柱子
selectTest const QPointF &pos, bool onlySelectable, QVariant *details double 测试点是否选中柱子

四、信号列表

信号 参数 描述
selectionChanged bool selected 选中状态改变时触发
selectableChanged QCP::SelectionType selectable 可选择状态改变时触发

五、枚举类型

1. WidthType 宽度类型

描述
wtAbsolute 绝对宽度(坐标轴单位)
wtAxisRectRatio 相对于轴矩形宽度的比例
wtPlotCoords 使用绘图坐标计算宽度

六、基础使用示例

cpp

// 创建柱状图
QCPBars *bars = new QCPBars(customPlot->xAxis, customPlot->yAxis);

// 设置数据
QVector<double> x(5), y(5);
for (int i=0; i<5; ++i) {
    x[i] = i+1;  // 1, 2, 3, 4, 5
    y[i] = QRandomGenerator::global()->bounded(1, 10); // 随机值1-10
}
bars->setData(x, y);

// 设置样式
bars->setName("月度销售额");
bars->setWidth(0.5); // 柱子宽度
bars->setPen(QPen(Qt::darkBlue));
bars->setBrush(QColor(100, 150, 250));

// 设置坐标轴
customPlot->xAxis->setRange(0, 6);
customPlot->yAxis->setRange(0, 10);

// 刷新显示
customPlot->replot();

七、高级功能示例

1. 多组柱状图

cpp

// 创建第一组柱状图
QCPBars *bars1 = new QCPBars(customPlot->xAxis, customPlot->yAxis);
bars1->setData({1,2,3,4}, {3,5,2,6});
bars1->setWidth(0.3);
bars1->setBrush(QColor(100, 150, 250));
bars1->setName("第一季度");

// 创建第二组柱状图
QCPBars *bars2 = new QCPBars(customPlot->xAxis, customPlot->yAxis);
bars2->setData({1,2,3,4}, {4,3,6,2});
bars2->setWidth(0.3);
bars2->setBrush(QColor(250, 150, 100));
bars2->setName("第二季度");

// 创建柱状图分组并设置间距
QCPBarsGroup *group = new QCPBarsGroup(customPlot);
group->setSpacingType(QCPBarsGroup::stAbsolute);
group->setSpacing(0.1); // 柱子间距
group->append(bars1);
group->append(bars2);

2. 堆叠柱状图

cpp

// 创建基础柱状图
QCPBars *baseBars = new QCPBars(customPlot->xAxis, customPlot->yAxis);
baseBars->setData({1,2,3,4}, {3,2,4,1});
baseBars->setBrush(QColor(100, 150, 250));

// 创建堆叠在上方的柱状图
QCPBars *stackedBars = new QCPBars(customPlot->xAxis, customPlot->yAxis);
stackedBars->setData({1,2,3,4}, {2,3,1,4});
stackedBars->setBrush(QColor(250, 150, 100));
stackedBars->moveAbove(baseBars); // 关键:设置堆叠顺序

3. 自定义柱子选择样式

cpp

bars->setSelectable(QCP::stSingleData); // 允许选择单个柱子
bars->setSelectedPen(QPen(Qt::red, 2));
bars->setSelectedBrush(QBrush(QColor(255, 100, 100, 150)));

// 连接选择变化信号
connect(customPlot, &QCustomPlot::selectionChangedByUser, [=](){
    if (bars->selected()) {
        QCPDataSelection selection = bars->selection();
        if (selection.dataRangeCount() > 0) {
            int index = selection.dataRange().begin();
            qDebug() << "选中了第" << index+1 << "个柱子";
        }
    }
});

八、性能优化技巧

  1. 大数据集处理

    cpp

    bars->setAntialiased(false); // 关闭抗锯齿提高性能
  2. 自定义绘制

    cpp

    // 继承QCPBars重写draw方法实现自定义绘制
    class CustomBars : public QCPBars {
    protected:
        virtual void draw(QCPPainter *painter) override {
            // 自定义绘制逻辑
        }
    };
  3. 使用OpenGL加速

    cpp

    customPlot->setOpenGl(true);

QCPBars 提供了丰富的自定义选项,可以创建各种复杂的柱状图可视化效果,包括分组柱状图、堆叠柱状图、百分比柱状图等。


网站公告

今日签到

点亮在社区的每一天
去签到