当前位置:首页 > 芯闻号 > 充电吧
[导读]C++ GUI 绘图控件目录MFCVS2010 使用TeeChart绘图控件 - 之一 - 控件和类的导入VS2010 使用TeeChart绘图控件 - 之二 - 绘制图形(折线图,柱状图)TeeCh



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


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


Qt


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


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