来自:https://blog.csdn.net/czyt1988/article/details/7428415

C++ GUI 绘图控件目录

MFC

VS2010 使用TeeChart绘图控件 - 之一 - 控件和类的导入
VS2010 使用TeeChart绘图控件 - 之二 - 绘制图形(折线图,柱状图)
TeeChart绘图控件 - 之三 - 提高绘图的效率
MFC下好用的高速绘图控件-(Hight-Speed Charting)
绘制动态曲线
Qt

qt超强精美绘图控件 - QCustomPlot一览
qt超强绘图控件qwt - 安装及配置
QtChart Qt官方绘图控件

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

安装好控件后就可以在工程里加入teechart控件了
加入方法有如下几种:
1.添加Teechart控件
1.1 插入Teechart控件
1.1.1 插入控件

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

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

这时对话框就有TeeChart控件了

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

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

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

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

为选项卡添加项:在新建的选项卡的空白处点击右键,选择“选择项”
由于控件比较多,会耗费一定的时间打开这个选择项,别以为死机了,耐心等个几十秒吧

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

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

1.1.3 控件属性设置

双击控件进行相关设置
这里添加一个快速线图-Fast Line

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

在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:     CTchart1 m_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就可正常使用了

TeeChart5破解版下载地址:http://download.csdn.net/detail/czyt1988/4201107

vc6,vs2010皆可用

C++ GUI 绘图控件目录

MFC

VS2010 使用TeeChart绘图控件 - 之一 - 控件和类的导入
VS2010 使用TeeChart绘图控件 - 之二 - 绘制图形(折线图,柱状图)
TeeChart绘图控件 - 之三 - 提高绘图的效率
MFC下好用的高速绘图控件-(Hight-Speed Charting)
绘制动态曲线
Qt

qt超强精美绘图控件 - QCustomPlot一览
qt超强绘图控件qwt - 安装及配置

来自:https://blog.csdn.net/wangshouchao/article/details/8837080

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:

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

牛x

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

TeeChart控件相关推荐

  1. teechart mysql_TeeChart应用技术:在C# .NET Winforms设计/运行时TeeChart控件连接到MySQL(上篇)...

    介绍 昨天我发了一篇[资源]查看Steema TeeChart图表控件的最新StandardSeriesDemo示例|附(源代码)下载文章,其中Steema/TeeChart-for-.NET-CSh ...

  2. TeeChart控件的安装与常用 功能设置

    TeeChart控件的安装 TeeChart 7.0 With Source在Delphi 7.0中的安装 一.删除Delphi7自带TeeChart  1.Component -> insta ...

  3. VS2010 MFC TeeChart控件命名

    这是我们新建的TeeChart控件 第一步:新建两条曲线 双击控件,单击Add,取消3D 双击Fast Line,就成功创建一条曲线了 修改标题: 修改Y轴: 修改X轴: 修改曲线提示:

  4. teeChart控件的异常:MARKS.CALLOUT.BRUSH.COLOR:Property callout does not exist

    环境: cb6.0 +windows xp 最近,程序中所有含有 TeeChart控件的窗口,突然之间打不开了, 连续提示3个错误: 1,...."Property callout does ...

  5. C#中TeeChart控件插件下载及安装

    下载:https://download.csdn.net/download/qq_37271216/11959104 安装:https://blog.csdn.net/sunriver2000/art ...

  6. 基于MFC串口编程和曲线图绘制(visual studio2008,Teechart绘图控件)的程序总结

    前言 今年刚进入公司按经理的要求为底盘测控机写了一个小小的console.这也是第一次教认真的完成整个程序的编写.程序不大,所用技术比较基础也不前卫,属于初级程序员的练手程序(知识的整理和搬运).虽然 ...

  7. 图表控件TeeChart安装使用

    优秀的图表控件很多,如AnyChart.TeeChart.Highcharts.FusionCharts XT,本文介绍如何在VC6.0上安装使用TeeChart,主要分三步: 第一步:安装TeeCh ...

  8. 轻松6步教您掌握TeeChart图表控件绘图攻略

    在软件开发的过程中,常会用到绘图控件,鉴于开发周期的限制,为了加快项目的开发效率,常选择使用TeeChart图表控件,快速将数据绘制成各式的曲线或图表,直观.形象地表示出数据传递出来的信息,本文就为大 ...

  9. 跨平台图表控件TeeChart使用教程:导入XML数据

    2019独角兽企业重金招聘Python工程师标准>>> TeeChart的最新版中包含了一个自动加载XML数据的新组件.这个组件的名字叫做TTeeXMLSource,用户可以在Tee ...

  10. VC++ 使用TeeChart图表控件(1)

    win10:vc6:下载后有个ocx,注册此ocx;先拷贝到system32目录:注册失败: 注册失败: 拷贝到syswow64目录:注册成功: 在VC新建一个对话框工程:在设计界面,右击对话框,插入 ...

最新文章

  1. dataframe,python,numpy 问题索引2
  2. jmeter4.0 执行jmeter_server.bat报错
  3. linux下安装nginx详细步骤_mac下安装nginx
  4. Flink从入门到精通100篇(二十一)-Flink 状态(State)管理在推荐场景中的应用
  5. mysql 插入数据后返回该条数据id
  6. java 释放指针_C库释放来自Rust的指针
  7. 移动端下网页border:1px显示
  8. PS提示错误1解决办法
  9. QCostomPlot 示例注解 2
  10. Java队列Disruptor 的使用
  11. python如何将抓取的数据保存到excel_Python实现提取XML内容并保存到Excel中的方法...
  12. ISL22346WFRT20Z-TK 数字电位器 4路 I²C
  13. 从零开始封装windows10 1803 超详细图文分享 第二篇:母盘的定制与安装
  14. 教你轻松创建谷歌账号、谷歌邮箱!
  15. CnOpenData工商注册企业数量统计数据:省份-年度-企业数量信息表
  16. html天猫倒计时代码,天猫倒计时,网页倒计时JavaScript代码
  17. 在UBUNTU 13.1 中使用五笔拼音混合输入法
  18. java模拟魔兽世界武器掉落
  19. w10计算机运行特别卡,Win10电脑运行卡死怎么办?Win10电脑卡死的解决方法
  20. python基础学习task09

热门文章

  1. ubuntu开机自启vnc虚拟显示器并使用向日葵远程连接
  2. Excel闪退问题解决
  3. idea的Database导出导入表操作
  4. 罗技驱动HUB安装,安装不上,一次性解决问题
  5. matlab里点除,MATLAB中点除点除
  6. python爬虫——使用selenium爬取qq群的成员信息(全自动实现自动登陆)
  7. 西南科技大学 SWUST OJ系统942: 逆置顺序表
  8. 下载Google Earth的地图并用ArcMap对其georeferencing
  9. NSGA2算法原理及python实现
  10. 模拟电路——阻容耦合放大电路