1.前期准备

详细可见VS2010 使用TeeChart画图控件 - 之中的一个 控件和类的导入

1. 1 加入TeeChart控件,给控件加入变量m_TeeChart

加入TeeChart控件,右击控件,选择加入变量,vs会自己主动给我们引入CTchart1这个类,可是仅仅有这个类,我们是远远不够的,须要加入teechart其它相关的类,加入方法在之前已经讲过,不再反复。

1.2. 引入必要的头文件

事实上之前的方法比較麻烦,更简单就是通过类向导,导入类型库的类

如图进入类向导,选择加入类button的下拉菜单,选择类型库中的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

代码例如以下

    ;i<m_TeeChart.get_SeriesCount();i++) 

    {

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

    }
 

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

 
void CTChartDlg::ClearAllSeries(void

{

    ;i<m_TeeChart.get_SeriesCount();i++)

    {

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

    }

}
 

好了如今開始说说怎么画折线图

2.2 普通连线图

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

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

2.2.1 普通线图 - AddXY

以下演示AddXY的方法

AddXY就是一个一个增加点,在点数不多,且须要动态显示的时候是不错的选择。点数多的情况下嘛,那就还是用AddArray了

先看看AddXY

 


    ; 

    double dData[nDATALENGTH];

    ;i<nDATALENGTH;i++)

    {

        dData[i] *i);

    }

    //ClearAllSeries();

    CSeries lineSeries );

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

    ;i<nDATALENGTH;i++)

    {

        lineSeries.AddXY(();

    }

因为在TeeChart里,仅仅加了一个FastLine,所以Series(0)就算Fast Line,代码首先获得图像序列m_TeeChart.Series();

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

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

做出来的效果:

AddXY的第一个參数是x点坐标,第二个是y点坐标,第三个參数是为了使x坐标特殊显示,这是会替换掉x坐标的显示内容,如我想显示“点xx“能够这样
 
    CString str; 

    ;i<nDATALENGTH;i++)

    {

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

        lineSeries.AddXY(();

    }
 

第四个參数在线图里不起作用,在柱状图里能够设置颜色

2.2.2 普通线图 - AddArray

 
在数据量特别大时,强烈建议使用AddArray函数
AddArray的函数声明例如以下
void AddArray(long ArraySize, VARIANT& YArray, VARIANT& XArray);
x,y是两个VARIANT的数据类型,VARIANT有个类型是VT_ARRAY
能够给VARIANT赋一个数组进去
详细操作例如以下:
方法1:
 
const UINT nDATALENGTH = 100; 

double dData[nDATALENGTH];



for (int i=0;i<nDATALENGTH;i++)

{

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

}

//声明例如以下数据:

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;//设置为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<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};    

    // 创建安全数组   

    XValues.Create(VT_R8, , numElements);    

    YValues.Create(VT_R8, , numElements);    

    // 初始化 

    long i;    

    double dval;

    ; i<nDATALENGTH; i++) 

    {       

        dval = i;

        XValues.PutElement(&i, &dval);

        dval = dData[i];

        YValues.PutElement(&i, &dval);

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

    };

    CSeries lineSeries );

    lineSeries.Clear();

    lineSeries.AddArray(nDATALENGTH,YValues,XValues);
 

2.3 去除/显示legend

假设不想要右边那一栏数据显示,能够通过代码去除
CLegend是用来控制这个显示的
 
CLegend legend = (CLegend)m_TeeChart.get_Legend();     

legend.put_Visible(FALSE);
 
能够用一个check控件控制器显示状态

加入单选控件   ,id为IDC_CHECK_ShowLegend,

单击响应

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);

    }

}
 
效果:

不用代码的话能够通过设置控件属性

明显,这没有代码灵活
 

2.4 改变线图颜色

 
默认设置是红,我要设置成其它颜色能够用put_Colour
 
如上代码的lineSeries最后加一个,就会变成RGB(255,0,255)的颜色了
 
lineSeries.put_Color(RGB(,,));
 
效果:



3. teechart 绘图 -  柱状图

3.1  加入柱状图

这时会多一个图形

注意这里默认是绿色的,等下会发现画出来的不一样

3.2 AddXY

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

    double dData[nDATALENGTH];



    ;i<nDATALENGTH;i++)

    {

        dData[i] *sin((float)i));

    }

    //

    ClearAllSeries();

    CSeries barSeries );

    ;i<nDATALENGTH;i++)

    {

             barSeries.AddXY(();

    }
 
注意不是Series(0)了


我擦~那效果
 
加个abs,好看非常多~~

3.3 改变柱状图的颜色

 
为啥是黑色的?设置了绿色的,我一開始也以为坑爹的设置没实用,后来研究了一下发现时AddXY的第四个參数起作用的
 
上面的图我们是这样加的
barSeries.AddXY((double)i,dData[i],NULL,0);
 
第四个參数0就相当于RGB(0,0,0),这第四个參数就是设置颜色的了
 
把程序稍作改动
 
    ;i<nDATALENGTH;i++) 

    {

        i

            ,,))

            ,,));

    }

牛x

3.4 去除/显示 数据标示

 
好吧又遇到问题了,去掉上面的标示
ok,那个标示是用CMarks管理的,增加这个类即可了,用类向导,增加CMarks
#include "CMarks.h"

加入单选控件  IDC_CHECK_Marks

 
void CTChartDlg::OnBnClickedCheckMarks() 

{

    CSeries barSeries );

    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 给柱状图加入数据

