VS使用TeeChart绘图控件.docx

上传人:b****1 文档编号:13696264 上传时间:2023-06-16 格式:DOCX 页数:32 大小:1.57MB
下载 相关 举报
VS使用TeeChart绘图控件.docx_第1页
第1页 / 共32页
VS使用TeeChart绘图控件.docx_第2页
第2页 / 共32页
VS使用TeeChart绘图控件.docx_第3页
第3页 / 共32页
VS使用TeeChart绘图控件.docx_第4页
第4页 / 共32页
VS使用TeeChart绘图控件.docx_第5页
第5页 / 共32页
VS使用TeeChart绘图控件.docx_第6页
第6页 / 共32页
VS使用TeeChart绘图控件.docx_第7页
第7页 / 共32页
VS使用TeeChart绘图控件.docx_第8页
第8页 / 共32页
VS使用TeeChart绘图控件.docx_第9页
第9页 / 共32页
VS使用TeeChart绘图控件.docx_第10页
第10页 / 共32页
VS使用TeeChart绘图控件.docx_第11页
第11页 / 共32页
VS使用TeeChart绘图控件.docx_第12页
第12页 / 共32页
VS使用TeeChart绘图控件.docx_第13页
第13页 / 共32页
VS使用TeeChart绘图控件.docx_第14页
第14页 / 共32页
VS使用TeeChart绘图控件.docx_第15页
第15页 / 共32页
VS使用TeeChart绘图控件.docx_第16页
第16页 / 共32页
VS使用TeeChart绘图控件.docx_第17页
第17页 / 共32页
VS使用TeeChart绘图控件.docx_第18页
第18页 / 共32页
VS使用TeeChart绘图控件.docx_第19页
第19页 / 共32页
VS使用TeeChart绘图控件.docx_第20页
第20页 / 共32页
亲,该文档总共32页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

VS使用TeeChart绘图控件.docx

《VS使用TeeChart绘图控件.docx》由会员分享,可在线阅读,更多相关《VS使用TeeChart绘图控件.docx(32页珍藏版)》请在冰点文库上搜索。

VS使用TeeChart绘图控件.docx

VS使用TeeChart绘图控件

VS2010使用TeeChart绘图控件-之一-控件和类的导入

vs2010的用法和vc6有很大的不同,特别是在一些函数调用那里,当然。

控件导入也是很不一样的

安装好控件后就可以在工程里加入teechart控件了

加入方法有如下几种:

1.添加Teechart控件

1.1插入Teechart控件

1.1.1插入控件

新建一个对话框工程,在对话框上点击鼠标右键,弹出的菜单里选择“插入ActiveX控件”

然后弹出的对话框里选择TeeChart控件

这时对话框就有TeeChart控件了

 

1.1.2vs2010另外一种插入控件的方法

vs2010对话框设置的工具栏上就有许多控件了,若想把我们常用的控件也加到工具栏上以后使用就很方便了,下面说的这种方法就是把控件加入工具栏里。

方便以后的调用

在工具栏的空白处点击右键,选择添加选项卡

 

这时vs就会新建一个选项卡,自己可以定义一个名称,这里命名为绘图控件

为选项卡添加项:

在新建的选项卡的空白处点击右键,选择“选择项”

由于控件比较多,会耗费一定的时间打开这个选择项,别以为死机了,耐心等个几十秒吧

在打开的对话框中选择选择com标签,选择teechart控件

这样teechart控件就会在你的工具栏新加的选项里了,以后都会存在(我添加TeeChat的同时还把其他的一些控件添加进去了)

1.1.3控件属性设置

双击控件进行相关设置

这里添加一个快速线图-FastLine

若数据量特别大,可以在Series标签里的Format的Drawall选项去掉

在Chart标签里还可以设置坐标轴的名称属性等,这里先不详细讲述属性的设置

2.为控件添加类

 

vs2010与vc6不一样,vs2010的控件对应的类添加相对比vc6麻烦

这里就对刚刚加入的TeeChart控件加入相关的类

 

2.1添加TypeLib的mfc类

