亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解C/C++ QT QChart 繪制組件應用

 更新時間:2021年11月19日 15:07:13   作者:lyshark  
Qtcharts 組件基于GraphicsView模式實現(xiàn),其核心是QChartView和QChart的二次封裝版。本文重點給大家介紹C/C++ QT QChart 繪制組件應用的相關知識,感興趣的朋友一起看看吧

QtCharts 組件是QT中提供圖表繪制的模塊,該模塊可以方便的繪制常規(guī)圖形,Qtcharts 組件基于GraphicsView模式實現(xiàn),其核心是QChartViewQChart的二次封裝版。

在使用繪圖模塊時需要在pro文件中包含QT += charts來引入繪圖類庫。

然后還需在頭文件中定義QT_CHARTS_USE_NAMESPACE宏,這樣才可以正常的使用繪圖功能。

一般情況下我們會在mainwindows.h頭文件中增加如下代碼段。

#include <QMainWindow>
#include <QtCharts>
QT_CHARTS_USE_NAMESPACE

// 解決MSVC編譯時,界面漢字亂碼的問題
#if _MSC_VER >= 1600
#pragma execution_character_set("utf-8")
#endif

由于QT中不存在單獨的繪圖畫布,因此在繪圖前我們需要在窗體中放入一個graphicsView組件。

并在該組件上右鍵將其提升為QChartView

輸入需要提升的組件名稱,即可將該組件提升為全局繪圖組件。

繪制折線圖: 折線圖的使用非常廣泛,如下代碼我們首先使用InitChart()將畫布初始化,接著調用SetData()實現(xiàn)在畫布中填充數(shù)據(jù),完整代碼如下。

#include "mainwindow.h"
#include "ui_mainwindow.h"

// 初始化Chart圖表
void MainWindow::InitChart()
{
    // 創(chuàng)建圖表的各個部件
    QChart *chart = new QChart();
    chart->setTitle("系統(tǒng)性能統(tǒng)計圖");

    // 將Chart添加到ChartView
    ui->graphicsView->setChart(chart);
    // this->setCentralWidget( ui->graphicsView);
    ui->graphicsView->setRenderHint(QPainter::Antialiasing);

    // 設置圖表主題色
    ui->graphicsView->chart()->setTheme(QChart::ChartTheme(0));

    // 創(chuàng)建曲線序列
    QLineSeries *series0 = new QLineSeries();
    QLineSeries *series1 = new QLineSeries();

    series0->setName("一分鐘負載");
    series1->setName("五分鐘負載");

    // 序列添加到圖表
    chart->addSeries(series0);
    chart->addSeries(series1);

    // 其他附加參數(shù)
    series0->setPointsVisible(false);       // 設置數(shù)據(jù)點可見
    series1->setPointLabelsVisible(false);  // 設置數(shù)據(jù)點數(shù)值可見

    // 創(chuàng)建坐標軸
    QValueAxis *axisX = new QValueAxis;    // X軸
    axisX->setRange(1, 100);               // 設置坐標軸范圍
    axisX->setTitleText("X軸標題");         // 標題
    axisX->setLabelFormat("%d %");         // 設置x軸格式
    axisX->setTickCount(3);               // 設置刻度
    axisX->setMinorTickCount(3);

    QValueAxis *axisY = new QValueAxis;    // Y軸
    axisY->setRange(0, 100);               // Y軸范圍(-1 - 20)
    axisY->setTitleText("Y軸標題");         // 標題

    // 設置X于Y軸數(shù)據(jù)集
    chart->setAxisX(axisX, series0);   // 為序列設置坐標軸
    chart->setAxisY(axisY, series0);

    chart->setAxisX(axisX, series1);   // 為序列設置坐標軸
    chart->setAxisY(axisY, series1);

    // 圖例被點擊后觸發(fā)
    foreach (QLegendMarker* marker, chart->legend()->markers())
    {
       QObject::disconnect(marker, SIGNAL(clicked()), this, SLOT(on_LegendMarkerClicked()));
       QObject::connect(marker, SIGNAL(clicked()), this, SLOT(on_LegendMarkerClicked()));
    }
}

// 為序列生成數(shù)據(jù)
void MainWindow::SetData()
{
    // 獲取指針
    QLineSeries *series0=(QLineSeries *)ui->graphicsView->chart()->series().at(0);
    QLineSeries *series1=(QLineSeries *)ui->graphicsView->chart()->series().at(1);

    // 清空圖例
    series0->clear();
    series1->clear();

    // 賦予數(shù)據(jù)
    qreal t=0,intv=1;
    for(int i=1;i<100;i++)
    {
       series0->append(t,i);       // 設置軸粒度以及數(shù)據(jù)
       series1->append(t,i+10);    // 此處用隨機數(shù)替代
       t+=intv;                    // X軸粒度
    }
}