和line一样



    ; 

    double dData[nDATALENGTH];



    ;i<nDATALENGTH;i++)

    {

        dData[i] *sin((float)i));

    }

    COleSafeArray XValues;    

    COleSafeArray YValues;    

    DWORD numElements[] = {nDATALENGTH};    

    // 创建安全数组   

    XValues.Create(VT_R8, , numElements);    

    YValues.Create(VT_R8, , numElements);    

    // 初始化 

    long i;    

    double dval;

    ; i<nDATALENGTH; i++) 

    {       

        dval = i;

        XValues.PutElement(&i, &dval);

        dval = dData[i];

        YValues.PutElement(&i, &dval);

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

    };

    //

    ClearAllSeries();

    CSeries lineSeries );

    lineSeries.AddArray(nDATALENGTH,YValues,XValues);
 
这时出现的图像就是默认的颜色了

想改颜色!没问题,还是用put_Color
 
barSeries.put_Color(RGB(,,));

VS2010 使用TeeChart画图控件 - 之二 - 绘制图形(折线图,柱状图)的更多相关文章

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

    1.前期准备 具体可见VS2010 使用TeeChart绘图控件 - 之一 控件和类的导入 1. 1 添加TeeChart控件,给控件添加变量m_TeeChart 添加TeeChart控件,右击控件, ...

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

    vs2010的用法和vc6有很大的不同,特别是在一些函数调用那里,当然.控件导入也是很不一样的 安装好控件后就可以在工程里加入teechart控件了 加入方法有如下几种: 1.添加Teechart控件 ...

  3. EasyMvc入门教程-图形控件说明(21)线形图+柱状图+饼形图

    本章将介绍一些基本但常用的图形:线型图,柱状图和饼形图. 以上三种图形对于的数据都是键值对数组,请参考第一个例子: @{ var data = new List<LineItem>(); ...

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

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

  5. 对百度WebUploader开源上传控件的二次封装,精简前端代码(两句代码搞定上传)

    前言 首先声明一下,我这个是对WebUploader开源上传控件的二次封装,底层还是WebUploader实现的,只是为了更简洁的使用他而已. 下面先介绍一下WebUploader 简介: WebUp ...

  6. PropertyGrid控件由浅入深(二):基础用法

    目录 PropertyGrid控件由浅入深(一):文章大纲 PropertyGrid控件由浅入深(二):基础用法 控件的外观构成 控件的外观构成如下图所示: PropertyGrid控件包含以下几个要 ...

  7. GUI创建各常用控件(二)

    继续接着上一篇! 在我看来有一点需要申明:由于是GUI的相关知识,所以我只是在复习中粗略的总结而已,因此参考价值可能有限,更多的是当作自己学习的一个记录以及便于自己查阅. 好啦!干货继续: 1.类似于 ...

  8. 怎样在VS2013/MFC中使用TeeChart绘图控件

    TeeChart作为一款强大好用的绘图控件,通过它可以绘制出各式各样的图表,包括2D的,还有3D的,绘制的图表美观实用,这里主要讲述如何在VS2013/MFC中使用TeeChart控件,顺便说一下在V ...

  9. C#:ZedGraph画图控件(待补充)

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

随机推荐

  1. AFNetworking使用详解

    导语: 众所周知,AFNetworking是目前IOS开发中非常受欢迎的第三方网络通信类库,同时AFNetworking对苹果官方NSURLConnection和NSURLSession进行了封装,使 ...

  2. angular.js学习手册(二)

    如何使用angularjs? 各个 angular.js 版本下载: https://github.com/angular/angular.js/releases 下载完之后,在你需要使用angula ...

  3. NOI 193棋盘分割.cpp

    193:棋盘分割 查看 提交 统计 提问 总时间限制:  1000ms 内存限制:  65536kB 描述 将一个8*8的棋盘进行如下分割:将原棋盘割下一块矩形棋盘并使剩下部分也是矩形,再将剩下的部分 ...

  4. 【USACO 1.1.3】黑色星期五

    [问题描述] 13号又是一个星期五.13号在星期五比在其他日子少吗?为了回答这个问题,写一个程序,要求计算每个月的十三号落在周一到周日的次数.给出N年的一个周期,要求计算1900年1月1日至1900+ ...

  5. 修改一行SQL代码 性能提升了N倍

    在PostgreSQL中修改了一行不明显的代码,把(ANY(ARRAY[...]) 改成 ANY(VALUES(...))),结果查询时间从20s变为0.2s.最初我们学习使用EXPLAN ANALY ...

  6. ‘for’ loop initial declarations are only allowed in C99 mode

    #include <stdio.h>int main(){ for(int i=0;i<10;i++){ printf("\n%d",i); } return 0 ...

  7. 78 Subsets(求子集Medium)

    题目意思:求解一个数组的所有子集,子集内的元素增序排列eg:[1,3,2] result:[],[1],[2],[1,2],[3],[1,3],[2,3],[1,2,3]思路:这是一个递推的过程 [] ...

  8. [Struts2学习笔记] -- 环境配置

    在创建好WebProject后,就可以开始进行Struts2的环境配置,可以到Struts2官网下载,本环境使用struts-2.3.24.1版本. 首先导入必要的jar包到WebProject的/W ...

  9. Github 上利用github pages 部署站点

    一:起始 准备项目,如果你在github上已有项目,则无需新建,如果你要新起一个项目,则需先在github上创建一个项目 本文以已创建好的 github/TestGitPage  为例. 二:设置gi ...

  10. bzoj2067: [Poi2004]SZN

    Description String-Toys joint-stock 公司需要你帮他们解决一个问题. 他们想制造一个没有环的连通图模型. 每个图都是由一些顶点和特定数量的边构成. 每个顶点都可以连向 ...