MSChart ActiveX控件添加进VS2010项目

  1. 下载个MSCHART20.ocx,放进c:/windows/system32
  2. 下载个控件注册工具,下载地址http://download.csdn.net/source/3017983
  3. 在VS2010项目中添加类CDMSChart类,项目- 添加类- 添加ActiveX控件的MFC类,选择Microsoft Chart Control 6.0,添加CDMSChart类。PS.该控件还包括很多类,在添加类-添加TypeLib中的MFC类可以看到,但只能添加头文件,cpp文件没找到(不解!)。只添加CDMSCHart类,不知功能是否齐全~~~
  4. 在VS2010项目的对话空中拖入该控件,或者直接用生成CDMSChart类对象,用其Create函数在需要的地方画出该控件。如,
    1. // CDemoView::OnCreate()   
    2. CRect rc;  
    3. GetClientRect(&rc);  
    4. if(!m_Chart.Create("mschart", WS_CHILD| WS_VISIBLE, rc, this, 10))  
    5. return -1;  
  5.  CDemoView::OnSize 中调整 m_Chart 的大小,使之能随窗口大小变化而变化
    1. // CDemoView::OnSize   
    2. if( m_Chart.GetSafeHwnd() )  
    3. m_Chart.MoveWindow( 0, 0, cx, cy );   

来自:http://blog.csdn.net/qq361301276/article/details/6179786

