工学
RSS阅读器
 您现在的位置: 在职教育交流中心 >> 论文写作 >> 计算机 >> 计算机应用 >> 论文正文

基于Mschart的数据库图表应用编程

作者:佚名    论文来源:在职教育交流中心    点击数:    更新时间:2007-5-21

摘要:本文较详尽地介绍了在Windows系统中,如何使用MSChart 图表控件来实现数据库的图表显示,并给出了编程要点和相关的VC++6.0代码。

关键词:Windows 数据库图表 MsChart VC++6.0

 

  图表由于其直观明了的特性,在实际应用中十分很广泛。我们常常希望数据能通过图表来显示其特性。例如在Delphi和C++Builder编程中,我们可以很方便地实现数据图表。MsChart(6.0或5.0版)是Windows系统中Visual studio自带的一个ACTIVEX控件,它功能强大,应用广泛,具有以下特点:

· 支持随机数据和随机数组,动态显示。

· 支持所有主要的图表类型。

· 支持三维显示。

MsChart具有45个属性,9方法49 事件,可灵活编程,可实现各类表的显示。

1 插入MsChart 控件窗口

1 MsChart 应用编程

首先插入MsChart 控件,如图1

1.1 坐标系属性的设置

a)纵轴初始化属性

Mschart 默认支持自动标准,将自动调整,可以缺省设置。

#include "mschart.h" //添加相关的头文件

#include "vcplot.h"

#include "vcaxis.h"

#include "vcvaluescale.h"

CMSChart m_Chart;//m_Chart 为图表变量

VARIANT var;

m_Chart.GetPlot().GetAxis(1,var)//获取纵轴

//设置是否支持自动标准;控件默认支持自动标准。

m_Chart.GetPlot().GetAxis().GetValuesScale().SetAuto(FALSE);

//设置最大刻度为M;

m_Chart.GetPlot().GetAxis().GetValuesScale().SetMaximum(M);

//设置最小刻度为m;

m_Chart.GetPlot().GetAxis().GetValuesScale().SetMinimum(m);

//设置轴的等分数D;

m_Chart.GetPlot().GetAxis().GetValuesScale().SetMajorDivision(D);

//设置每等分的刻度线数n;

m_Chart.GetPlot().GetAxis().GetValuesScale().SetMinorDivision(n);

b)横轴初始化属性

VARIANT var;

m_Chart.GetPlot().GetAxis(0,var)//获取横轴

其他属性设置跟纵轴相同。

1.2 数据显示

a)设置标题栏和标签

m_Chart.SetTitleText(“标题”);//设置标题栏

m_Chart.SetRowLabel((“第I行”);//设置第i行标签

m_Chart.SetColumnLabel((“第j列”);//设置第j列标签

b)行列的显示布局

MSChart的行列显示布局有其自身的特点:下面显示是一个行列4×3,即(四行,三列)的布局示意图(图2所示)。

图2 数据显示布局示意图

m_Chart.SetRowCount(4); //行数为4

m_Chart.SetColumnCount(3); //列数为3

c)行列操作

// 操作行列<i, j>i行、第j

m_Chart.SetRow(i);// i

m_Chart.SetColumn(j);//j

m_Chart.SetRowLabel((“第i行”);//设置第i行标签

CString str”90.5”;

m_Chart.SetData((LPCTSTR(str)); //设置行列<i j>的显示数据

m_Chart.Refresh();//刷新视图

d)显示方式

获取当前的显示方式:

long nType m_Chart.GetChartType()

设置显示方式:

m_Chart.SetChartType(0);//3D(三维) 显示

m_Chart.SetChartType(1);//2D(二维) 显示

m_Chart.Refresh();

其它常用组合方式为:

m_Chart.SetChartType(1|0) //2D(),

m_Chart.SetChartType(0|0) //3D()

m_Chart.SetChartType(1|2) //2D线条型

m_Chart.SetChartType(0|2) //3D线条型

m_Chart.SetChartType(1|4) //2D区域型

m_Chart.SetChartType(0|4) //3D区域型

m_Chart.SetChartType(1|6) //2D阶梯型

m_Chart.SetChartType(0|6) //3D阶梯型

m_Chart.SetChartType(1|8) //2D()合型

m_Chart.SetChartType(0|8) //3D()合型

另外,2D方式中,还有两类:饼型和XY

m_Chart.SetChartType(14) //2D 饼型

m_Chart.SetChartType(16) //2DXY

e)其他

其他属性,比如设置字体,颜色,对齐方式等

图3 数据控件界面示意图

2 程序示例

(1) VC6.0中建一基于支持数据库的单文档(MFC)的工程项目。其中数据库为ACCESS,包括四个字段(即四个科目成绩字段):ChineseMathEnglishComputer

(2) 添加相关变量和控件,如图3

3 程序演示

演示结果如图4和图5

 

图4

图5

【声明】本网站刊载的资料由网友提供分享 资料内容纯属作者个人观点,不表示本网同意其说法或描述,仅为提供更多信息,也不构成任何建议。网友转载请注明原作者姓名及出处。如有侵犯到您的版权,请与我们联系
·基于Mschart的数据库图表应用编程· 【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口】    
    
  • 上一篇论文:
  •  
        
  • 下一篇论文:
  •  
    相关论文
    基于动态网页——ASP的WEB数据库开发
    基于ASP组件技术的在线教育系统的设计与开发…
    基于ASP组件技术的在线教育系统的设计与开发…
    基于JSP网页自动生成工具的设计与实现
    基于“积件”思想的网络课件设计
    基于Internet远程教育系统的网络架构
    网友评论:
    (只显示最新10条。评论内容只代表网友观点!)
    早上8:30-下午5:30
    全国客服热线: 010-84639241
    客服QQ: 10015411 / 173799180
    客服Email: edufo@163.com
      QQ交流群: 5379191 / 5371551
    网站介绍 |  联系我们 | 加盟合作 | 友情链接 | 广告服务 | 诚聘英才 | 网站地图 | 免责声明
    不良信息
    举报中心
    在职教育交流中心 版权所有 TEL:010-84639241 京ICP备06028089
    Copyright © 1998 - 2007 EDUFO Inc. All Rights Reserved
    网络110
    报警服务