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



C++ GUI 绘图控件目录

MFC

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

Qt

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


1.前期准备

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


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

 

添加TeeChart控件,右击控件,选择添加变量,vs会自动给我们引入CTchart1这个类,但是只有这个类,我们是远远不够的,需要添加teechart其他相关的类,添加方法在之前已经讲过,不再重复。

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


1.2. 引入必要的头文件

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

如图进入类向导,选择添加类按钮的下拉菜单,选择类型库中的MFC类

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


选择teechart5即可

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


引入

[cpp]  view plain copy
  1. #include "CSeries.h"   
  2. #include "CAxis.h"  
  3. #include "CAxes.h"  
  4. #include "CLegend.h"  

需要还可以继续在之后引入


--------------------------------------------------------------------------------------------------------------------------------


2. teechart 画图 - 折线图


TeeChart 画图步骤一般是先获得图线序列CSeries,再给Series添加点;添加点可以用函数AddXY,或者AddArray。AddArray要比AddXY的效率高出很多,其比较可见 TeeChart绘图控件 - 之三 - 提高绘图的效率


2.1 清除图形

在画线之前把图形清除一下,否则会覆盖,清除可用CSeries的函数Clear();
但是当添加多个Series后要对所有Series都clear,这是很蛋疼的,因为你有时都不知道有多少个Series,这样可以先获得Series的总数在clear

代码如下

[cpp]  view plain copy
  1. for(long i = 0;i<m_TeeChart.get_SeriesCount();i++)   
  2. {  
  3.      ((CSeries)m_TeeChart.Series(i)).Clear();  
  4. }  

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

[cpp]  view plain copy
  1. void CTChartDlg::ClearAllSeries(void)   
  2. {  
  3.     for(long i = 0;i<m_TeeChart.get_SeriesCount();i++)  
  4.     {  
  5.         ((CSeries)m_TeeChart.Series(i)).Clear();  
  6.     }  
  7. }  

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


2.2 普通连线图

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

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


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


2.2.1 普通线图 - AddXY

下面演示AddXY的方法

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

先看看AddXY

[cpp]  view plain copy
  1. const UINT nDATALENGTH=100;   
  2. double dData[nDATALENGTH];  
  3. for (int i=0;i<nDATALENGTH;i++)  
  4. {  
  5.     dData[i] = 100 * sin((float)i)*cos((float)4*i);  
  6. }  
  7. //ClearAllSeries();  
  8. CSeries lineSeries = (CSeries)m_TeeChart.Series(0);  
  9. lineSeries.Clear();//在最前面加上ClearAllSeries(ClearAllSeries是自己写的函数)就不用了  
  10. for(int i=0;i<nDATALENGTH;i++)  
  11. {  
  12.     lineSeries.AddXY((double)i,dData[i],NULL,0);  
  13. }  

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

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

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

做出来的效果:

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


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

[cpp]  view plain copy
  1. CString str;   
  2. for(int i=0;i<nDATALENGTH;i++)  
  3. {  
  4.     str.Format(_T("点%d"),i);  
  5.     lineSeries.AddXY((double)i,dData[i],str,0);  
  6. }  


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


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