1,databasesearch.ZIP数据库查询示例程序(3KB)2,dbgrid.ZIP在DBGRID控件的单元格中实现下拉列表框(3KB)3,flex.ZIP 隐藏FlexGrid的某些行(2KB)4,dbpic.ZIP 将图片添加到Access数据库中。(19KB)5,dbprint.ZIP 一个数据库打印的范例(8KB)6,exportdb.ZIP 将数据库输出到一个文本文件中(5KB)7,sqlcount.ZIP 从一次SQL查询中获得多个查询数值(6KB)8,createnewdatabase.ZIP 通过程序在磁盘上建立一个新的Access数据库文件。(2KB)9,munir.ZIP 显示数据库中内容的例子(13KB) 10,shahida.ZIP query数据库的例子(12KB)11,datafile.ZIP 创建和修改自定义的数据库 (20KB)12,edittbls.ZIP 演示编辑一个数据表 (9KB)13,graphdb.ZIP 从数据库中读取数据并将它放入图形中,需要mschart ocx (6KB)14,binarydb.ZIP 快速数据库的编程实现 (11KB)15,tysjk.zip 数据库观察器(8KB)16,creatmdb.zip 用代码在程序运行阶段建立MDB数据库文件(4KB)17,datafile1.zip 创建和修改自定义的数据库(5KB)18,datediff.zip 创建和修改自定义的数据库(2KB)19,dbgrid3.zip 使用没有连接到数据库的 DBGrid 控件(5KB)20,mschart.zip 从数据库中读取数据行图形显示, 需要MSChart OCX(9KB)21,sqltest.zip 基于SQL Server 6.5的公司销存管理的实例(298KB)22,dbsprop.zip 数据库属性页(14KB)23,rdsdemo.zip RDS 数据库(18KB)24,accesspwd.zip 读取Access97数据库密码(9KB)25,d032_gzgl.zip嘉兴金蜂软件作坊的定单管理软件(953KB)26,d031_sqltest.zip基于SQL Server 6.5的公司销存管理的实例(300KB)27,d030_grzb.zip小小收支薄 (67KB)28,d029_addressbook.zip一个简单的数据库程序,包括添加,搜索等功能,是一个入门级的程序(9KB)29,d028_zm046.zip你只要把想做的查询方式告诉它,它就会把相应的SQL语句告诉你,很酷吧?(33KB)30,d027_zm027.zip一个简易的ACCESS的源程序,用到了很多操作数据库的技巧,Cool(128KB)31,d026_binaryDB.zip一定要用微软的数据引擎吗?一定要承受巨大的 DLL 文件?本程序说:No (11KB)32,d025_TwFAQ.zip FAQ统计系统(374KB)33,d024_ddgl.zip一个完整的数据库管理程序(262KB)34,d023_grzb.zip程志刚的个人财务软件的源码,完整的数据库程序(67KB)35,d022_demos-02.zip将MDB文件导出为多种格式文件,如:DBF,TXT等(3KB)36,d021_mdbto.zip范例-如何在 MSFlexGrid 中输入资料(3KB)37,d020_sqlcount.zipSQL计数的例子(6KB)38,d019_xlstomdb.zip如何把Excel文件转换成mdb数据库(14KB)39,d018exportdb.zip类似(基本无异)Microsoft Access 的数据库属性页源代码(5KB)40,d017_shahida.zipQuery数据库的例子(9KB)41,d016_mschart.zip从数据库中读取数据行图形显示, 需要MSChart OCX(9KB)42,d015_chunkole.zip将多媒体文件保存到数据库中,或将数据库中的多媒体文件显示出来(90KB)43,d014_dbpic.zip把图片放到数据库中(19KB)44,d013_dbgrid3.zip使用没有连接到数据库的 DBGrid 控件(5KB)45,d012_datediff.zip创建和修改自定义的数据库(2KB)46,d011_databasesearch.zip数据库查询示例程序(3KB)47,d010_vbcodelib.zip一个管理VB源码的数据库例子(101KB)48,d009_creatmdb.zip用代码在程序运行阶段建立MDB数据库文件(4KB)49,d008_tysjk.zip一个不错的数据库观察器(8KB)50,d007_mydata.zip个人的数据库(10KB)51,d006.zip建立大于屏幕的虚拟表单(3KB)52,d005.zip数据库打印的例子(8KB)53,d004.zip这个例子演示读取数据库中的内容并输出到文本文件(5KB)54,d003.zip快速数据库的编程实现(11KB)55,d002.zip演示编辑一个数据表(9KB)56,d001.zip显示数据库中内容的例子(13KB)57,ddeexamp.zip 利用 DDE 控制Access(39KB)58,sql.zip 数据库及前端应用程序(300KB)59,dbtohtml.zip MDB2HTM(23KB)60,mydata.zip 从库中调用图片(10KB)61,gzgl.zip 工资管理(953KB)62,n-10.zip 创建和修改自定义的数据库(20KB)63,n-26.zip 显示数据库中内容的例子(13KB)
如何安装mschart#Region "定义变量" Const XOffset As Integer = 50, Yoffset As Integer = 20 Dim WithEvents PicCurve As PictureBox Dim xStep As Single = 5, yStep As Single Dim ValueArray As ArrayList Dim ThresHold() As Single 'HIHI、HI、LO、LOLO Dim Name As String = "参数名" Dim Unit As String = "单位" #End Region #Region "构造函数、析构函数" Public Sub New(ByVal mPictureBox As PictureBox, ByVal mThresHold() As Single, ByVal mName As String) ValueArray = New ArrayList PicCurve = mPictureBox ThresHold = mThresHold mPictureBox.BorderStyle = BorderStyle.None Name = mName End Sub Protected Overrides Sub Finalize() MyBase.Finalize() ValueArray.Clear() End Sub #End Region #Region "添加要绘制的点的信息" Public Sub AddValue(ByVal Value As Single) 'Value = ThresHold(0) * Rnd() + ThresHold(3) '测试代码 ValueArray.Add(Value) Call DrawCurve(GetGraphics(PicCurve)) End Sub Public Sub AddValues(ByVal Values() As Single, ByVal G As Graphics) For i As Integer = 0 To Values.Length - 1 ValueArray.Add(Values(i)) Next Call DrawCurve(G) End Sub #End Region #Region "绘制点之间的连线" Private Sub DrawCurve(ByVal G As Graphics, Optional ByVal mClear As Boolean = True) If ValueArray.Count > 0 Then If mClear Then G.Clear(Color.White) G.SmoothingMode = Drawing2D.SmoothingMode.HighQuality Dim mPoints(ValueArray.Count - 1) As Point, Position As Integer = XOffset For i As Integer = ValueArray.Count - 1 To 0 Step -1 Dim ThisValue As Single = CType(ValueArray(i), Single) 'If Position < PicCurve.Width Then Position += xStep Else Exit For Position += xStep mPoints(i) = New Point(Position, (ThresHold(0) - ThisValue) * yStep + Yoffset) Next G.DrawCurve(Pens.Blue, mPoints) mPoints = Nothing End If End Sub #End Region #Region "绘制坐标系统" Private Sub DrawReferenceFrame(ByVal G As Graphics) Dim mPoint1 As New Point, mPoint2 As New Point '定义绘图画笔 Dim MyPen As New Pen(Color.Black, 3) Dim MyStringFormat As New System.Drawing.StringFormat MyStringFormat.Alignment = StringAlignment.Center Dim mSize As New SizeF MyPen.SetLineCap(Drawing2D.LineCap.NoAnchor, Drawing2D.LineCap.ArrowAnchor, Drawing2D.DashCap.Flat) Dim mFont As Font = New Font(FontFamily.GenericSansSerif, 12.0F, FontStyle.Bold) '绘制Y轴 MyPen.Color = Color.Black mPoint1 = New Point(XOffset, PicCurve.Height) mPoint2 = New Point(XOffset, 0) G.DrawLine(MyPen, mPoint1, mPoint2) '绘制X轴 MyPen.Color = Color.LightGreen mPoint1 = New Point(XOffset, PicCurve.Height / 2) mPoint2 = New Point(PicCurve.Width, PicCurve.Height / 2) G.DrawLine(MyPen, mPoint1, mPoint2) '绘制参数名 MyStringFormat.FormatFlags = StringFormatFlags.DirectionVertical mSize = G.MeasureString(Name, mFont) mPoint1.Offset(-mSize.Height, 0) G.DrawString(Name, mFont, Brushes.Black, mPoint1, MyStringFormat) '绘制参数各门限 MyPen.DashStyle = Drawing2D.DashStyle.Dash : MyPen.Width = 2 MyPen.SetLineCap(Drawing2D.LineCap.NoAnchor, Drawing2D.LineCap.NoAnchor, Drawing2D.DashCap.Round) 'HI If ThresHold(1) <> ThresHold(0) Then MyPen.Color = Color.Yellow mPoint1 = New Point(XOffset, (ThresHold(0) - ThresHold(1)) * yStep + Yoffset) mPoint2 = New Point(PicCurve.Width, (ThresHold(0) - ThresHold(1)) * yStep + Yoffset) G.DrawLine(MyPen, mPoint1, mPoint2) mSize = G.MeasureString(ThresHold(1).ToString, mFont) mPoint1.Offset(-mSize.Width, -mSize.Height / 2) G.DrawString(ThresHold(1).ToString, mFont, Brushes.Yellow, mPoint1) End If 'LO If ThresHold(2) <> ThresHold(3) Then mPoint1 = New Point(XOffset, (ThresHold(0) - ThresHold(2)) * yStep + Yoffset) mPoint2 = New Point(PicCurve.Width, (ThresHold(0) - ThresHold(2)) * yStep + Yoffset) G.DrawLine(MyPen, mPoint1, mPoint2) mSize = G.MeasureString(ThresHold(2).ToString, mFont) mPoint1.Offset(-mSize.Width, -mSize.Height / 2) G.DrawString(ThresHold(2).ToString, mFont, Brushes.Yellow, mPoint1) End If 'HIHI MyPen.Color = Color.Red mPoint1 = New Point(XOffset, Yoffset) mPoint2 = New Point(PicCurve.Width, Yoffset) G.DrawLine(MyPen, mPoint1, mPoint2) mSize = G.MeasureString(ThresHold(0).ToString, mFont) mPoint1.Offset(-mSize.Width, -mSize.Height / 2) G.DrawString(ThresHold(0).ToString, mFont, Brushes.Red, mPoint1) 'LOLO mPoint1 = New Point(XOffset, PicCurve.Height - Yoffset) mPoint2 = New Point(PicCurve.Width, PicCurve.Height - Yoffset) G.DrawLine(MyPen, mPoint1, mPoint2) mSize = G.MeasureString(ThresHold(3).ToString, mFont) mPoint1.Offset(-mSize.Width, -mSize.Height / 2) G.DrawString(ThresHold(3).ToString, mFont, Brushes.Red, mPoint1) MyPen.Dispose() mFont.Dispose() End Sub #End Region #Region "要在其上绘制的控件事件" Private Sub PicCurve_Paint(ByVal sender As Object, ByVal e As System.Windows.Forms.PaintEventArgs) Handles PicCurve.Paint Call DrawReferenceFrame(e.Graphics) End Sub Private Sub PicCurve_Resize(ByVal sender As Object, ByVal e As System.EventArgs) Handles PicCurve.Resize On Error Resume Next xStep = 5 yStep = (PicCurve.Height - 2 * Yoffset) / (ThresHold(0) - ThresHold(3)) End Sub #End Region #Region "绘制永久图像" Function GetGraphics(ByRef pic As PictureBox) As Graphics Dim bmp As Bitmap = New Bitmap(pic.Width, pic.Height) pic.Image = bmp Dim g As System.Drawing.Graphics = Graphics.FromImage(bmp) Return g End Function #End Region #Region "保存图形" Public Sub SaveCurve(ByVal FileName As String) Dim bmp As New Bitmap(PicCurve.Width, PicCurve.Height) Dim g As Graphics = Graphics.FromImage(bmp) Call DrawReferenceFrame(g) Call DrawCurve(g, False) bmp.Save(FileName) End Sub #End Region End Class
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值