VS2010 使用TeeChart繪圖控件 - - 繪制圖形(折線圖,柱狀圖)
C++ GUI 繪圖控件目錄
MFC
VS2010 使用TeeChart繪圖控件 - 之一 - 控件和類的導(dǎo)入VS2010 使用TeeChart繪圖控件 - 之二 - 繪制圖形(折線圖,柱狀圖)TeeChart繪圖控件 - 之三 - 提高繪圖的效率MFC下好用的高速繪圖控件-(Hight-Speed Charting)繪制動態(tài)曲線
Qt
qt超強精美繪圖控件 - QCustomPlot一覽qt超強繪圖控件qwt - 安裝及配置
1.前期準備
?具體可見VS2010 使用TeeChart繪圖控件 - 之一?控件和類的導(dǎo)入
1. 1 添加TeeChart控件,給控件添加變量m_TeeChart
?
添加TeeChart控件,右擊控件,選擇添加變量,vs會自動給我們引入CTchart1這個類,但是只有這個類,我們是遠遠不夠的,需要添加teechart其他相關(guān)的類,添加方法在之前已經(jīng)講過,不再重復(fù)。
1.2. 引入必要的頭文件
其實之前的方法比較麻煩,更簡單就是通過類向?qū)В瑢?dǎo)入類型庫的類
如圖進入類向?qū)?,選擇添加類按鈕的下拉菜單,選擇類型庫中的MFC類
選擇teechart5即可
引入
#include?"CSeries.h"? #include?"CAxis.h" #include?"CAxes.h" #include?"CLegend.h"
需要還可以繼續(xù)在之后引入
--------------------------------------------------------------------------------------------------------------------------------
2. teechart 畫圖 - 折線圖
TeeChart 畫圖步驟一般是先獲得圖線序列CSeries,再給Series添加點;添加點可以用函數(shù)AddXY,或者AddArray。AddArray要比AddXY的效率高出很多,其比較可見 TeeChart繪圖控件 - 之三 - 提高繪圖的效率
2.1 清除圖形
在畫線之前把圖形清除一下,否則會覆蓋,清除可用CSeries的函數(shù)Clear();
但是當(dāng)添加多個Series后要對所有Series都clear,這是很蛋疼的,因為你有時都不知道有多少個Series,這樣可以先獲得Series的總數(shù)在clear
代碼如下
for(long?i?=?0;i<m_TeeChart.get_SeriesCount();i++)? { ?????((CSeries)m_TeeChart.Series(i)).Clear(); }
通過CTchart 的get_SeriesCount函數(shù)獲得所有圖像序列,再全部清除,這個函數(shù)經(jīng)常用到,可用定義為類成員函數(shù),這里是個對話框CTChartDlg
void?CTChartDlg::ClearAllSeries(void)? { ????for(long?i?=?0;i<m_TeeChart.get_SeriesCount();i++) ????{ ????????((CSeries)m_TeeChart.Series(i)).Clear(); ????} }
好了現(xiàn)在開始說說怎么畫折線圖
2.2 普通連線圖
一般我們畫的圖都屬于這種,就是把點連接起來,選擇fast line 的 Normal,就是普通連線圖
在需要畫圖的地方先要獲得曲線序列Series,然后通過畫圖函數(shù)AddXY,或者AddArray作圖。
2.2.1 普通線圖 - AddXY
下面演示AddXY的方法
AddXY就是一個一個加入點,在點數(shù)不多,且需要動態(tài)顯示的時候是不錯的選擇。點數(shù)多的情況下嘛,那就還是用AddArray了
先看看AddXY
????const?UINT?nDATALENGTH=100;? ????double?dData[nDATALENGTH]; ????for?(int?i=0;i<nDATALENGTH;i++) ????{ ????????dData[i]?=?100?*?sin((float)i)*cos((float)4*i); ????} ????//ClearAllSeries(); ????CSeries?lineSeries?=?(CSeries)m_TeeChart.Series(0); ????lineSeries.Clear();//在最前面加上ClearAllSeries(ClearAllSeries是自己寫的函數(shù))就不用了 ????for(int?i=0;i<nDATALENGTH;i++) ????{ ????????lineSeries.AddXY((double)i,dData[i],NULL,0); ????}
由于在TeeChart里,只加了一個FastLine,所以Series(0)就算Fast Line,代碼首先獲得圖像序列m_TeeChart.Series(0);
然后再調(diào)用這個序列來作圖,作圖前先清空圖像,用ClearAllSeries()也可以
然后就是一個點一個點的往里加了
做出來的效果:
AddXY的第一個參數(shù)是x點坐標,第二個是y點坐標,第三個參數(shù)是為了使x坐標特殊顯示,這是會替換掉x坐標的顯示內(nèi)容,如我想顯示“點xx“可以這樣
????CString?str;? ????for(int?i=0;i<nDATALENGTH;i++) ????{ ????????str.Format(_T("點%d"),i); ????????lineSeries.AddXY((double)i,dData[i],str,0); ????}
?
第四個參數(shù)在線圖里不起作用,在柱狀圖里可以設(shè)置顏色
2.2.2 普通線圖 - AddArray ? 在數(shù)據(jù)量特別大時,強烈建議使用AddArray函數(shù) AddArray的函數(shù)聲明如下 void AddArray(long ArraySize, VARIANT& YArray, VARIANT& XArray); x,y是兩個VARIANT的數(shù)據(jù)類型,VARIANT有個類型是VT_ARRAY 可以給VARIANT賦一個數(shù)組進去 具體操作如下: 方法1:
constUINT?nDATALENGTH=100;? double?dData[nDATALENGTH]; for?(int?i=0;i<nDATALENGTH;i++) { ?????dData[i]?=100*sin((float)i)*cos((float)4*i); } //聲明如下數(shù)據(jù): VARIANT?vAX,vAY; SAFEARRAY*?psax; SAFEARRAY*?psay; SAFEARRAYBOUND?rgsabound; //初始化 rgsabound.cElements=nDATALENGTH;? rgsabound.lLbound=0; psax=SafeArrayCreate(VT_R8,1,&rgsabound);//分配空間 psay=SafeArrayCreate(VT_R8,1,&rgsabound); vAX.vt=VT_ARRAY|VT_R8;//設(shè)置為double型數(shù)組,VT_R8就是指double vAX.parray=psax;//把內(nèi)容加入VARIANT中 vAY.vt=VT_ARRAY|VT_R8; vAY.parray=psay; //這時VARIANT?就可以加入數(shù)據(jù)了 double?dtemp;//用來臨時存放x坐標? for(long?i=0;i<nDATALENGTH;i++) { ????dtemp?=?i; ????SafeArrayPutElement(psax,&i,&dtemp); ????dtemp?=?dData[i]; ????SafeArrayPutElement(psay,&i,&dtemp); ????//更簡單寫法 ????//SafeArrayPutElement(psay,&i,dData+i); } //開始畫圖 CSeries?lineSeries?=?(CSeries)m_TeeChart.Series(0);? lineSeries.Clear(); lineSeries.AddArray(nDATALENGTH,vAY,vAX);
?
方法2:
這時我看TeeChart官方實例找到的方法,相對簡單點
COleSafeArray?XValues;???? COleSafeArray?YValues;???? DWORD?numElements[]?=?{nDATALENGTH};???? //?創(chuàng)建安全數(shù)組??? XValues.Create(VT_R8,?1,?numElements);???? YValues.Create(VT_R8,?1,?numElements);???? //?初始化? long?i;???? double?dval; for(i=0;?i<nDATALENGTH;?i++)? {??????? ????dval?=?i; ????XValues.PutElement(&i,?&dval); ????dval?=?dData[i]; ????YValues.PutElement(&i,?&dval); ????//YValues.PutElement(&i,?dData+i); }; CSeries?lineSeries?=?(CSeries)m_TeeChart.Series(0); lineSeries.Clear(); lineSeries.AddArray(nDATALENGTH,YValues,XValues);
?
2.3 去除/顯示legend
如果不想要右邊那一欄數(shù)據(jù)顯示,可以通過代碼去除
CLegend是用來控制這個顯示的
?
CLegend?legend?=?(CLegend)m_TeeChart.get_Legend();????? legend.put_Visible(FALSE);
?
可以用一個check控件控制器顯示狀態(tài)
添加單選控件?? ,id為IDC_CHECK_ShowLegend,
單擊響應(yīng)
void?CTChartDlg::OnBnClickedCheck_ShowLegend()? { ????CLegend?legend?=?(CLegend)m_TeeChart.get_Legend(); ????if(BST_CHECKED?==?((CButton*)GetDlgItem(IDC_CHECK_ShowLegend))->GetCheck()) ????{ ????????legend.put_Visible(TRUE); ????} ????else ????{ ????????legend.put_Visible(FALSE); ????} }
效果:
不用代碼的話可以通過設(shè)置控件屬性
明顯,這沒有代碼靈活 ? 2.4 改變線圖顏色 ? 默認設(shè)置是紅,我要設(shè)置成其他顏色可以用put_Colour ? 如上代碼的lineSeries最后加一個,就會變成RGB(255,0,255)的顏色了
lineSeries.put_Color(RGB(255,0,255));
效果:
3. teechart 畫圖 - ?柱狀圖
?
3.1 ?添加柱狀圖
這時會多一個圖形
注意這里默認是綠色的,等下會發(fā)現(xiàn)畫出來的不一樣
3.2 AddXY ? 方法和線圖沒什么區(qū)別,直接上碼: ?
const?UINT?nDATALENGTH?=?20;? double?dData[nDATALENGTH]; for?(int?i=0;i<nDATALENGTH;i++) { ????dData[i]?=?abs(100*sin((float)i)); } // ClearAllSeries(); CSeries?barSeries?=?(CSeries)m_TeeChart.Series(1); for(int?i=0;i<nDATALENGTH;i++) { ????barSeries.AddXY((double)i,dData[i],NULL,0); }
?
注意不是Series(0)了
效果還是很不錯的
?
加個abs,好看很多~~
3.3 改變柱狀圖的顏色 ? 為啥是黑色的?設(shè)置了綠色的,我一開始也以為坑爹的設(shè)置沒有用,后來研究了一下發(fā)現(xiàn)時AddXY的第四個參數(shù)起作用的 ? 上面的圖是這樣加的:
barSeries.AddXY((double)i,dData[i],NULL,0);
第四個參數(shù)0就相當(dāng)于RGB(0,0,0),這第四個參數(shù)就是設(shè)置顏色的了
?
把程序稍作修改
for(int?i=0;i<nDATALENGTH;i++)? { ????i%2==0 ??????????barSeries.AddXY((double)i,dData[i],NULL,RGB(255,255,0)) ????????:?barSeries.AddXY((double)i,dData[i],NULL,RGB(0,255,255)); }
很漂亮的效果~
3.4 去除/顯示 數(shù)據(jù)標示
?
好吧又遇到問題了,去掉上面的標示
ok,那個標示是用CMarks管理的,加入這個類就行了,用類向?qū)?,加入CMarks
#include "CMarks.h"
添加單選控件??IDC_CHECK_Marks
void?CTChartDlg::OnBnClickedCheckMarks()? { ????CSeries?barSeries?=?(CSeries)m_TeeChart.Series(1); ????CMarks?SeriesMarks?=?(CMarks)barSeries.get_Marks(); ????if(BST_CHECKED?==?((CButton*)GetDlgItem(IDC_CHECK_Marks))->GetCheck()) ????{ ????????SeriesMarks.put_Visible(TRUE); ????} ????else ????{ ????????SeriesMarks.put_Visible(FALSE); ????} }
效果:
3.5 AddArray 給柱狀圖添加數(shù)據(jù) 和line一樣
??const?UINT?nDATALENGTH?=?20;? ????double?dData[nDATALENGTH]; ????for?(int?i=0;i<nDATALENGTH;i++) ????{ ????????dData[i]?=?abs(100*sin((float)i)); ????} ????COleSafeArray?XValues;???? ????COleSafeArray?YValues;???? ????DWORD?numElements[]?=?{nDATALENGTH};???? ????//?創(chuàng)建安全數(shù)組??? ????XValues.Create(VT_R8,?1,?numElements);???? ????YValues.Create(VT_R8,?1,?numElements);???? ????//?初始化? ????long?i;???? ????double?dval; ????for(i=0;?i<nDATALENGTH;?i++)? ????{??????? ????????dval?=?i; ????????XValues.PutElement(&i,?&dval); ????????dval?=?dData[i]; ????????YValues.PutElement(&i,?&dval); ????????//YValues.PutElement(&i,?dData+i); ????}; ????// ????ClearAllSeries(); ????CSeries?lineSeries?=?(CSeries)m_TeeChart.Series(1); ????lineSeries.AddArray(nDATALENGTH,YValues,XValues);
?
這時出現(xiàn)的圖像就是默認的顏色了
想改顏色!沒問題,還是用put_Color ?
barSeries.put_Color(RGB(255,0,0));
C++ GUI 繪圖控件目錄
MFC
VS2010 使用TeeChart繪圖控件 - 之一 - 控件和類的導(dǎo)入VS2010 使用TeeChart繪圖控件 - 之二 - 繪制圖形(折線圖,柱狀圖)TeeChart繪圖控件 - 之三 - 提高繪圖的效率MFC下好用的高速繪圖控件-(Hight-Speed Charting)繪制動態(tài)曲線
Qt
qt超強精美繪圖控件 - QCustomPlot一覽qt超強繪圖控件qwt - 安裝及配置