// 將添加的widget控件件提升為QChartView類
MainWindow::MainWindow(QWidget *parent) :QMainWindow(parent),ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    InitChart();
    SetData();
}

MainWindow::~MainWindow()
{
    delete ui;
}

// 圖例點擊后顯示與隱藏線條
void MainWindow::on_LegendMarkerClicked()
{
    QLegendMarker* marker = qobject_cast<QLegendMarker*> (sender());

    switch (marker->type())
    {
        case QLegendMarker::LegendMarkerTypeXY:
        {
            marker->series()->setVisible(!marker->series()->isVisible());
            marker->setVisible(true);
            qreal alpha = 1.0;
            if (!marker->series()->isVisible())
                alpha = 0.5;

            QColor color;
            QBrush brush = marker->labelBrush();
            color = brush.color();
            color.setAlphaF(alpha);
            brush.setColor(color);
            marker->setLabelBrush(brush);

            brush = marker->brush();
            color = brush.color();
            color.setAlphaF(alpha);
            brush.setColor(color);
            marker->setBrush(brush);

            QPen pen = marker->pen();
            color = pen.color();
            color.setAlphaF(alpha);
            pen.setColor(color);
            marker->setPen(pen);
            break;
        }
        default:
            break;
    }
}

效果如下所示:

繪制餅狀圖: 餅狀圖用于統(tǒng)計數(shù)據(jù)的集的占用百分比,其繪制方式與折線圖基本一致,代碼如下。

#include "mainwindow.h"
#include "ui_mainwindow.h"

// 餅狀圖A
void MainWindow::printA()
{
    // 構造數(shù)據(jù) [已用CPU 60%] [剩余CPU 40%]
    QPieSlice *slice_1 = new QPieSlice(QStringLiteral("已使用"), 0.6, this);
    slice_1->setLabelVisible(true);

    QPieSlice *slice_2 = new QPieSlice(QStringLiteral("可用"), 0.4, this);
    slice_2->setLabelVisible(true);

    // 將兩個餅狀分區(qū)加入series
    QPieSeries *series = new QPieSeries(this);
    series->append(slice_1);
    series->append(slice_2);

    // 創(chuàng)建Chart畫布
    QChart *chart = new QChart();
    chart->addSeries(series);
    chart->setAnimationOptions(QChart::AllAnimations); // 設置顯示時的動畫效果
    chart->setTitle("系統(tǒng)CPU利用率");

    // 將參數(shù)設置到畫布
    ui->graphicsView->setChart(chart);
    ui->graphicsView->setRenderHint(QPainter::Antialiasing);
    ui->graphicsView->chart()->setTheme(QChart::ChartTheme(0));
}

// 餅狀圖B
void MainWindow::printB()
{
    // 構造數(shù)據(jù) [C盤 20%] [D盤 30%] [E盤 50%]
    QPieSlice *slice_c = new QPieSlice(QStringLiteral("C盤"), 0.2, this);
    slice_c->setLabelVisible(true);

    QPieSlice *slice_d = new QPieSlice(QStringLiteral("D盤"), 0.3, this);
    slice_d->setLabelVisible(true);

    QPieSlice *slice_e = new QPieSlice(QStringLiteral("E盤"),0.5,this);
    slice_e->setLabelVisible(true);

    // 將兩個餅狀分區(qū)加入series
    QPieSeries *series = new QPieSeries(this);
    series->append(slice_c);
    series->append(slice_d);
    series->append(slice_e);

    // 創(chuàng)建Chart畫布
    QChart *chart = new QChart();
    chart->addSeries(series);
    chart->setAnimationOptions(QChart::AllAnimations); // 設置顯示時的動畫效果
    chart->setTitle("系統(tǒng)磁盤信息");

    // 將參數(shù)設置到畫布
    ui->graphicsView_2->setChart(chart);
    ui->graphicsView_2->setRenderHint(QPainter::Antialiasing);
    ui->graphicsView_2->chart()->setTheme(QChart::ChartTheme(3));   // 設置不同的主題
}

// 將添加的widget控件件提升為QChartView類
MainWindow::MainWindow(QWidget *parent) :QMainWindow(parent),ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    printA();
    printB();
}

MainWindow::~MainWindow()
{
    delete ui;
}

效果如下所示:

繪制柱狀圖: 柱狀圖可用于一次展示多個用戶數(shù)據(jù),大體是使用上與折線圖大體一致,其代碼如下:

#include "mainwindow.h"
#include "ui_mainwindow.h"

