首先,做一些简单的铺垫,目前针对ChartCtrl源码的剖析只针对V.15版本。名义上说是剖析,倒不如说是记录下自己针对该控件的理解,非常感谢Cedric Moonen大神,一切的功劳与掌声都该赠予给他。Code Project项目地址:https://www.codeproject.com/Articles/14075/High-speed-Charting-Control。剖析以源码注释加额外说明为主,有记录不妥的地方,欢迎各路大神拍砖,交流与沟通是大家各自进步的基石。
 先概览一下该源码的关键类之间的关系图,做到阅读源码的时候心中有数。 
CChartObject类的头文件。
#if !defined(AFX_CHARTOBJECT_H__6ED024F2_00D9_45D5_AB83_258EF0075288__INCLUDED_)
#define AFX_CHARTOBJECT_H__6ED024F2_00D9_45D5_AB83_258EF0075288__INCLUDED_ #if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000 #include <afx.h>
#include <afxwin.h> // CChartCtrl类的前置声明
class CChartCtrl;
class CChartObject
{
friend CChartCtrl;
public:
CChartObject(CChartCtrl* pOwner);
virtual ~CChartObject();
void SetVisible(bool bVisible);
bool IsVisible() const { return m_bIsVisible; }
COLORREF GetColor() const { return m_ObjectColor; }
void SetColor(COLORREF NewColor);
COLORREF GetShadowColor() const { return m_ShadowColor; }
void SetShadowColor(COLORREF NewColor);
void EnableShadow(bool bEnable);
void SetShadowDepth(int Depth);
bool Clip(int& dX, int& dY) const
{
bool bResult = true;
if (dX>m_ObjectRect.right)
{
dX = m_ObjectRect.right;
bResult = false;
}
if (dX<m_ObjectRect.left)
{
dX = m_ObjectRect.left;
bResult = false;
}
if (dY>m_ObjectRect.bottom)
{
dY = m_ObjectRect.bottom;
bResult = false;
}
if (dY<m_ObjectRect.top)
{
dY = m_ObjectRect.top;
bResult = false;
}
return bResult;
}
protected:
void SetRect(CRect NewTect) { m_ObjectRect = NewTect; } CRect m_ObjectRect; // Size of the object
COLORREF m_ObjectColor; // Color of the objet
CChartCtrl* m_pParent; // Owner of the object
bool m_bIsVisible;
bool m_bShadow; // Specifies if the object generate a shadow.
// This is not supported for all objects.
COLORREF m_ShadowColor;
int m_iShadowDepth;
private:
virtual void Draw(CDC* pDC) = ;
};
#endif // !defined(AFX_CHARTOBJECT_H__6ED024F2_00D9_45D5_AB83_258EF0075288__INCLUDED_)

CChartObject类的源文件。

#include "stdafx.h"
#include "ChartCtrl.h"
CChartObject::CChartObject(CChartCtrl* pOwner)
{
m_ObjectRect.left = m_ObjectRect.right = ;
m_ObjectRect.top = m_ObjectRect.bottom = ;
m_ObjectColor = RGB(,,);
m_pParent = pOwner;
m_bIsVisible = true;
m_bShadow = false;
m_ShadowColor = RGB(,,);
m_iShadowDepth = ;
}
CChartObject::~CChartObject()
{
}
void CChartObject::SetVisible(bool bVisible)
{
m_bIsVisible = bVisible;
m_pParent->RefreshCtrl();
}
void CChartObject::SetColor(COLORREF NewColor)
{
m_ObjectColor = NewColor;
m_pParent->RefreshCtrl();
}
void CChartObject::SetShadowColor(COLORREF NewColor)
{
m_ShadowColor = NewColor;
m_pParent->RefreshCtrl();
}
void CChartObject::EnableShadow(bool bEnable)
{
m_bShadow = bEnable;
m_pParent->RefreshCtrl();
}
void CChartObject::SetShadowDepth(int Depth)
{
m_iShadowDepth = Depth;
m_pParent->RefreshCtrl();
}
在这份源码中没什么特别难懂且复杂的地方,简单说几个自己觉得值得记录的知识点。
  • 头文件中的#if !defined(……) …… #endif是为了避免当前头文件被二次包含,起到类似功能的还有#ifndef …… #endif。
  • _MSC_VER为Microsoft的C编译器版本,微软不同时期,编译器有不同的版本:
    • Visual C++ 2005 MS VC++8.0   _MSC_VER = 1400
    • Visual C++ 2008 MS VC++9.0   _MSC_VER = 1500
    • Visual C++ 2010 MS VC++10.0 _MSC_VER = 1600
  • 在程序中加入_MSC_VER宏可以根据编译器版本让不同版本的编译器选择性地编译一段程序。查看编译的版本信息,可以在开发工具对应的Command line里敲 cl /?
  • Clip函数用来将函数参数中的位置约束在m_ObjectRect矩形空间内,当该位置在m_ObjectRect矩形空间的时候函数返回值为True;否则,返回False。