2.2.2 普通线图 - AddArray

 
在数据量特别大时,强烈建议使用AddArray函数
AddArray的函数声明如下
void AddArray(long ArraySize, VARIANT& YArray, VARIANT& XArray);
x,y是两个VARIANT的数据类型,VARIANT有个类型是VT_ARRAY
可以给VARIANT赋一个数组进去
具体操作如下:
方法1:
[cpp]  view plain copy
  1. constUINT nDATALENGTH=100;   
  2. double dData[nDATALENGTH];  
  3.   
  4. for (int i=0;i<nDATALENGTH;i++)  
  5. {  
  6.      dData[i] =100*sin((float)i)*cos((float)4*i);  
  7. }  
  8. //声明如下数据:  
  9. VARIANT vAX,vAY;  
  10. SAFEARRAY* psax;  
  11. SAFEARRAY* psay;  
  12. SAFEARRAYBOUND rgsabound;  
  13. //初始化  
  14. rgsabound.cElements=nDATALENGTH;   
  15. rgsabound.lLbound=0;  
  16. psax=SafeArrayCreate(VT_R8,1,&rgsabound);//分配空间  
  17. psay=SafeArrayCreate(VT_R8,1,&rgsabound);  
  18. vAX.vt=VT_ARRAY|VT_R8;//设置为double型数组,VT_R8就是指double  
  19. vAX.parray=psax;//把内容加入VARIANT中  
  20. vAY.vt=VT_ARRAY|VT_R8;  
  21. vAY.parray=psay;  
  22. //这时VARIANT 就可以加入数据了  
  23. double dtemp;//用来临时存放x坐标   
  24. for(long i=0;i<nDATALENGTH;i++)  
  25. {  
  26.     dtemp = i;  
  27.     SafeArrayPutElement(psax,&i,&dtemp);  
  28.     dtemp = dData[i];  
  29.     SafeArrayPutElement(psay,&i,&dtemp);  
  30.     //更简单写法  
  31.     //SafeArrayPutElement(psay,&i,dData+i);  
  32. }  
  33. //开始画图  
  34. CSeries lineSeries = (CSeries)m_TeeChart.Series(0);   
  35. lineSeries.Clear();  
  36. lineSeries.AddArray(nDATALENGTH,vAY,vAX);  

 
方法2:
这时我看TeeChart官方实例找到的方法,相对简单点
[cpp]  view plain copy
  1. COleSafeArray XValues;      
  2. COleSafeArray YValues;      
  3. DWORD numElements[] = {nDATALENGTH};      
  4. // 创建安全数组     
  5. XValues.Create(VT_R8, 1, numElements);      
  6. YValues.Create(VT_R8, 1, numElements);      
  7. // 初始化   
  8. long i;      
  9. double dval;  
  10. for(i=0; i<nDATALENGTH; i++)   
  11. {         
  12.     dval = i;  
  13.     XValues.PutElement(&i, &dval);  
  14.     dval = dData[i];  
  15.     YValues.PutElement(&i, &dval);  
  16.     //YValues.PutElement(&i, dData+i);  
  17. };  
  18. CSeries lineSeries = (CSeries)m_TeeChart.Series(0);  
  19. lineSeries.Clear();  
  20. lineSeries.AddArray(nDATALENGTH,YValues,XValues);  


 

2.3 去除/显示legend

如果不想要右边那一栏数据显示,可以通过代码去除
CLegend是用来控制这个显示的
 
[cpp]  view plain copy
  1. CLegend legend = (CLegend)m_TeeChart.get_Legend();       
  2. legend.put_Visible(FALSE);  

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

添加单选控件   ,id为IDC_CHECK_ShowLegend,


单击响应
[cpp]  view plain copy
  1. void CTChartDlg::OnBnClickedCheck_ShowLegend()   
  2. {  
  3.     CLegend legend = (CLegend)m_TeeChart.get_Legend();  
  4.     if(BST_CHECKED == ((CButton*)GetDlgItem(IDC_CHECK_ShowLegend))->GetCheck())  
  5.     {  
  6.         legend.put_Visible(TRUE);  
  7.     }  
  8.     else  
  9.     {  
  10.         legend.put_Visible(FALSE);  
  11.     }  
  12. }  

效果:

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


不用代码的话可以通过设置控件属性

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


明显,这没有代码灵活
 

2.4 改变线图颜色

 
默认设置是红,我要设置成其他颜色可以用put_Colour
 
如上代码的lineSeries最后加一个,就会变成RGB(255,0,255)的颜色了
[cpp]  view plain copy
  1. lineSeries.put_Color(RGB(255,0,255));  

效果:

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


3. teechart 画图 -  柱状图

 

3.1  添加柱状图

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


这时会多一个图形

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


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


