QT使用qcustomplot 繪制柱狀圖

jopen 10年前發布 | 69K 次閱讀 GUI開發框架 qcustomplot QT

   今天因為需要在QT底下繪制一個柱狀圖,由于不想自己麻煩重載一個QWidget所以就在網上搜索到了QCustomPlot,按照這個項目主頁的圖像顯示它是可以滿足我的要求。

  首先來看一下效果圖(繪制風格,畫刷,顏色都使用的默認的) 

  QT使用qcustomplot 繪制柱狀圖

  先將下載來的QCustomPlot.cpp QCustomPlot.h拷貝到你的工程里

  首先在QtCreator中拖出一個QWidget,然后提升為QCustomPlot類。

  假設該成員變量為widget.

  柱狀圖我們需要兩個數據,一個是每個柱的相應標簽(QString),一個就是其值(double)

void MainWindow::init_ui()
{
    QVector labels(5);
    QVector values(5);
    for(int i=0;i<5;++i)
        labels[i]=QString("MAC")+('0'+i);
    values[0]=(10.05);
    values[1]=23;
    values[2]=12;
    values[3]=19.3;
    values[4]=20;


我們使用QCustomPlot提供的QCPBars來表示柱狀圖

QCPBars* bars=new QCPBars(this->ui->widget->xAxis,this->ui->widget->yAxis);
    QVector index(5);
    for(int i=0;i<5;++i)
        index[i]=i;
    bars->setData(index,values);



QCPBars的setData()的兩個參數也是兩個向量,只不過第一個向量index的每個元素表示“第幾個柱子”,然后后面對應的values表示對應“柱子的值”

添加完了繪制的柱狀圖,接下來添加標簽,要想完全自己定義標簽,需要先執行以下代碼關閉默認的底部標簽自動生成

this->ui->widget->xAxis->setAutoTicks(false);
    this->ui->widget->xAxis->setAutoTickLabels(false);
    this->ui->widget->xAxis->setAutoTickStep(false);

先將bars添加到widget上吧,然后自動調整下坐標系

this->ui->widget->addPlottable(bars);
    this->ui->widget->rescaleAxes();



接下來我們要生成我們標簽的位置坐標,有個公式計算,其生成的向量 coor里面就對應了我的labels的坐標,注意這個坐標不是屏幕像素坐標,而是它這個坐標系的坐標,如果不是很明白就把上面的那三個false改為true看下它默認的坐標。
double wid=this->ui->widget->xAxis->range().upper-this->ui->widget->xAxis->range().lower;
    double cl=bars->width()+(1.0wid-bars->width()5)/4;

QVector<double> coor;
for(int i=0;i<5;++i)
    coor.append(this->ui->widget->xAxis->range().lower+i*cl+bars->width()/2);
this->ui->widget->xAxis->setTickVector(coor);
this->ui->widget->xAxis->setTickVectorLabels(labels);</double></pre> <p><br />

</p>


最后replot一下
this->ui->widget->replot();
}



然后就完工了 

在MainWindow::MainWindow最后面加上一句

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



啟動程序就可以看到開頭的效果了。具體的修改顏色畫刷和QWidget里的一樣,可以調整到我們滿意的效果。

來自:http://my.oschina.net/000quanwei/blog/344135

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!