MainWindow::MainWindow(QWidget *parent) :QMainWindow(parent),ui(new Ui::MainWindow)
{
    ui->setupUi(this);

    // 創(chuàng)建人名
    QBarSet *set0 = new QBarSet("張三");
    QBarSet *set1 = new QBarSet("李四");
    QBarSet *set2 = new QBarSet("王五");
    QBarSet *set3 = new QBarSet("蘇三");
    QBarSet *set4 = new QBarSet("劉麻子");

    // 分別為不同人添加bu不同數(shù)據(jù)集
    *set0 << 1 << 2 << 8 << 4 << 6 << 6;
    *set1 << 5 << 2 << 5 << 4 << 5 << 3;
    *set2 << 5 << 5 << 8 << 15 << 9 << 5;
    *set3 << 8 << 6 << 7 << 5 << 4 << 5;
    *set4 << 4 << 7 << 5 << 3 << 3 << 2;

    // 將數(shù)據(jù)集關聯(lián)到series中
    QBarSeries *series = new QBarSeries();
    series->append(set0);
    series->append(set1);
    series->append(set2);
    series->append(set3);
    series->append(set4);

    // 增加頂部提示
    QChart *chart = new QChart();
    chart->addSeries(series);
    chart->setTitle("當前人數(shù)統(tǒng)計");
    chart->setAnimationOptions(QChart::SeriesAnimations);

    // 創(chuàng)建X軸底部提示
    QStringList categories;
    categories << "周一" << "周二" << "周三" << "周四" << "周五" << "周六";

    QBarCategoryAxis *axis = new QBarCategoryAxis();
    axis->append(categories);
    chart->createDefaultAxes();
    chart->setAxisX(axis, series);

    chart->legend()->setVisible(true);
    chart->legend()->setAlignment(Qt::AlignBottom);

    // 將參數(shù)設置到畫布
    ui->graphicsView->setChart(chart);
    ui->graphicsView->setRenderHint(QPainter::Antialiasing);
    ui->graphicsView->chart()->setTheme(QChart::ChartTheme(0));
}

MainWindow::~MainWindow()
{
    delete ui;
}

效果如下所示:

到此這篇關于C/C++ QT QChart 繪制組件應用的文章就介紹到這了,更多相關C++ QChart組件內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • C語言基于EasyX實現(xiàn)貪吃蛇

    C語言基于EasyX實現(xiàn)貪吃蛇

    這篇文章主要為大家詳細介紹了C語言基于EasyX實現(xiàn)貪吃蛇,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • C語言實現(xiàn)萬年歷小功能

    C語言實現(xiàn)萬年歷小功能

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)萬年歷小功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • Qt 數(shù)據(jù)庫QSqlDatabase使用示例

    Qt 數(shù)據(jù)庫QSqlDatabase使用示例

    本文主要介紹了Qt數(shù)據(jù)庫QSqlDatabase使用示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-12-12
  • C語言實現(xiàn)實時鐘表

    C語言實現(xiàn)實時鐘表

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)實時鐘表,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • Typedef在C語言和C++中的用法和區(qū)別

    Typedef在C語言和C++中的用法和區(qū)別

    在C語言和C++中,typedef是一個非常常用的關鍵字,用于為數(shù)據(jù)類型定義別名,盡管它在兩種語言中都有相似的功能,但由于C++具有更豐富的類型系統(tǒng),因此在實際應用中,typedef在兩者間的使用存在一些微妙的差異
    2024-01-01
  • 詳解C++ sizeof(上)

    詳解C++ sizeof(上)

    這篇文章主要介紹了C++ sizeof的相關資料,幫助大家更好的理解和學習c++,感興趣的朋友可以了解下
    2020-08-08
  • C語言菜鳥基礎教程之自定義函數(shù)

    C語言菜鳥基礎教程之自定義函數(shù)

    自定義函數(shù): 必須直接或間接在main中調用,否則該自定義函數(shù)不會被執(zhí)行。 返回值類型 函數(shù)名(參數(shù)類型 參數(shù)名,參數(shù)類型 參數(shù)名...)
    2017-10-10
  • C語言實現(xiàn)txt數(shù)據(jù)讀入內存/CPU緩存實例詳解

    C語言實現(xiàn)txt數(shù)據(jù)讀入內存/CPU緩存實例詳解

    這篇文章主要介紹了C語言實現(xiàn)txt數(shù)據(jù)讀入內存/CPU緩存實例詳解的相關資料,這里對實現(xiàn)該函數(shù)進行了代碼實現(xiàn),需要的朋友可以參考下
    2017-01-01
  • C語言深入細致講解動態(tài)內存管理

    C語言深入細致講解動態(tài)內存管理

    動態(tài)內存是相對靜態(tài)內存而言的。所謂動態(tài)和靜態(tài)就是指內存的分配方式。動態(tài)內存是指在堆上分配的內存,而靜態(tài)內存是指在棧上分配的內存,本文帶你深入探究C語言中動態(tài)內存的管理
    2022-05-05
  • C語言撲克牌游戲示例

    C語言撲克牌游戲示例

    大家好,本篇文章主要講的是C語言撲克牌游戲示例,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12

最新評論