VS2010使⽤TeeChart绘图控件-之⼆-绘制图形(折线图,柱
状图)
1.前期准备
1. 1 添加TeeChart控件,给控件添加变量m_TeeChart
添加TeeChart控件,右击控件,选择添加变量,vs会⾃动给我们引⼊CTchart1这个类,但是只有这个类,我们是远远不够的,需要添加teechart其他相关的类,添加⽅法在之前已经讲过,不再重复。
1.2. 引⼊必要的头⽂件
其实之前的⽅法⽐较⿇烦,更简单就是通过类向导,导⼊类型库的类
如图进⼊类向导,选择添加类按钮的下拉菜单,选择类型库中的MFC类
选择teechart5即可
暂时引⼊
#include "CSeries.h"
#include "CAxis.h"
#include "CAxes.h"
#include "CLegend.h"
需要还可以继续在之后引⼊
--------------------------------------------------------------------------------------------------------------------------------
2. teechart 画图 - 折线图
TeeChart 画图步骤⼀般是先获得图线序列CSeries,再给Series添加点;添加点可以⽤函数AddXY,或者AddArray。AddArray要⽐AddXY的效率⾼出很多,其⽐较可见 TeeChart绘图控件 - 之三 - 提⾼绘图的效率
2.1 清除图形
在画线之前把图形清除⼀下,否则会覆盖,清除可⽤CSeries的函数Clear();
但是当添加多个Series后要对所有Series都clear,这是很蛋疼的,因为你有时都不知道有多少个Series,
这样可以先获得Series的总数在clear
代码如下
for( long i =0;i <_SeriesCount();i ++)
{
((CSeries)m_TeeChart.Series(i)).Clear();
}
通过CTchart 的get_SeriesCount函数获得所有图像序列,再全部清除,这个函数经常⽤到,可⽤定义为类成员函数,这⾥是个对话框CTChartDlg
void CTChartDlg ::ClearAllSeries( void)
{
for( long i =0;i <_SeriesCount();i ++)
{
((CSeries)m_TeeChart.Series(i)).Clear();
}
}
好了现在开始说说怎么画折线图
2.2 普通连线图
⼀般我们画的图都属于这种,就是把点连接起来,选择fast line 的 Normal,就是普通连线图
在需要画图的地⽅先要获得曲线序列Series,然后通过画图函数AddXY,或者AddArray作图。
2.2.1 普通线图 - AddXY
下⾯演⽰AddXY的⽅法
AddXY就是⼀个⼀个加⼊点,在点数不多,且需要动态显⽰的时候是不错的选择。点数多的情况下嘛,那就还是⽤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是⾃⼰写的函数)就不⽤了
for( int i =0;i <nDATALENGTH;i ++)
{
teechart控件安装lineSeries.AddXY(( double)i,dData[i],NULL, 0);
}
由于在TeeChart⾥,只加了⼀个FastLine,所以Series(0)就算Fast Line,代码⾸先获得图像序列m_TeeChart.Series(0);
然后再调⽤这个序列来作图,作图前先清空图像,⽤ClearAllSeries()也可以
然后就是⼀个点⼀个点的往⾥加了
做出来的效果:
AddXY的第⼀个参数是x点坐标,第⼆个是y点坐标,第三个参数是为了使x坐标特殊显⽰,这是会替换掉x坐标的显⽰内容,如我想显⽰“点xx“可以这样
CString str;
for(int i=0;i<nDATALENGTH;i++)
{
str.Format(_T("点%d"),i);
lineSeries.AddXY((double)i,dData[i],str,0);
}
第四个参数在线图⾥不起作⽤,在柱状图⾥可以设置颜⾊
2.2.2 普通线图 - AddArray
在数据量特别⼤时,强烈建议使⽤AddArray函数
AddArray的函数声明如下
void AddArray(long ArraySize, VARIANT& YArray, VARIANT& XArray);
x,y是两个VARIANT的数据类型,VARIANT有个类型是VT_ARRAY
可以给VARIANT赋⼀个数组进去
具体操作如下:
⽅法1:
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};
// 创建安全数组
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
如果不想要右边那⼀栏数据显⽰,可以通过代码去除CLegend是⽤来控制这个显⽰的
CLegend legend = (CLegend)_Legend(); legend.put_Visible(FALSE);
可以⽤⼀个check控件控制器显⽰状态
添加单选控件,id为IDC_CHECK_ShowLegend,单击响应
void CTChartDlg ::OnBnClickedCheck_ShowLegend()
{
CLegend legend = (CLegend)_Legend();
if(BST_CHECKED == (( CButton*)GetDlgItem(IDC_CHECK_ShowLegend)) ->GetCheck()) {
legend.put_Visible(TRUE);
}
else
{
legend.put_Visible(FALSE);
}
}
效果:
不⽤代码的话可以通过设置控件属性
明显,这没有代码灵活
2.4 改变线图颜⾊
默认设置是红,我要设置成其他颜⾊可以⽤put_Colour
如上代码的lineSeries最后加⼀个,就会变成RGB(255,0,255)的颜⾊了lineSeries.put_Color(RGB( 255, 0, 255));
效果:
3. teechart 画图 - 柱状图
3.1 添加柱状图
这时会多⼀个图形
注意这⾥默认是绿⾊的,等下会发现画出来的不⼀样
3.2 AddXY
⽅法和线图没什么区别,直接上码:
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论