原創(chuàng)|使用教程|編輯:龔雪|2015-06-09 10:11:01.000|閱讀 1109 次
概述:TeeChart是個(gè)很強(qiáng)大的控件,其繪圖能力之強(qiáng),其他控件難以比擬,但是有個(gè)問題就是他的繪圖速度,其實(shí)TeeChart繪圖速度還是很快的,只是大家一直都沒正確運(yùn)用其功能所以導(dǎo)致繪圖速度慢的假象。
# 界面/圖表報(bào)表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
相關(guān)鏈接:
TeeChart是個(gè)很強(qiáng)大的控件,其繪圖能力之強(qiáng),其他控件難以比擬,但是有個(gè)問題就是他的繪圖速度,其實(shí)TeeChart繪圖速度還是很快的,只是大家一直都沒正確運(yùn)用其功能所以導(dǎo)致繪圖速度慢的假象。
下面說說影響繪圖速度的兩個(gè)主要因素。
1、當(dāng)點(diǎn)數(shù)特別多時(shí)不需要繪出全部點(diǎn)(性能提升不大)
TeeChart繪圖控件可以設(shè)置只繪出部分點(diǎn)。設(shè)置方法如圖:

這個(gè)選項(xiàng)能一定程度的提升畫圖速度。提升多少,可看看如下實(shí)例:
163840個(gè)隨機(jī)點(diǎn),取消Draw All時(shí)效果,使用AddXY函數(shù),耗時(shí)1092毫秒

163840個(gè)隨機(jī)點(diǎn),取消Draw All時(shí)效果,使用AddXY函數(shù),耗時(shí)1217毫秒

可見這個(gè)效果并不明顯,但是顯示效果卻很明顯
2.通過畫圖函數(shù)來改變畫圖速度
TeeChart的AddXY函數(shù)時(shí)畫圖最慢的函數(shù),但是卻好多人使用,可能是簡單的原因吧,我專門做了一個(gè)程序來測試AddXY和AddArray函數(shù)的效率,發(fā)現(xiàn)效率幾乎差30倍。
2.1AddXY函數(shù):
AddXY 函數(shù)每次調(diào)用都要刷新,所以畫圖速率相當(dāng)?shù)?/p>
如上圖所示的界面畫圖(AddXY)按鈕實(shí)現(xiàn)如下。
randf是一個(gè)產(chǎn)生隨機(jī)數(shù)的函數(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ù)點(diǎn)數(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;
}
//由于需要計(jì)算時(shí)間,畫圖就不在第一個(gè)for循環(huán)里實(shí)現(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("耗時(shí):%d ms"),dwTimeE);
SetDlgItemText(IDC_STATIC_T,str);
}
在
for(i=0;i<(unsigned)m_nPointNum;i++)
{
ChartSpeed.AddXY(pDataX[i],pDataY[i],NULL,0);
}
上下加了兩個(gè)計(jì)時(shí),專門計(jì)算畫圖時(shí)間。
程序運(yùn)行時(shí)間如圖:1638400個(gè)點(diǎn)居然花了差不多6秒。

2.2 AddArray函數(shù)-真正實(shí)現(xiàn)快速畫圖函數(shù)
為了驗(yàn)證AddArray的快速性,
添加了一個(gè)按鈕:
按鈕依然實(shí)現(xiàn)畫圖,不過是用AddArray函數(shù),
利用COleSafeArray 實(shí)現(xiàn)數(shù)據(jù)存儲。
實(shí)現(xiàn)代碼如下:
void CTeeChartDlg::OnBnClickedButtondraw2()
{
CSeries ChartSpeed = (CSeries)m_Chart.Series(0);
UpdateData(TRUE);
if (m_nPointNum<=0)
{
MessageBox(_T("數(shù)據(jù)點(diǎn)數(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);
};
//由于需要計(jì)算時(shí)間,畫圖就不在第一個(gè)for循環(huán)里實(shí)現(xiàn)了
dwTimeS = GetTickCount();
ChartSpeed.Clear();
ChartSpeed.AddArray(m_nPointNum,YValues,XValues);
dwTimeE = GetTickCount();
dwTimeE -= dwTimeS;
str.Format(_T("耗時(shí):%d ms"),dwTimeE);
SetDlgItemText(IDC_STATIC_T,str);
}
效果如何?
看圖

快30倍,1638400個(gè)點(diǎn)瞬間完成
一般我們的數(shù)據(jù)經(jīng)常是用double數(shù)組保存的,很少用COleSafeArray所以,為了方便,可以寫一個(gè)函數(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í)只要把數(shù)組的首地址和長度傳進(jìn)去就行了。
from:CSDN
本站文章除注明轉(zhuǎn)載外,均為本站原創(chuàng)或翻譯。歡迎任何形式的轉(zhuǎn)載,但請務(wù)必注明出處、不得修改原文相關(guān)鏈接,如果存在內(nèi)容上的異議請郵件反饋至chenjj@ke049m.cn