原創(chuàng)|使用教程|編輯:龔雪|2015-06-09 10:11:01.000|閱讀 1100 次
概述:TeeChart是個很強大的控件,其繪圖能力之強,其他控件難以比擬,但是有個問題就是他的繪圖速度,其實TeeChart繪圖速度還是很快的,只是大家一直都沒正確運用其功能所以導(dǎo)致繪圖速度慢的假象。
# 界面/圖表報表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
相關(guān)鏈接:
TeeChart是個很強大的控件,其繪圖能力之強,其他控件難以比擬,但是有個問題就是他的繪圖速度,其實TeeChart繪圖速度還是很快的,只是大家一直都沒正確運用其功能所以導(dǎo)致繪圖速度慢的假象。
下面說說影響繪圖速度的兩個主要因素。
1、當(dāng)點數(shù)特別多時不需要繪出全部點(性能提升不大)
TeeChart繪圖控件可以設(shè)置只繪出部分點。設(shè)置方法如圖:
這個選項能一定程度的提升畫圖速度。提升多少,可看看如下實例:
163840個隨機點,取消Draw All時效果,使用AddXY函數(shù),耗時1092毫秒
163840個隨機點,取消Draw All時效果,使用AddXY函數(shù),耗時1217毫秒
可見這個效果并不明顯,但是顯示效果卻很明顯
2.通過畫圖函數(shù)來改變畫圖速度
TeeChart的AddXY函數(shù)時畫圖最慢的函數(shù),但是卻好多人使用,可能是簡單的原因吧,我專門做了一個程序來測試AddXY和AddArray函數(shù)的效率,發(fā)現(xiàn)效率幾乎差30倍。
2.1AddXY函數(shù):
AddXY 函數(shù)每次調(diào)用都要刷新,所以畫圖速率相當(dāng)?shù)?/p>
如上圖所示的界面畫圖(AddXY)按鈕實現(xiàn)如下。
randf是一個產(chǎn)生隨機數(shù)的函數(shù)實現(xiàn)見源文件,
m_nPointNum是何文本編輯框關(guān)聯(lián)的int型數(shù)據(jù),
IDC_STATIC_T是文本標(biāo)簽的ID,
void CTeeChartDlg::OnBnClickedButtondraw() { CSeries ChartSpeed = (CSeries)m_Chart.Series(0); UpdateData(TRUE); if (m_nPointNum<=0) { MessageBox(_T("數(shù)據(jù)點數(shù)不能小于0")); return; } DWORD dwTimeS,dwTimeE; CString str(_T("")); unsigned i(0); double* pDataX= NULL; double* pDataY= NULL; //分配內(nèi)存 pDataX = newdouble[m_nPointNum]; pDataY = newdouble[m_nPointNum]; for (i=0;i<(unsigned)m_nPointNum;i++) { pDataY[i] = randf(-20,20); pDataX[i] = i; } //由于需要計算時間,畫圖就不在第一個for循環(huán)里實現(xiàn)了 dwTimeS = GetTickCount(); ChartSpeed.Clear(); for(i=0;i<(unsigned)m_nPointNum;i++) { ChartSpeed.AddXY(pDataX[i],pDataY[i],NULL,0); } dwTimeE = GetTickCount(); dwTimeE -= dwTimeS; if (pDataX) { delete[] pDataX; } if (pDataY) { delete[] pDataY; } str.Format(_T("耗時:%d ms"),dwTimeE); SetDlgItemText(IDC_STATIC_T,str); }
在
for(i=0;i<(unsigned)m_nPointNum;i++) { ChartSpeed.AddXY(pDataX[i],pDataY[i],NULL,0); }
上下加了兩個計時,專門計算畫圖時間。
程序運行時間如圖:1638400個點居然花了差不多6秒。
2.2 AddArray函數(shù)-真正實現(xiàn)快速畫圖函數(shù)
為了驗證AddArray的快速性,
添加了一個按鈕:
按鈕依然實現(xiàn)畫圖,不過是用AddArray函數(shù),
利用COleSafeArray 實現(xiàn)數(shù)據(jù)存儲。
實現(xiàn)代碼如下:
void CTeeChartDlg::OnBnClickedButtondraw2() { CSeries ChartSpeed = (CSeries)m_Chart.Series(0); UpdateData(TRUE); if (m_nPointNum<=0) { MessageBox(_T("數(shù)據(jù)點數(shù)不能小于0")); return; } DWORD dwTimeS,dwTimeE; CString str(_T("")); long i(0); double val; COleSafeArray XValues; COleSafeArray YValues; DWORD pNumElements[] = {m_nPointNum}; XValues.Create(VT_R8, 1, pNumElements); YValues.Create(VT_R8, 1, pNumElements); for(i=0; i<m_nPointNum; i++) { val = i; XValues.PutElement(&i, &val); val = randf(-20,20); YValues.PutElement(&i, &val); }; //由于需要計算時間,畫圖就不在第一個for循環(huán)里實現(xiàn)了 dwTimeS = GetTickCount(); ChartSpeed.Clear(); ChartSpeed.AddArray(m_nPointNum,YValues,XValues); dwTimeE = GetTickCount(); dwTimeE -= dwTimeS; str.Format(_T("耗時:%d ms"),dwTimeE); SetDlgItemText(IDC_STATIC_T,str); }
效果如何?
看圖
快30倍,1638400個點瞬間完成
一般我們的數(shù)據(jù)經(jīng)常是用double數(shù)組保存的,很少用COleSafeArray所以,為了方便,可以寫一個函數(shù)方便畫圖
如下:
void DrawLine(double* pX,double* pY,long nNum) { COleSafeArray XValues; COleSafeArray YValues; long i(0); DWORD wLength = nNum; XValues.Create(VT_R8, 1, &wLength); YValues.Create(VT_R8, 1, &wLength); for(i=0; i<nNum; i++) { XValues.PutElement(&i, pX+i); YValues.PutElement(&i, pY+i); } CSeries Chart = (CSeries)m_Chart.Series(0); Chart.Clear(); Chart.AddArray(nNum,YValues,XValues); }
調(diào)用時只要把數(shù)組的首地址和長度傳進去就行了。
from:CSDN
本站文章除注明轉(zhuǎn)載外,均為本站原創(chuàng)或翻譯。歡迎任何形式的轉(zhuǎn)載,但請務(wù)必注明出處、不得修改原文相關(guān)鏈接,如果存在內(nèi)容上的異議請郵件反饋至chenjj@fc6vip.cn