QtCharts Legend 点击选择demo

Qwt 上有专门的类QwtLegend来实现legend图标滴点击选中,QtCharts上没有现成的类来实现,copy qtcharts example(legendmarkers)。代码如下:

void MainWindow::MarkersConnect(QChart *poChart)
{
    /* Connect all markers to handler */
    foreach (QLegendMarker* poLegendMarker, poChart->legend()->markers())
    {
        /* Disconnect possible existing connection to avoid multiple connections */
        QObject::disconnect(poLegendMarker, SIGNAL(clicked()), this, SLOT(HandleMarkerClicked()));
        QObject::connect(poLegendMarker, SIGNAL(clicked()), this, SLOT(HandleMarkerClicked()));
    }
}

void MainWindow::HandleMarkerClicked()
{
    QLegendMarker* poLegendMarker = qobject_cast<QLegendMarker*> (sender());
    Q_ASSERT(poLegendMarker);

    switch (poLegendMarker->type())
    {
        case QLegendMarker::LegendMarkerTypeXY:
        {
        /* Toggle visibility of Series */
        poLegendMarker->series()->setVisible(!poLegendMarker->series()->isVisible());

        /* Turn legend marker back to visible,
         * since hiding poSeries also hides the marker
         * and we don't want it to happen now. */
        poLegendMarker->setVisible(true);

        /* Dim the marker, if series is not visible */
        qreal alpha = 1.0;

        if (!poLegendMarker->series()->isVisible())
        {
            alpha = 0.5;
        }

        QColor oColor;
        QBrush oBrush = poLegendMarker->labelBrush();
        oColor = oBrush.color();
        oColor.setAlphaF(alpha);
        oBrush.setColor(oColor);
        poLegendMarker->setLabelBrush(oBrush);

        oBrush = poLegendMarker->brush();
        oColor = oBrush.color();
        oColor.setAlphaF(alpha);
        oBrush.setColor(oColor);
        poLegendMarker->setBrush(oBrush);

        QPen oPen = poLegendMarker->pen();
        oColor = oPen.color();
        oColor.setAlphaF(alpha);
        oPen.setColor(oColor);
        poLegendMarker->setPen(oPen);

        break;
        }
    default:
        {
        qDebug() << "Unknown poLegendMarker type";
        break;
        }
    }
}


### 配置和使用 QtCharts 模块 #### 创建项目并选择合适的模板 在创建一个新的 QT 项目时,可以选择 **Qt Widgets Application** 的模板来构建应用程序。这一步可以通过图形界面完成,在向导中选择对应的选项即可[^1]。 #### 安装和编译 QtCharts 模块 如果尚未安装 QtCharts 模块,则需要先下载其源码,并按照官方文档中的说明进行编译。对于版本号为 5.7.0 或更高版本的情况,可以参考相关教程完成编译过程。成功编译后,需将生成的库文件复制至指定路径(通常位于 `lib` 文件夹)。此外,还需要修改项目的 `.pro` 文件以确保正确加载 QtCharts 模块[^2]。 以下是 `.pro` 文件的一个典型配置示例: ```plaintext QT += core gui widgets charts ``` 上述代码片段表示启用了核心功能 (`core`)、GUI 支持 (`gui`) 和图表支持 (`charts`)。 #### 设置开发环境 (Visual Studio 中的例子) 当您希望在 Visual Studio 下集成 Qt 并使用 QtCharts 功能时,应遵循如下设置: - 添加头文件路径: 将包含 QtCharts 头文件的位置加入工程属性 -> C/C++ -> 常规 -> 附加包含目录。例如: ```D:\Qt\Qt5.13.1\5.13.1\msvc2015_64\include\QtCharts``` - 添加库文件路径: 同样地,在链接器部分定义库所在位置。具体操作是在工程属性 -> 链接器 -> 常规 -> 附加库目录中添加类似以下条目: ```D:\Qt\Qt5.13.1\5.13.1\msvc2015_64\lib``` - 配置调试与发布模式下的依赖项: 对于不同的构建模式分别引入相应的静态库文件。比如 Debug 版本下添加 `Qt5Chartsd.lib` 而 Release 则对应的是 `Qt5Charts.lib`[^3]。 #### 示例代码展示 下面给出一段简单的例子用于演示如何初始化以及绘制基本折线图。 ```cpp #include <QApplication> #include <QtCharts/QChartView> #include <QtCharts/QLineSeries> using namespace QtCharts; int main(int argc, char *argv[]) { QApplication app(argc, argv); QLineSeries* series = new QLineSeries(); series->append(0, 6); series->append(2, 4); series->append(3, 8); series->append(7, 4); series->append(10, 5); QChart* chart = new QChart(); chart->legend()->hide(); //隐藏默认显示出来的图例框 chart->addSeries(series); //把series加进去chart里边去 chart->createDefaultAxes(); //自动创建坐标轴 chart->setTitle("Simple line chart example"); QChartView* chartView = new QChartView(chart); chartView->setRenderHint(QPainter::Antialiasing); QMainWindow window; window.setCentralWidget(chartView); window.resize(400, 300); window.show(); return app.exec(); } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值