vs2010画图控件_VS2010 使用TeeChart绘图控件
一、TeeChart 控件导入VS2010
vs2010的用法和vc6有很大的不同,特别是在一些函数调用那里,当然。控件导入也是很不一样的,安装好控件后就可以在工程里加入teechart控件了:
1、添加Teechart控件
(1)右键插入Teechart控件
新建一个对话框工程,在对话框上点击鼠标右键,弹出的菜单里选择“插入ActiveX控件” 然后弹出的对话框里选择TeeChart控件 这时对话框就有TeeChart控件了
(2)工具库添加Teechart控件
vs2010对话框设置的工具栏上就有许多控件了,若想把我们常用的控件也加到工具栏上以后使用就很方便了,下面说的这种方法就是把控件加入工具栏里,方便以后的调用。
在工具栏的空白处点击右键,选择添加选项卡 这时vs就会新建一个选项卡,自己可以定义一个名称,这里命名为绘图控件 为选项卡添加项:在新建的选项卡的空白处点击右键,选择“选择项”,由于控件比较多,会耗费一定的时间打开这个选择项,别以为死机了,耐心等个几十秒吧。 在打开的对话框中选择选择com标签,选择teechart控件 这样teechart控件就会在你的工具栏新加的选项里了,以后都会存在(我添加TeeChat的同时还把其他的一些控件添加进去了)
2、控件属性设置
双击控件进行相关设置,这里添加一个快速线图-Fast Line 若数据量特别大,可以在Series标签里的Format的Draw all选项去掉 在Chart标签里还可以设置坐标轴的名称属性等,这里先不详细讲述属性的设置。
3、为控件添加类
vs2010与vc6不一样,vs2010的控件对应的类添加相对比vc6麻烦。这里就对刚刚加入的TeeChart控件加入相关的类。
(1)添加TypeLib的mfc类
选择vs菜单“项目”-“添加类”(注意这时类视图树形控件选中最顶端的父节点) 添加TypeLib的mfc类 在可用的类型库里选择teechart5 在接口里就有TeeChart对应的所有类了,这里TChart是必须的接口,其他的可以根据需要添加 点击完成就把CTChart这个类添加进工程里了
其实第2步可以选择ActiveX控件的Mfc类,操作方法雷同,不过这时是只列出对应的接口
4、TeeChart控件和对象关联
(1)为控件关联对象
在控件上点击右键,选择添加变量,即可为控件关联对象
(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就可正常使用了
二、绘制图形
1、给控件添加变量m_TeeChart
添加TeeChart控件,右击控件,选择添加变量,vs会自动给我们引入CTchart1这个类,但是只有这个类,我们是远远不够的,需要添加teechart其他相关的类,添加方法在之前已经讲过,不再重复。
2、引入必要的头文件
其实之前的方法比较麻烦,更简单就是通过类向导,导入类型库的类。
如图进入类向导,选择添加类按钮的下拉菜单,选择类型库中的MFC类 选择teechart5即可 暂时引入,需要还可以继续在之后引入。
#include "CSeries.h"
#include "CAxis.h"
#include "CAxes.h"
#include "CLegend.h"
3、折线图
TeeChart 画图步骤一般是先获得图线序列CSeries,再给Series添加点;添加点可以用函数AddXY,或者AddArray。AddArray要比AddXY的效率高出很多。
(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)普通连线图
好了现在开始说说怎么画折线图: 一般我们画的图都属于这种,就是把点连接起来,选择fast line 的 Normal,就是普通连线图。在需要画图的地方先要获得曲线序列Series,然后通过画图函数AddXY,或者AddArray作图。
a、普通线图 - 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);
}
第四个参数在线图里不起作用,在柱状图里可以设置颜色。
b、普通线图 - AddArray
在数据量特别大时,强烈建议使用AddArray函数,AddArray的函数声明如下:
void AddArray(long ArraySize, VARIANT& YArray, VARIANT& XArray);
x,y是两个VARIANT的数据类型,VARIANT有个类型是VT_ARRAY,可以给VARIANT赋一个数组进去,具体操作如下:
方法一:
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);
方法二(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);
(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);
}
}
效果:
不用代码的话可以通过设置控件属性,明显,这没有代码灵活:
(4)颜色控制
默认设置是红,我要设置成其他颜色可以用put_Colour,如上代码的lineSeries最后加一个,就会变成RGB(255,0,255)的颜色了:
lineSeries.put_Color(RGB(255,0,255));
效果:
4、柱状图
(1)添加图形
添加柱状图:
这时会多一个图形(注意这里默认是绿色的,等下会发现画出来的不一样):
(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)颜色控制
为啥是黑色的?设置了绿色的,我一开始也以为设置没有用,后来研究了一下发现时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));
}
(4)数据标示
去掉上面的标示,那个标示是用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);
}
}
(5)AddArray 给柱状图添加数据
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是个很强大的控件,其绘图能力之强,其他控件难以比拟,但是有个问题就是他的绘图速度,其实TeeChart绘图速度还是很快的,只是大家一直都没正确运用其功能所以导致绘图速度慢的假象。下面说说影响绘图速度的两个主要因素:
1、数特别多不需要绘出全部点——性能提升不大
TeeChart绘图控件可以设置只绘出部分点。设置方法如图:
这个选项能一定程度的提升画图速度。提升多少,可看看如下实例:163840个随机点,取消Draw All时效果,使用AddXY函数,耗时1092毫秒。
163840个随机点,取消Draw All时效果,使用AddXY函数,耗时1217毫秒。
可见这个效果并不明显,但是显示效果却很明显
2、通过画图函数来改变画图速度
TeeChart的AddXY函数时画图最慢的函数,但是却好多人使用,可能是简单的原因吧,我专门做了一个程序来测试AddXY和AddArray函数的效率,发现效率几乎差30倍。
(1)AddXY函数:
AddXY 函数每次调用都要刷新,所以画图速率相当低。如上图所示的界面画图(AddXY)按钮实现如下,randf是一个产生随机数的函数实现见源文件,m_nPointNum是何文本编辑框关联的int型数据,IDC_STATIC_T是文本标签的ID:
void CTeeChartDlg::OnBnClickeondraw()
{
CSeries ChartSpeed = (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;
}
//由于需要计算时间,画图就不在第一个for循环里实现了
dwTimeS = GetTickCount();
ChartSpeed.Clear();
for(i=0;i<(unsigned)m_nPointNum;i++)
{
ChartSpeed.AddXY(pDataX[i],pDataY[i],NULL,0);
}
dwTimeE = GetTickCount();
dwTimeE -= dwTimeS;
if (pDataX)
{
delete[] pDataX;
}
if (pDataY)
{
delete[] pDataY;
}
str.Format(_T("耗时:%d ms"),dwTimeE);
SetDlgItemText(IDC_STATIC_T,str);
}
加了两个计时,专门计算画图时间:
for(i=0;i<(unsigned)m_nPointNum;i++)
{
ChartSpeed.AddXY(pDataX[i],pDataY[i],NULL,0);
}
程序运行时间如图:1638400个点居然花了差不多6秒:
(2)AddArray函数-真正实现快速画图函数
为了验证AddArray的快速性,添加了一个按钮:按钮依然实现画图,不过是用AddArray函数,利用COleSafeArray 实现数据存储,实现代码如下:
void CTeeChartDlg::OnBnClickeondraw2()
{
CSeries ChartSpeed = (CSeries)m_Chart.Series(0);
UpdateData(TRUE);
if (m_nPointNum<=0)
{
MessageBox(_T("数据点数不能小于0"));
return;
}
DWORD dwTimeS,dwTimeE;
CString str(_T(""));
long i(0);
double val;
COleSafeArray XValues;
COleSafeArray YValues;
DWORD pNumElements[] = {m_nPointNum};
XValues.Create(VT_R8, 1, pNumElements);
YValues.Create(VT_R8, 1, pNumElements);
for(i=0; i<m_nPointNum; i++)
{
val = i;
XValues.PutElement(&i, &val);
val = randf(-20,20);
YValues.PutElement(&i, &val);
};
//由于需要计算时间,画图就不在第一个for循环里实现了
dwTimeS = GetTickCount();
ChartSpeed.Clear();
ChartSpeed.AddArray(m_nPointNum,YValues,XValues);
dwTimeE = GetTickCount();
dwTimeE -= dwTimeS;
str.Format(_T("耗时:%d ms"),dwTimeE);
SetDlgItemText(IDC_STATIC_T,str);
}
快30倍,1638400个点瞬间完成:
一般我们的数据经常是用double数组保存的,很少用COleSafeArray所以,为了方便,可以写一个函数方便画图如下:
void DrawLine(double* pX,double* pY,long nNum)
{
COleSafeArray XValues;
COleSafeArray YValues;
long i(0);
DWORD wLength = nNum;
XValues.Create(VT_R8, 1, &wLength);
YValues.Create(VT_R8, 1, &wLength);
for(i=0; i<nNum; i++)
{
XValues.PutElement(&i, pX+i);
YValues.PutElement(&i, pY+i);
}
CSeries Chart = (CSeries)m_Chart.Series(0);
Chart.Clear();
Chart.AddArray(nNum,YValues,XValues);
}
调用时只要把数组的首地址和长度传进去就行了。
VS2010 使用TeeChart绘图控件——控件和类的导入 VS2010 使用TeeChart绘图控件——绘制图形(折线图,柱状图) 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其他相关的类,添加方法在之前已经讲过,不再重复。
1.2. 引入必要的头文件
其实之前的方法比较麻烦,更简单就是通过类向导,导入类型库的类
如图进入类向导,选择添加类按钮的下拉菜单,选择类型库中的MFC类
选择teechart5即可
引入
[cpp]?
view plain
copy
#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
代码如下
[cpp]?
view plain
copy
for(long?i?=?0;i 通过CTchart 的 get_SeriesCount函数获得所有图像序列,再全部清除,这个函数经常用到,可用定义为类成员函数,这里是个对话框CTChartDlg [cpp]? view plain copy void?CTChartDlg::ClearAllSeries(void)??? {?? ????for(long?i?=?0;i 好了现在开始说说怎么画折线图 2.2 普通连线图 一般我们画的图都属于这种,就是把点连接起来,选择fast line 的 Normal,就是普通连线图 在需要画图的地方先要获得曲线序列Series,然后通过画图函数AddXY,或者AddArray作图。 2.2.1 普通线图 - AddXY 下面演示AddXY的方法 AddXY就是一个一个加入点,在点数不多,且需要动态显示的时候是不错的选择。点数多的情况下嘛,那就还是用AddArray了 先看看AddXY [cpp]? view plain copy const?UINT?nDATALENGTH=100;??? double?dData[nDATALENGTH];?? for?(int?i=0;i 由于在TeeChart里,只加了一个FastLine,所以Series(0)就算Fast Line,代码首先获得图像序列m_TeeChart.Series(0); 然后再调用这个序列来作图,作图前先清空图像,用ClearAllSeries()也可以 然后就是一个点一个点的往里加了 做出来的效果: AddXY的第一个参数是x点坐标,第二个是y点坐标,第三个参数是为了使x坐标特殊显示,这是会替换掉x坐标的显示内容,如我想显示“点xx“可以这样 [cpp]? view plain copy CString?str;??? for(int?i=0;i ? 第四个参数在线图里不起作用,在柱状图里可以设置颜色 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 constUINT?nDATALENGTH=100;??? double?dData[nDATALENGTH];?? ?? for?(int?i=0;i ? 方法2: 这时我看TeeChart官方实例找到的方法,相对简单点 [cpp]? view plain copy 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 ? 2.3 去除/显示legend 如果不想要右边那一栏数据显示,可以通过代码去除 CLegend是用来控制这个显示的 ? [cpp]? view plain copy CLegend?legend?=?(CLegend)m_TeeChart.get_Legend();??????? legend.put_Visible(FALSE);?? ? 可以用一个check控件控制器显示状态 添加单选控件?? ,id为IDC_CHECK_ShowLegend, 单击响应 [cpp]? view plain copy 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)的颜色了 [cpp]? view plain copy lineSeries.put_Color(RGB(255,0,255));?? 效果: 3. teechart 画图 - ?柱状图 ? 3.1 ?添加柱状图 这时会多一个图形 注意这里默认是绿色的,等下会发现画出来的不一样 3.2 AddXY ? 方法和线图没什么区别,直接上码: ? [cpp]? view plain copy const?UINT?nDATALENGTH?=?20;??? double?dData[nDATALENGTH];?? ?? for?(int?i=0;i ? 注意不是Series(0)了 效果还是很不错的 ? 加个abs,好看很多~~ 3.3 改变柱状图的颜色 ? 为啥是黑色的?设置了绿色的,我一开始也以为坑爹的设置没有用,后来研究了一下发现时AddXY的第四个参数起作用的 ? 上面的图是这样加的: [cpp]? view plain copy barSeries.AddXY((double)i,dData[i],NULL,0);?? 第四个参数0就相当于RGB(0,0,0),这第四个参数就是设置颜色的了 ? 把程序稍作修改 [cpp]? view plain copy for(int?i=0;i 很漂亮的效果~ 3.4 去除/显示 数据标示 ? 好吧又遇到问题了,去掉上面的标示 ok,那个标示是用CMarks管理的,加入这个类就行了,用类向导,加入CMarks #include "CMarks.h" 添加单选控件??IDC_CHECK_Marks [cpp]? view plain copy 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一样 [cpp]? view plain copy const?UINT?nDATALENGTH?=?20;??? ??double?dData[nDATALENGTH];?? ?? ??for?(int?i=0;i ? 这时出现的图像就是默认的颜色了 想改颜色!没问题,还是用put_Color ? [cpp]? view plain copy barSeries.put_Color(RGB(255,0,0));?? 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其他相关的类,添加方法在之前已经讲过,不再重复。 1.2. 引入必要的头文件 其实之前的方法比较麻烦,更简单就是通过类向导,导入类型库的类 如图进入类向导,选择添加类按钮的下拉菜单,选择类型库中的MFC类 选择teechart5即可 引入 [cpp]? view plain copy #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 代码如下 [cpp]? view plain copy for(long?i?=?0;i 通过CTchart 的 get_SeriesCount函数获得所有图像序列,再全部清除,这个函数经常用到,可用定义为类成员函数,这里是个对话框CTChartDlg [cpp]? view plain copy void?CTChartDlg::ClearAllSeries(void)??? {?? ????for(long?i?=?0;i 好了现在开始说说怎么画折线图 2.2 普通连线图 一般我们画的图都属于这种,就是把点连接起来,选择fast line 的 Normal,就是普通连线图 在需要画图的地方先要获得曲线序列Series,然后通过画图函数AddXY,或者AddArray作图。 2.2.1 普通线图 - AddXY 下面演示AddXY的方法 AddXY就是一个一个加入点,在点数不多,且需要动态显示的时候是不错的选择。点数多的情况下嘛,那就还是用AddArray了 先看看AddXY [cpp]? view plain copy const?UINT?nDATALENGTH=100;??? double?dData[nDATALENGTH];?? for?(int?i=0;i 由于在TeeChart里,只加了一个FastLine,所以Series(0)就算Fast Line,代码首先获得图像序列m_TeeChart.Series(0); 然后再调用这个序列来作图,作图前先清空图像,用ClearAllSeries()也可以 然后就是一个点一个点的往里加了 做出来的效果: AddXY的第一个参数是x点坐标,第二个是y点坐标,第三个参数是为了使x坐标特殊显示,这是会替换掉x坐标的显示内容,如我想显示“点xx“可以这样 [cpp]? view plain copy CString?str;??? for(int?i=0;i ? 第四个参数在线图里不起作用,在柱状图里可以设置颜色 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 constUINT?nDATALENGTH=100;??? double?dData[nDATALENGTH];?? ?? for?(int?i=0;i ? 方法2: 这时我看TeeChart官方实例找到的方法,相对简单点 [cpp]? view plain copy 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 ? 2.3 去除/显示legend 如果不想要右边那一栏数据显示,可以通过代码去除 CLegend是用来控制这个显示的 ? [cpp]? view plain copy CLegend?legend?=?(CLegend)m_TeeChart.get_Legend();??????? legend.put_Visible(FALSE);?? ? 可以用一个check控件控制器显示状态 添加单选控件?? ,id为IDC_CHECK_ShowLegend, 单击响应 [cpp]? view plain copy 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)的颜色了 [cpp]? view plain copy lineSeries.put_Color(RGB(255,0,255));?? 效果: 3. teechart 画图 - ?柱状图 ? 3.1 ?添加柱状图 这时会多一个图形 注意这里默认是绿色的,等下会发现画出来的不一样 3.2 AddXY ? 方法和线图没什么区别,直接上码: ? [cpp]? view plain copy const?UINT?nDATALENGTH?=?20;??? double?dData[nDATALENGTH];?? ?? for?(int?i=0;i ? 注意不是Series(0)了 效果还是很不错的 ? 加个abs,好看很多~~ 3.3 改变柱状图的颜色 ? 为啥是黑色的?设置了绿色的,我一开始也以为坑爹的设置没有用,后来研究了一下发现时AddXY的第四个参数起作用的 ? 上面的图是这样加的: [cpp]? view plain copy barSeries.AddXY((double)i,dData[i],NULL,0);?? 第四个参数0就相当于RGB(0,0,0),这第四个参数就是设置颜色的了 ? 把程序稍作修改 [cpp]? view plain copy for(int?i=0;i 很漂亮的效果~ 3.4 去除/显示 数据标示 ? 好吧又遇到问题了,去掉上面的标示 ok,那个标示是用CMarks管理的,加入这个类就行了,用类向导,加入CMarks #include "CMarks.h" 添加单选控件??IDC_CHECK_Marks [cpp]? view plain copy 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一样 [cpp]? view plain copy const?UINT?nDATALENGTH?=?20;??? ??double?dData[nDATALENGTH];?? ?? ??for?(int?i=0;i ? 这时出现的图像就是默认的颜色了 想改颜色!没问题,还是用put_Color ? [cpp]? view plain copy barSeries.put_Color(RGB(255,0,0));?? 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其他相关的类,添加方法在之前已经讲过,不再重复。 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 普通连线图 一般我们画的图都属于这种,就是把点连接起来,选择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 ++) ????{ ????????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 ++) ????{ ????????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 ? 第四个参数在线图里不起作用,在柱状图里可以设置颜色 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 ++)? ????{??????? ????????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 ++) ????{ ????????dData[i]? =?abs( 100 *sin(( float)i)); ????} ???? // ????ClearAllSeries(); ????CSeries barSeries? =?(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()? { ????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 ++) ????{ ????????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 ++)? ????{??????? ????????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));
相关文章
- 10-06 对标大厂,微服务网关应该这样设计!
- 10-06 对标大厂,微服务网关应该这样设计!
- 10-06 摆脱恼人的 NullPointerExceptio
- 10-06 2.7k star,最强大的开源支付系统,马上就可
- 10-06 2.7k star,最强大的开源支付系统,马上就可
- 10-06 基于标签的时间跟踪工具 Traggo
- 10-06 面试官问我,try catch 应该放在 for
- 10-06 面试官问我try catch应该在for循环里面还
- 10-06 RocketMQ源码分析监控指标分析
- 10-06 《硬盘磁头修复》:让您的数据恢复如初! (硬盘磁头
- 10-06 教你如何在电脑店恢复丢失的U盘数据(电脑店U盘数据
- 10-06 如果手机上存储的数据被破坏了怎么办? (手机数据分
- 10-06 九月开学季新教师亮相班美丽句子(九月开学季美丽句子
- 10-06 UiPath 在 3B 轮 C 轮融资中获得 2.
- 10-06 什么是长焦镜头,什么是广角镜头(什么是长焦镜头)
- 10-06 vs2010对应msdn下载_如何下载安装Visu
- 10-06 stm32芯片焊接方向(stm32芯片焊接教程)
- 10-06 如何画lm324原理图(lm324原理图绘制步骤)
- 10-06 郭明錤:预计歌尔将恢复苹果AirPods Pro
- 10-06 小米海外首发5G CPE Pro:采用高通CPU,
- 最近发表