3.2 AddXY

 
方法和线图没什么区别,直接上码:
 
[cpp]  view plain copy
  1. const UINT nDATALENGTH = 20;   
  2. double dData[nDATALENGTH];  
  3.   
  4. for (int i=0;i<nDATALENGTH;i++)  
  5. {  
  6.     dData[i] = abs(100*sin((float)i));  
  7. }  
  8. //  
  9. ClearAllSeries();  
  10. CSeries barSeries = (CSeries)m_TeeChart.Series(1);  
  11. for(int i=0;i<nDATALENGTH;i++)  
  12. {  
  13.     barSeries.AddXY((double)i,dData[i],NULL,0);  
  14. }  

 
注意不是Series(0)了

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

效果还是很不错的
 
加个abs,好看很多~~

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


3.3 改变柱状图的颜色

 
为啥是黑色的?设置了绿色的,我一开始也以为坑爹的设置没有用,后来研究了一下发现时AddXY的第四个参数起作用的
 
上面的图是这样加的:
[cpp]  view plain copy
  1. barSeries.AddXY((double)i,dData[i],NULL,0);  

第四个参数0就相当于RGB(0,0,0),这第四个参数就是设置颜色的了
 
把程序稍作修改
[cpp]  view plain copy
  1. for(int i=0;i<nDATALENGTH;i++)   
  2. {  
  3.     i%2==0  
  4.         ? barSeries.AddXY((double)i,dData[i],NULL,RGB(255,255,0))  
  5.         : barSeries.AddXY((double)i,dData[i],NULL,RGB(0,255,255));  
  6. }  


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


很漂亮的效果~

3.4 去除/显示 数据标示

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

添加单选控件  IDC_CHECK_Marks

[cpp]  view plain copy
  1. void CTChartDlg::OnBnClickedCheckMarks()   
  2. {  
  3.     CSeries barSeries = (CSeries)m_TeeChart.Series(1);  
  4.     CMarks SeriesMarks = (CMarks)barSeries.get_Marks();  
  5.     if(BST_CHECKED == ((CButton*)GetDlgItem(IDC_CHECK_Marks))->GetCheck())  
  6.     {  
  7.         SeriesMarks.put_Visible(TRUE);  
  8.     }  
  9.     else  
  10.     {  
  11.         SeriesMarks.put_Visible(FALSE);  
  12.     }  
  13. }  

效果:


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


3.5 AddArray 给柱状图添加数据

和line一样
[cpp]  view plain copy
  1. const UINT nDATALENGTH = 20;   
  2.   double dData[nDATALENGTH];  
  3.   
  4.   for (int i=0;i<nDATALENGTH;i++)  
  5.   {  
  6.       dData[i] = abs(100*sin((float)i));  
  7.   }  
  8.   COleSafeArray XValues;      
  9.   COleSafeArray YValues;      
  10.   DWORD numElements[] = {nDATALENGTH};      
  11.   // 创建安全数组     
  12.   XValues.Create(VT_R8, 1, numElements);      
  13.   YValues.Create(VT_R8, 1, numElements);      
  14.   // 初始化   
  15.   long i;      
  16.   double dval;  
  17.   for(i=0; i<nDATALENGTH; i++)   
  18.   {         
  19.       dval = i;  
  20.       XValues.PutElement(&i, &dval);  
  21.       dval = dData[i];  
  22.       YValues.PutElement(&i, &dval);  
  23.       //YValues.PutElement(&i, dData+i);  
  24.   };  
  25.   //  
  26.   ClearAllSeries();  
  27.   CSeries lineSeries = (CSeries)m_TeeChart.Series(1);  
  28.   lineSeries.AddArray(nDATALENGTH,YValues,XValues);  


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

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


想改颜色!没问题,还是用put_Color
 
[cpp]  view plain copy
  1. barSeries.put_Color(RGB(255,0,0));  


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


C++ GUI 绘图控件目录

MFC

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

Qt

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

C++ GUI 绘图控件目录

MFC

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

Qt

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


