當(dāng)前位置:首頁 > 芯聞號 > 充電吧
[導(dǎo)讀]C++ GUI 繪圖控件目錄MFCVS2010 使用TeeChart繪圖控件 - 之一 - 控件和類的導(dǎo)入VS2010 使用TeeChart繪圖控件 - 之二 - 繪制圖形(折線圖,柱狀圖)TeeCh



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 - 安裝及配置


本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