(1)选择vs菜单“项目”-“添加类”(注意这时类视图树形控件选中最顶端的父节点)

(2)添加TypeLib的mfc类

 

(3)在可用的类型库里选择teechart5

(4)在接口里就有TeeChart对应的所有类了,这里TChart是必须的接口,其他的可以根据需要添加

(5)点击完成就把CTChart这个类添加进工程里了

 

其实第

(2)步可以选择ActiveX控件的Mfc类,操作方法雷同,不过这时是只列出对应的接口

3.把TeeChart控件和对象关联

3.1为控件关联对象

在控件上点击右键,选择添加变量,即可为控件关联对象

3.2去掉vs默认的初始化

不知为何vs会默认给添加的变量初始化0,这个初始化一定要去掉否则无法使用

public:

     CTchart1m_Chart;

 

CTeeChartDlg:

:

CTeeChartDlg(CWnd* pParent/*=NULL*/) 

    :

 CDialogEx(CTeeChartDlg:

:

IDD,pParent)

{

    m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);

}

void CTeeChartDlg:

:

DoDataExchange(CDataExchange* pDX) 

{

    CDialogEx:

:

DoDataExchange(pDX);

    DDX_Control(pDX,IDC_TCHART1,m_Chart);

}

 

这时TeeChart就可正常使用了

 

 

VS2010使用TeeChart绘图控件-之二-绘制图形(折线图,柱状图)

1.前期准备

 具体可见VS2010使用TeeChart绘图控件-之一 控件和类的导入

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

    {

        ((CSeries)m_TeeChart.Series(i)).Clear();

    }

 

通过CTchart的get_SeriesCount函数获得所有图像序列,再全部清除,这个函数经常用到,可用定义为类成员函数,这里是个对话框CTChartDlg

 

void CTChartDlg:

:

ClearAllSeries(void) 