1.前期准备

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


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

 

添加TeeChart控件,右击控件,选择添加变量,vs会自动给我们引入CTchart1这个类,但是只有这个类,我们是远远不够的,需要添加teechart其他相关的类,添加方法在之前已经讲过,不再重复。

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


1.2. 引入必要的头文件

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

如图进入类向导,选择添加类按钮的下拉菜单,选择类型库中的MFC类

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


选择teechart5即可

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


引入

[cpp]  view plain copy
  1. #include "CSeries.h"   
  2. #include "CAxis.h"  
  3. #include "CAxes.h"  
  4. #include "CLegend.h"  

需要还可以继续在之后引入


--------------------------------------------------------------------------------------------------------------------------------


2. teechart 画图 - 折线图


TeeChart 画图步骤一般是先获得图线序列CSeries,再给Series添加点;添加点可以用函数AddXY,或者AddArray。AddArray要比AddXY的效率高出很多,其比较可见 TeeChart绘图控件 - 之三 - 提高绘图的效率


2.1 清除图形

在画线之前把图形清除一下,否则会覆盖,清除可用CSeries的函数Clear();
但是当添加多个Series后要对所有Series都clear,这是很蛋疼的,因为你有时都不知道有多少个Series,这样可以先获得Series的总数在clear

代码如下

[cpp]  view plain copy
  1. for(long i = 0;i<m_TeeChart.get_SeriesCount();i++)   
  2. {  
  3.      ((CSeries)m_TeeChart.Series(i)).Clear();  
  4. }  

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

[cpp]  view plain copy
  1. void CTChartDlg::ClearAllSeries(void)   
  2. {  
  3.     for(long i = 0;i<m_TeeChart.get_SeriesCount();i++)  
  4.     {  
  5.         ((CSeries)m_TeeChart.Series(i)).Clear();  
  6.     }  
  7. }  

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


2.2 普通连线图

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

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


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


2.2.1 普通线图 - AddXY

下面演示AddXY的方法

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

先看看AddXY

[cpp]  view plain copy
  1. const UINT nDATALENGTH=100;   
  2. double dData[nDATALENGTH];  
  3. for (int i=0;i<nDATALENGTH;i++)  
  4. {  
  5.     dData[i] = 100 * sin((float)i)*cos((float)4*i);  
  6. }  
  7. //ClearAllSeries();  
  8. CSeries lineSeries = (CSeries)m_TeeChart.Series(0);  
  9. lineSeries.Clear();//在最前面加上ClearAllSeries(ClearAllSeries是自己写的函数)就不用了  
  10. for(int i=0;i<nDATALENGTH;i++)  
  11. {  
  12.     lineSeries.AddXY((double)i,dData[i],NULL,0);  
  13. }  

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

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

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

做出来的效果:

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


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

[cpp]  view plain copy
  1. CString str;   
  2. for(int i=0;i<nDATALENGTH;i++)  
  3. {  
  4.     str.Format(_T("点%d"),i);  
  5.     lineSeries.AddXY((double)i,dData[i],str,0);  
  6. }  


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


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

