• [导入]接上面的,ASP里用Mschart


    目录 文尾口口口 m 工程地质计算机应用 2005年1期 总37期

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

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

    杨宗长1 匡 虹2

    (1 武汉大学电信学院 武汉 430072;2 怀化广播电视大学 湖南怀化 418000)

    【摘要】本文较详尽地介绍了在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,包括四个字段(即四个科目成绩字段):Chinese,Math,English,Computer。

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

    3 程序演示

    演示结果如图4和图5。

     

    图4

    图5

    (收稿日期:2004-12-06;Email:kh93@163.com; yzc2@btamail.net.cn)

    目录 文首


    文章来源:http://computer.mblogger.cn/wucountry/posts/40260.aspx
    ================================
      /\_/\                        
     (=^o^=)  Wu.Country@侠缘      
     (~)@(~)  一辈子,用心做一件事!
    --------------------------------
      学而不思则罔,思而不学则怠!  
    ================================
  • 相关阅读:
    今年要读的书
    java多线程
    json-lib 使用教程
    tomcat原理
    静态long类型常量serialVersionUID的作用
    使用junit4测试Spring
    MySQL各版本的区别
    spring mvc 下载安装
    hibernate、struts、spring mvc的作用
    【面试】hibernate n+1问题
  • 原文地址:https://www.cnblogs.com/WuCountry/p/305949.html
Copyright © 2020-2023  润新知