{

    for(long i = 0;i

    {

        ((CSeries)m_TeeChart.Series(i)).Clear();

    }

}

 

好了现在开始说说怎么画折线图

2.2普通连线图

一般我们画的图都属于这种,就是把点连接起来,选择fastline的Normal,就是普通连线图

在需要画图的地方先要获得曲线序列Series,然后通过画图函数AddXY,或者AddArray作图。

2.2.1普通线图-AddXY

下面演示AddXY的方法

AddXY就是一个一个加入点,在点数不多,且需要动态显示的时候是不错的选择。

点数多的情况下嘛,那就还是用AddArray了

先看看AddXY

 

   const UINT nDATALENGTH= 100; 

    double dData[nDATALENGTH];

    for (int i=0;i

    {

        dData[i] = 100*sin((float)i)*cos((float)4*i);

    }

    //ClearAllSeries();

    CSerieslineSeries = (CSeries)m_TeeChart.Series(0);

    lineSeries.Clear();//在最前面加上ClearAllSeries(ClearAllSeries是自己写的函数)就不用了

    for(int i=0;i

    {

        lineSeries.AddXY((double)i,dData[i],NULL,0);

    }

由于在TeeChart里,只加了一个FastLine,所以Series(0)就算FastLine,代码首先获得图像序列m_TeeChart.Series(0);

然后再调用这个序列来作图,作图前先清空图像,用ClearAllSeries()也可以

然后就是一个点一个点的往里加了

做出来的效果:

AddXY的第一个参数是x点坐标,第二个是y点坐标,第三个参数是为了使x坐标特殊显示,这是会替换掉x坐标的显示内容,如我想显示“点xx“可以这样

 

    CString str; 

    for(int i=0;i

    {

        str.Format(_T("点%d"),i);

        lineSeries.AddXY((double)i,dData[i],str,0);

    }

 

第四个参数在线图里不起作用,在柱状图里可以设置颜色

2.2.2普通线图-AddArray

 

在数据量特别大时,强烈建议使用AddArray函数

AddArray的函数声明如下

voidAddArray(longArraySize,VARIANT&YArray,VARIANT&XArray);

x,y是两个VARIANT的数据类型,VARIANT有个类型是VT_ARRAY

可以给VARIANT赋一个数组进去

具体操作如下:

方法1:

 

const UINT nDATALENGTH = 100; 

double dData[nDATALENGTH];

for (int i=0;i

{

     dData[i] = 100*sin((float)i)*cos((float)4*i);

}

//声明如下数据:

VARIANTvAX,vAY;

SAFEARRAY* psax;

SAFEARRAY* psay;

SAFEARRAYBOUNDrgsabound;

//初始化

rgsabound.cElements=nDATALENGTH; 

rgsabound.lLbound=0;

psax=SafeArrayCreate(VT_R8,1,&rgsabound);//分配空间

psay=SafeArrayCreate(VT_R8,1,&rgsabound);

vAX.vt=VT_ARRAY|VT_R8;//设置为double型数组,VT_R8就是指double

vAX.parray=psax;//把内容加入VARIANT中

vAY.vt=VT_ARRAY|VT_R8;

vAY.parray=psay;

//这时VARIANT就可以加入数据了

double dtemp;//用来临时存放x坐标 

for(long i=0;i

{

    dtemp = i;

    SafeArrayPutElement(psax,&i,&dtemp);

    dtemp = dData[i];

    SafeArrayPutElement(psay,&i,&dtemp);

    //更简单写法

    //SafeArrayPutElement(psay,&i,dData+i);

}

//开始画图

CSerieslineSeries = (CSeries)m_TeeChart.Series(0); 

lineSeries.Clear();

lineSeries.AddArray(nDATALENGTH,vAY,vAX);

 

 

方法2:

这时我看TeeChart官方实例找到的方法,相对简单点

    COleSafeArrayXValues;    

    COleSafeArrayYValues;    

    DWORD numElements[] = {nDATALENGTH};    

    //创建安全数组   

    XValues.Create(VT_R8, 1,numElements);    

    YValues.Create(VT_R8, 1,numElements);    

    //初始化 

    long i;    

    double dval;

    for(i=0;i

    {       

        dval = i;

        XValues.PutElement(&i, &dval);

        dval = dData[i];

        YValues.PutElement(&i, &dval);

        //YValues.PutElement(&i,dData+i);

    };

    CSerieslineSeries = (CSeries)m_TeeChart.Series(0);

    lineSeries.Clear();

    lineSeries.AddArray(nDATALENGTH,YValues,XValues);

 

2.3去除/显示legend

如果不想要右边那一栏数据显示,可以通过代码去除

CLegend是用来控制这个显示的

 

CLegendlegend = (CLegend)m_TeeChart.get_Legend();     

legend.put_Visible(FALSE);

 

可以用一个check控件控制器显示状态

添加单选控件 

 ,id为IDC_CHECK_ShowLegend,

单击响应

void CTChartDlg:

:

OnBnClickedCheck_ShowLegend() 

{

    CLegendlegend = (CLegend)m_TeeChart.get_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.2AddXY

 

方法和线图没什么区别,直接上码:

 

    const UINT nDATALENGTH = 20; 

    double dData[nDATALENGTH];

    for (int i=0;i

    {

        dData[i] = abs(100*sin((float)i));

    }

    //

    ClearAllSeries();

    CSeriesbarSeries = (CSeries)m_TeeChart.Series

(1);

    for(int i=0;i

    {

             barSeries.AddXY((double)i,dData[i],NULL,0);

    }

 

注意不是Series(0)了

我擦~那效果

 

加个abs,好看很多~~

3.3改变柱状图的颜色

 

为啥是黑色的?

设置了绿色的,我一开始也以为坑爹的设置没有用,后来研究了一下发现时AddXY的第四个参数起作用的

 

上面的图我们是这样加的

barSeries.AddXY((double)i,dData[i],NULL,0);

 

第四个参数0就相当于RGB(0,0,0),这第四个参数就是设置颜色的了

 

把程序稍作修改

 

    for(int i=0;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));

    }

牛x

3.4去除/显示数据标示

 

好吧又遇到问题了,去掉上面的标示

ok,那个标示是用CMarks管理的,加入这个类就行了,用类向导,加入CMarks

#include"CMarks.h"

添加单选控件 

 IDC_CHECK_Marks

 

void CTChartDlg:

:

OnBnClickedCheckMarks() 

{

    CSeriesbarSeries = (CSeries)m_TeeChart.Series

(1);

    CMarksSeriesMarks = (CMarks)barSeries.get_Marks();

    if(BST_CHECKED == ((CButton*)GetDlgItem(IDC_CHECK_Marks))->GetCheck())

    {

        SeriesMarks.put_Visible(TRUE);

    }

    else

    {

        SeriesMarks.put_Visible(FALSE);

    }

}

 

效果:

3.5AddArray给柱状图添加数据

和line一样

    const UINT nDATALENGTH = 20; 

    double dData[nDATALENGTH];

    for (int i=0;i

    {

        dData[i] = abs(100*sin((float)i));

    }

    COleSafeArrayXValues;    

    COleSafeArrayYValues;    

    DWORD numElements[] = {nDATALENGTH};    

    //创建安全数组   

    XValues.Create(VT_R8, 1,numElements);    

    YValues.Create(VT_R8, 1,numElements);    

    //初始化 

    long i;    

    double dval;

    for(i=0;i

    {       

        dval = i;

        XValues.PutElement(&i, &dval);

        dval = dData[i];

        YValues.PutElement(&i, &dval);

        //YValues.PutElement(&i,dData+i);

    };

    //

    ClearAllSeries();

    CSerieslineSeries = (CSeries)m_TeeChart.Series

(1);

    lineSeries.AddArray(nDATALENGTH,YValues,XValues);

 

这时出现的图像就是默认的颜色了

想改颜色!

没问题,还是用put_Color

 

barSeries.put_Color(RGB(255,0,0));

 

TeeChart绘图控件-之三-提高绘图的效率

TeeChart是个很强大的控件,其绘图能力之强,其他控件难以比拟,但是有个问题就是他的绘图速度,其实TeeChart绘图速度还是很快的,只是大家一直都没正确运用其功能所以导致绘图速度慢的假象。

下面说说影响绘图速度的两个主要因素

1、当点数特别多时不需要绘出全部点(性能提升不大)

TeeChart绘图控件-之一文章里已经讲过,可以设置只绘出部分点。

设置方法如图:

这个选项能一定程度的提升画图速度。

提升多少,可看看如下实例:

163840个随机点,取消DrawAll时效果,使用AddXY函数,耗时1092毫秒

163840个随机点,取消DrawAll时效果,使用AddXY函数,耗时1217毫秒

可见这个效果并不明显,但是显示效果却很明显

2.通过画图函数来改变画图速度

TeeChart的AddXY函数时画图最慢的函数,但是却好多人使用,可能是简单的原因吧,我专门做了一个程序来测试AddXY和AddArray函数的效率,发现效率几乎差30倍

2.1AddXY函数:

AddXY函数每次调用都要刷新,所以画图速率相当低

如上图所示的界面画图(AddXY)按钮实现如下

randf是一个产生随机数的函数实现见源文件,

m_nPointNum是何文本编辑框关联的int型数据

IDC_STATIC_T是文本标签的ID

void CTeeChartDlg:

:

OnBnClickedButtondraw() 

{

    CSeriesChartSpeed = (CSeries)m_Chart.Series(0);

    UpdateData(TRUE);

    if (m_nPointNum<=0)

    {

        MessageBox(_T("数据点数不能小于0"));

        return;

    }

    DWORD dwTimeS,dwTimeE;

    CString str(_T(""));

    unsigned i(0);

    double* pDataX= NULL;

    double* pDataY= NULL;

    //分配内存

    pDataX = newdouble[m_nPointNum];

    pDataY = newdouble[m_nPointNum];

    for (i=0;i<(unsigned)m_nPointNum;i++)

    {

        pDataY[i] = randf(-20,20);

        pDataX[i] = i;

    }

    //由于需要计算时间,

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 自然科学 > 物理

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2