2.2.2 普通线图 - AddArray

 
在数据量特别大时,强烈建议使用AddArray函数
AddArray的函数声明如下
void AddArray(long ArraySize, VARIANT& YArray, VARIANT& XArray);
x,y是两个VARIANT的数据类型,VARIANT有个类型是VT_ARRAY
可以给VARIANT赋一个数组进去
具体操作如下:
方法1:
[cpp]  view plain copy
  1. constUINT nDATALENGTH=100;   
  2. double dData[nDATALENGTH];  
  3.   
  4. for (int i=0;i<nDATALENGTH;i++)  
  5. {  
  6.      dData[i] =100*sin((float)i)*cos((float)4*i);  
  7. }  
  8. //声明如下数据:  
  9. VARIANT vAX,vAY;  
  10. SAFEARRAY* psax;  
  11. SAFEARRAY* psay;  
  12. SAFEARRAYBOUND rgsabound;  
  13. //初始化  
  14. rgsabound.cElements=nDATALENGTH;   
  15. rgsabound.lLbound=0;  
  16. psax=SafeArrayCreate(VT_R8,1,&rgsabound);//分配空间  
  17. psay=SafeArrayCreate(VT_R8,1,&rgsabound);  
  18. vAX.vt=VT_ARRAY|VT_R8;//设置为double型数组,VT_R8就是指double  
  19. vAX.parray=psax;//把内容加入VARIANT中  
  20. vAY.vt=VT_ARRAY|VT_R8;  
  21. vAY.parray=psay;  
  22. //这时VARIANT 就可以加入数据了  
  23. double dtemp;//用来临时存放x坐标   
  24. for(long i=0;i<nDATALENGTH;i++)  
  25. {  
  26.     dtemp = i;  
  27.     SafeArrayPutElement(psax,&i,&dtemp);  
  28.     dtemp = dData[i];  
  29.     SafeArrayPutElement(psay,&i,&dtemp);  
  30.     //更简单写法  
  31.     //SafeArrayPutElement(psay,&i,dData+i);  
  32. }  
  33. //开始画图  
  34. CSeries lineSeries = (CSeries)m_TeeChart.Series(0);   
  35. lineSeries.Clear();  
  36. lineSeries.AddArray(nDATALENGTH,vAY,vAX);  

 
方法2:
这时我看TeeChart官方实例找到的方法,相对简单点
[cpp]  view plain copy
  1. COleSafeArray XValues;      
  2. COleSafeArray YValues;      
  3. DWORD numElements[] = {nDATALENGTH};      
  4. // 创建安全数组     
  5. XValues.Create(VT_R8, 1, numElements);      
  6. YValues.Create(VT_R8, 1, numElements);      
  7. // 初始化   
  8. long i;      
  9. double dval;  
  10. for(i=0; i<nDATALENGTH; i++)   
  11. {         
  12.     dval = i;  
  13.     XValues.PutElement(&i, &dval);  
  14.     dval = dData[i];  
  15.     YValues.PutElement(&i, &dval);  
  16.     //YValues.PutElement(&i, dData+i);  
  17. };  
  18. CSeries lineSeries = (CSeries)m_TeeChart.Series(0);  
  19. lineSeries.Clear();  
  20. lineSeries.AddArray(nDATALENGTH,YValues,XValues);  


 

2.3 去除/显示legend

如果不想要右边那一栏数据显示,可以通过代码去除
CLegend是用来控制这个显示的
 
[cpp]  view plain copy
  1. CLegend legend = (CLegend)m_TeeChart.get_Legend();       
  2. legend.put_Visible(FALSE);  

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

添加单选控件   ,id为IDC_CHECK_ShowLegend,


单击响应
[cpp]  view plain copy
  1. void CTChartDlg::OnBnClickedCheck_ShowLegend()   
  2. {  
  3.     CLegend legend = (CLegend)m_TeeChart.get_Legend();  
  4.     if(BST_CHECKED == ((CButton*)GetDlgItem(IDC_CHECK_ShowLegend))->GetCheck())  
  5.     {  
  6.         legend.put_Visible(TRUE);  
  7.     }  
  8.     else  
  9.     {  
  10.         legend.put_Visible(FALSE);  
  11.     }  
  12. }  

效果:

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


不用代码的话可以通过设置控件属性

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


明显,这没有代码灵活
 

2.4 改变线图颜色

 
默认设置是红,我要设置成其他颜色可以用put_Colour
 
如上代码的lineSeries最后加一个,就会变成RGB(255,0,255)的颜色了
[cpp]  view plain copy
  1. lineSeries.put_Color(RGB(255,0,255));  

效果:

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


3. teechart 画图 -  柱状图

 

3.1  添加柱状图

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


这时会多一个图形

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


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


3.2 AddXY

 
方法和线图没什么区别,直接上码:
 
