`
wx1569110409
  • 浏览: 18604 次
文章分类
社区版块
存档分类
最新评论

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

 
阅读更多



C++ GUI 绘图控件目录

MFC

Qt



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<m_TeeChart.get_SeriesCount();i++) 
{
     ((CSeries)m_TeeChart.Series(i)).Clear();
}

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

void CTChartDlg::ClearAllSeries(void) 
{
    for(long i = 0;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

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++)
    {
        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:
constUINT 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, 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)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(255,0,255));

效果:




3. teechart 画图 -  柱状图

 

3.1  添加柱状图



这时会多一个图形



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


3.2 AddXY

 
方法和线图没什么区别,直接上码:
 
const UINT nDATALENGTH = 20; 
double dData[nDATALENGTH];

for (int i=0;i<nDATALENGTH;i++)
{
    dData[i] = abs(100*sin((float)i));
}
//
ClearAllSeries();
CSeries barSeries = (CSeries)m_TeeChart.Series(1);
for(int i=0;i<nDATALENGTH;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<nDATALENGTH;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));
}



很漂亮的效果~

3.4 去除/显示 数据标示

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

添加单选控件  IDC_CHECK_Marks

void CTChartDlg::OnBnClickedCheckMarks() 
{
    CSeries barSeries = (CSeries)m_TeeChart.Series(1);
    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一样
const UINT nDATALENGTH = 20; 
    double dData[nDATALENGTH];

    for (int i=0;i<nDATALENGTH;i++)
    {
        dData[i] = abs(100*sin((float)i));
    }
    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);
    };
    //
    ClearAllSeries();
    CSeries lineSeries = (CSeries)m_TeeChart.Series(1);
    lineSeries.AddArray(nDATALENGTH,YValues,XValues);


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



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




C++ GUI 绘图控件目录

MFC

Qt






推广

teechart应用技术详解——快速图表制作工具 VC++ MFC Extensions  by Example/J.E. Swanke C++ Primer Plus 第6版

转载于:https://my.oschina.net/2nmjeSMen3/blog/674362

分享到:
评论

相关推荐

    VS2010 使用TeeChart绘图控件(含项目).rar

    2. "VS2010 使用TeeChart绘图控件 - 之二 - 绘制图形(折线图,柱状图) - 尘中远的专栏 - 博客频道 - CSDN_NET.mht":这份教程详细讲解了如何利用TeeChart绘制折线图和柱状图,包括设置图表类型、添加数据点、调整...

    VS2008环境下Teechart绘制折线图柱状图

    VS2008环境下Teechart绘制折线图柱状图 ...使用TeeChart控件在VS2008环境下绘制折线图柱状图需要按照上述步骤进行,包括安装控件、设置控件属性、添加TypeLib的MFC类、关联对象、清除图形等步骤。

    TeeChart绘图控件(VS2010)

    **TeeChart绘图控件在VS2010中的应用** TeeChart是一款强大的图形绘制控件,广泛应用于数据可视化领域,尤其适用于Visual Studio 2010开发环境。这款控件支持多种编程语言,如C++, C#, VB.NET等,并且与MFC...

    TeeChart.Pro.v5安装包及操作方法

    2. **绘制图形**:文档“VS2010 使用TeeChart绘图控件 - 之二 - 绘制图形(折线图,柱状图).doc”提供了创建折线图和柱状图的实例。例如,你可以创建一个`TeeChart`对象,然后添加`Series`,设置`Series.Type`为所...

    TeeChart绘图控件——VS2010 使用.zip_TeeChart_TeeChart控件_TeeChart绘图_teech

    在Visual Studio 2010中使用TeeChart控件,可以帮助开发者轻松创建各种类型的图表,如折线图、柱状图、饼图、散点图等,以直观地展示数据。以下是对TeeChart控件在VS2010中使用的一些关键知识点的详细解释: 1. **...

    TeeChart5实时图形绘制、显示控件

    **TeeChart5:实时图形绘制与显示控件详解** TeeChart5是一款高效且功能丰富的实时图形绘制和显示控件,广泛应用于各种行业,尤其是那些需要实时数据采集和监控的场景。它提供了强大的图表绘制能力,使得开发者可以...

    MFC下好用的高速绘图控件-(Hight-Speed Charting)

    3. **丰富的图表类型**:提供多种图表类型,如折线图、柱状图、饼图、散点图等,满足不同数据展示需求。 4. **自定义样式和交互**:允许开发者自定义颜色、线条样式、标记等视觉元素,同时支持用户与图表的交互,如...

    teechart绘图控件vc教程4

    首先,TeeChart8是TeeChart控件的第八个主要版本,它提供了丰富的图表类型,如折线图、柱状图、饼图、散点图等,支持2D和3D视图,以及各种自定义选项,使开发者能够创建出专业且吸引人的图形展示。在VC++项目中集成...

    使用TeeChart绘制实时曲线

    它支持多种类型的图表,如折线图、柱状图、饼图等,并提供了丰富的自定义选项。本文将详细介绍如何在VC环境中利用TeeChart来实现动态更新的实时曲线绘制。 #### 2. 安装与注册TeeChart ActiveX控件 - **安装**: ...

    teechart控件使用

    首先,TeeChart控件提供了丰富的图表类型,包括折线图、柱状图、饼图、散点图、热力图等,以满足各种数据表示的需求。这些图表不仅外观专业,而且支持自定义样式和颜色,使数据可视化更具吸引力和解释性。 在VC6.0...

    TeeChar8控件及其使用方法(针对于VC++)

    - **VS2010 使用TeeChart绘图控件 - 之二 - 绘制图形(折线图,柱状图) - 尘中远的专栏 - 博客频道 - CSDN.NET.mht**:这个MHT文件可能是一个博客文章,详细介绍了如何在VS2010中使用TeeChart绘制折线图和柱状图,...

    TeeChart控件

    TeeChart控件是一款强大的图形绘制工具,广泛应用于.NET Framework和ActiveX环境中的数据可视化。由Steema Software公司开发,它提供了丰富的图表类型和自定义选项,使得开发者能够轻松地在应用程序中创建出专业级别...

    Chart控件,teechart控件,Visual Basic

    在Visual Basic .NET (VB.NET)环境中,Chart控件是一个强大的工具,用于创建各种图表,如折线图、柱状图、饼图等,适用于数据分析和可视化。TeeChart控件是另一个高级图表库,提供了更多自定义和扩展功能。在本篇...

    teeChart8控件

    1. **多样化图表类型**:teeChart8支持多种图表类型,包括折线图、柱状图、饼图、散点图、甘特图、热力图等,满足不同数据展示需求。 2. **自定义样式**:控件允许用户自定义每个元素的样式,如线条宽度、颜色、填充...

    teechart8控件教程3

    2. **图表类型**:TeeChart提供了丰富的图表类型,如折线图、柱状图、饼图、散点图、热力图等。每个图表类型都有其特定的用途,适用于不同种类的数据分析和可视化需求。 3. **自定义轴**:用户可以自由配置图表的X...

    TEEChart图表控件使用文档以及实例代码 TeeChart应用技术详解 delphi

    阅读此文档,你可以了解到如何在Delphi项目中引入和配置TeeChart控件,以及如何创建各种类型的图表,如折线图、柱状图、饼图、散点图等。此外,文档还会讲解如何进行图表的美化,包括调整颜色、线条样式、字体等,...

    TeeChart控件介绍及在实时监控系统中的应用

    #### 二、TeeChart控件在C++环境下的集成与使用 ##### 2.1 导入TeeChart到C++项目 在C++环境下使用TeeChart控件之前,首先需要将其导入到项目中。具体步骤如下: 1. **系统注册**:确保TeeChart5控件已经在系统中...

    Teechart使用实例

    它提供了丰富的图表类型,如折线图、柱状图、饼图、散点图等,使得用户能够方便地展示和理解复杂的数据。在本实例中,我们将深入探讨如何使用Teechart来绘制曲线图,特别关注如何处理数组数据并将时间轴与数值关联...

    vb中使用TeeChart控件

    TeeChart控件提供了丰富的图表类型和自定义选项,使得开发者能够轻松地在应用程序中集成各种图表,如折线图、柱状图、饼图、散点图等,以直观地展示数据。下面我们将深入探讨如何在VB中使用TeeChart控件进行绘图,并...

    Teechart控件

    它提供了丰富的图表类型,如折线图、柱状图、饼图、散点图等,使得数据的展示既直观又美观。在描述中提到的场景,TeeChart控件与网络UDP协议相结合,实现了数据的实时接收与动态显示。 首先,我们需要理解UDP(User...

Global site tag (gtag.js) - Google Analytics