ChartCtrl源码剖析之——CChartObject类的更多相关文章

  1. ChartCtrl源码剖析之——CChartAxis类

    CChartAxis类用来绘制波形控件的坐标轴,这个源码相对较复杂,当初阅读的时候耗费了不少精力来理解源码中的一些实现细节. CChartAxis类的头文件. #if !defined(AFX_CHA ...

  2. ChartCtrl源码剖析之——CChartTitle类

    CChartTitle类顾名思义,该类用来绘制波形控件的标题,它处于该控件的区域,如下图所示: CChartTitle类的头文件. #if !defined(AFX_CHARTTITLE_H__499 ...

  3. ChartCtrl源码剖析之——CChartScrollBar类

    CChartScrollBar类用来针对每个轴的数据进行滚动,将那些不在当前区域内的数据通过滚动展示出来. CChartScrollBar类的头文件. #pragma once class CChar ...

  4. ChartCtrl源码剖析之——CChartAxisLabel类

    CChartAxisLabel类用来绘制轴标签,上.下.左.右都可以根据实际需要设置对应的轴标签.它处于该控件的区域,如下图所示: CChartAxisLabel类的头文件. #if !defined ...

  5. ChartCtrl源码剖析之——CChartLegend类

    CChartLegend类用来绘制每一个波形的描述信息,它处于该控件的区域,如下图所示: CChartLegend类的头文件. #if !defined(AFX_CHARTLEGEND_H__CD72 ...

  6. ChartCtrl源码剖析之——CChartGrid类

    CChartGrid类用来绘制波形区域中的表格,当绘制波形时波形就显示在这些表格上面.它处于该控件的区域,如下图所示: CChartGrid类的头文件. #if !defined(AFX_CHARTG ...

  7. PART(Persistent Adaptive Radix Tree)的Java实现源码剖析

    论文地址 Adaptive Radix Tree: https://db.in.tum.de/~leis/papers/ART.pdf Persistent Adaptive Radix Tree: ...

  8. 老李推荐:第6章3节《MonkeyRunner源码剖析》Monkey原理分析-事件源-事件源概览-命令翻译类

    老李推荐:第6章3节<MonkeyRunner源码剖析>Monkey原理分析-事件源-事件源概览-命令翻译类   每个来自网络的字串命令都需要进行解析执行,只是有些是在解析的过程中直接执行 ...

  9. WorldWind源码剖析系列:影像存储类ImageStore、Nlt影像存储类NltImageStore和WMS影像存储类WmsImageStore

    影像存储类ImageStore 影像存储类ImageStore提供了计算本地影像路径和远程影像影像URL访问的各种接口,是WmsImageStore类和NltImageStore类的基类.当划分完层次 ...

随机推荐

  1. HttpClien Get&Post

    新公司上班第二周,开始进军.Net Core,这方面的东西比较新,所以已经封装好的东西比较少,比如HttpClien之类的开源类库,找了NuGet好久,没有找到,所以先写个简陋的来用着先. 引用: u ...

  2. OpenGL教程(0)——介绍

    OpenGL介绍 OpenGL,全称Open Graphics Library,是一个用C语言写的图形API.通俗地说,OpenGL用来绘制2D/3D图形.目前OpenGL的运用十分广泛,有许多用Op ...

  3. javaSE_06Java中的数组(array)-提高练习

    1.求1!+2!+3!+···+30!的和,定义一个方法 public class Test1{ public static void main(String[] args){ //1.求1!+2!+ ...

  4. 如何在vuejs中抽出公共代码

    当我们在使用vue构建中大型项目时,通常会遇到某些经常用的方法以及属性,比如说搭建一个员工管理系统,请求的url需要一个共同的前缀,或者在某几个view中需要用到时间,这个时间是通过某方法格式化之后的 ...

  5. 【2017-06-05】Jquery.ajax

    AJAX  是一种网页数据异步加载技术 通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新.这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新. 一.Json     ...

  6. nodeJS实现简单网页爬虫功能

    前面的话 本文将使用nodeJS实现一个简单的网页爬虫功能 网页源码 使用http.get()方法获取网页源码,以hao123网站的头条页面为例 http://tuijian.hao123.com/h ...

  7. OkHttp基本使用

    OkHttp介绍 Android系统提供了两种HTTP通信类,HttpURLConnection和HttpClient,HttpURLConnection相对来说比HttpClient难用,googl ...

  8. 关于oracle数据库备份还原-impdp,expdp

    初始化: -- 创建表空间 CREATE TABLESPACE 表空间名 DATAFILE '文件名.dat' SIZE 100M AUTOEXTEND ON NEXT 10M MAXSIZE UNL ...

  9. [1] Entity Framework / Code First

    CodeFirst是EntityFramework的一种技术手段,因为传统编程方式都是先建立数据库,然后根据数据库模型为应用程序建模,再进行开发:CodeFirst从字面上理解就是代码先行,先在程序中 ...

  10. iOS-Core-Animation-Advanced-Techniques(一)

    视图(UIView)和图层(CALayer)的关系: 每一个UIview都有一个CALayer实例的图层属性,视图的职责就是创建并管理这个图层,以确保当子视图在层级关系中添加或者被移除的时候,他们关联 ...