[cpp]  view plain copy
  1. const UINT nDATALENGTH = 20;   
  2. double dData[nDATALENGTH];  
  3.   
  4. for (int i=0;i<nDATALENGTH;i++)  
  5. {  
  6.     dData[i] = abs(100*sin((float)i));  
  7. }  
  8. //  
  9. ClearAllSeries();  
  10. CSeries barSeries = (CSeries)m_TeeChart.Series(1);  
  11. for(int i=0;i<nDATALENGTH;i++)  
  12. {  
  13.     barSeries.AddXY((double)i,dData[i],NULL,0);  
  14. }  

 
注意不是Series(0)了

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

效果还是很不错的
 
加个abs,好看很多~~

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


3.3 改变柱状图的颜色

 
为啥是黑色的?设置了绿色的,我一开始也以为坑爹的设置没有用,后来研究了一下发现时AddXY的第四个参数起作用的
 
上面的图是这样加的:
[cpp]  view plain copy
  1. barSeries.AddXY((double)i,dData[i],NULL,0);  

第四个参数0就相当于RGB(0,0,0),这第四个参数就是设置颜色的了
 
把程序稍作修改
[cpp]  view plain copy
  1. for(int i=0;i<nDATALENGTH;i++)   
  2. {  
  3.     i%2==0  
  4.         ? barSeries.AddXY((double)i,dData[i],NULL,RGB(255,255,0))  
  5.         : barSeries.AddXY((double)i,dData[i],NULL,RGB(0,255,255));  
  6. }  


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


很漂亮的效果~

3.4 去除/显示 数据标示

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

添加单选控件  IDC_CHECK_Marks

[cpp]  view plain copy
  1. void CTChartDlg::OnBnClickedCheckMarks()   
  2. {  
  3.     CSeries barSeries = (CSeries)m_TeeChart.Series(1);  
  4.     CMarks SeriesMarks = (CMarks)barSeries.get_Marks();  
  5.     if(BST_CHECKED == ((CButton*)GetDlgItem(IDC_CHECK_Marks))->GetCheck())  
  6.     {  
  7.         SeriesMarks.put_Visible(TRUE);  
  8.     }  
  9.     else  
  10.     {  
  11.         SeriesMarks.put_Visible(FALSE);  
  12.     }  
  13. }  

效果:


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


3.5 AddArray 给柱状图添加数据

和line一样
[cpp]  view plain copy
  1. const UINT nDATALENGTH = 20;   
  2.   double dData[nDATALENGTH];  
  3.   
  4.   for (int i=0;i<nDATALENGTH;i++)  
  5.   {  
  6.       dData[i] = abs(100*sin((float)i));  
  7.   }  
  8.   COleSafeArray XValues;      
  9.   COleSafeArray YValues;      
  10.   DWORD numElements[] = {nDATALENGTH};      
  11.   // 创建安全数组     
  12.   XValues.Create(VT_R8, 1, numElements);      
  13.   YValues.Create(VT_R8, 1, numElements);      
  14.   // 初始化   
  15.   long i;      
  16.   double dval;  
  17.   for(i=0; i<nDATALENGTH; i++)   
  18.   {         
  19.       dval = i;  
  20.       XValues.PutElement(&i, &dval);  
  21.       dval = dData[i];  
  22.       YValues.PutElement(&i, &dval);  
  23.       //YValues.PutElement(&i, dData+i);  
  24.   };  
  25.   //  
  26.   ClearAllSeries();  
  27.   CSeries lineSeries = (CSeries)m_TeeChart.Series(1);  
  28.   lineSeries.AddArray(nDATALENGTH,YValues,XValues);  


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

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


想改颜色!没问题,还是用put_Color
 
[cpp]  view plain copy
  1. barSeries.put_Color(RGB(255,0,0));  


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


C++ GUI 绘图控件目录

MFC

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

Qt

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

你可能感兴趣的:(VS2010 使用TeeChart绘图控件 - 之二 - 绘制图形(折线图,柱状图))