首先,做一些简单的铺垫,目前针对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. 在.Net下使用redis基于StackExchange.Redis

    研究了下redis在.net下的使用,因为以前在java上用redis用的是jedis操作,在.net不是很熟悉,在网站上也看了一部分的.net下redis的使用,大部分都是ServiceStack. ...

  2. WebSocket和kafka实现数据实时推送到前端

    一. 需求背景      最近新接触一个需求,需要将kafka中的数据实时推送到前端展示.最开始想到的是前端轮询接口数据,但是无法保证轮询的频率和消费的频率完全一致,或造成数据缺失等问题.最终确定用利 ...

  3. python3-如何正常使用HTMLTestRunner.py,生成自动化测试报告

    其实HTMLTestRunner.py是基于python2开发的,为了使其支持python3环境,需要对其的部分内容进行修改.下面我们通过编辑器打开HTMLTestRunner.py文件(编辑器可以选 ...

  4. Eclipse之文件【默认编码格式设置】,防止乱码等问题

    文件默认编码格式设置步骤如下: 这里显示的是workspace的视图 其他格式文件的视图如下:

  5. 什么是 html 标签,html 实体

    为什么需要转换 更简了,因为有时候我们需要在浏览器页面中显示 html 标签,然而直接输出<script>alert(1)</script>,在浏览页面时将会被当作 html ...

  6. Codility---MaxProfit

    Task description A zero-indexed array A consisting of N integers is given. It contains daily prices ...

  7. Facebook开源Zstandard新型压缩算法代替Zlib 简单使用

    简介 Zstandard(缩写为Zstd)是由Facebook的Yann Collet开发的一个无损数据压缩算法.Zstandard在设计上与DEFLATE(.zip.gzip)算法有着差不多的压缩比 ...

  8. R语言重要数据集分析研究——需要整理分析阐明理念

    1.R语言重要数据集分析研究需要整理分析阐明理念? 上一节讲了R语言作图,本节来讲讲当你拿到一个数据集的时候如何下手分析,数据分析的第一步,探索性数据分析. 统计量,即统计学里面关注的数据集的几个指标 ...

  9. 用CSS美化checkbox复选按钮和raido单选按钮-适用于移动端

    最终效果: 实现方法 index.html: <!DOCTYPE html> <html> <head> <title></title> & ...

  10. iOS获取WIFI的IP、子网掩码,以及域名转IP

    获取WIFI需要的头文件: #import "GetCurrentIP.h" #import <ifaddrs.h> #import <arpa/inet.h&g ...