深入浅出CChart 每日一课——第六课 童心未泯,老狐狸分油饼之饼图

本文主要是介绍深入浅出CChart 每日一课——第六课 童心未泯,老狐狸分油饼之饼图,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这节课我们轻松一下,很快就放学,呵呵。

笨笨一直就喜欢吃饼子。

记得小时候,那时2B还只是铅笔,不是某些青年的代名词,全国人民都不富裕,笨笨最喜欢的东西就是在一团面粉里面夹一块肥肉,然后放在家里炉灶里面的热灰里,等饭做熟了饼也烤好了,拿出来咬一口肥油直冒,那个香啊,现在想起了还直流口水。

岁月是把杀猪刀,葡萄木耳加香蕉。如今笨笨已经吃不上当年的炉灰烤肉饼了,现在笨笨的最爱是西安的肉夹馍,外加羊肉泡馍,呵呵。

扯远了,下面给大家介绍CChart的饼图绘制功能,这是一种应用非常广泛的图表形式。当然罗,由于我们的工具是CChart,简单是必然的了。

请大家按照第一课的方法用VC6建立一个名为Lesson06的工程。下面修改WM_CREATE消息的响应例程如下。

 
case WM_CREATE:chartWnd.Attach(hWnd, kTypePie);chartWnd.GetChart()->AddPie(28);chartWnd.GetChart()->AddPie(39);chartWnd.GetChart()->AddPie(21);chartWnd.GetChart()->AddPie(22);break;

注意到饼图的代号是kTypePie。

运行程序,效果如图。

这里用AddPie添加饼图的数据。

A piece of cake!

上图中不爽之处在于每块饼的名称没有设置,下面重新修改WM_CREATE的响应例程。

 
case WM_CREATE:chartWnd.Attach(hWnd, kTypePie);chartWnd.GetChart()->AddPie(28);chartWnd.GetChart()->AddPie(39);chartWnd.GetChart()->AddPie(21);chartWnd.GetChart()->AddPie(22);chartWnd.GetChart()->SetPieTitle(_T("赵敏"), 0);chartWnd.GetChart()->SetPieTitle(_T("周芷若"), 1);chartWnd.GetChart()->SetPieTitle(_T("殷离"), 2);chartWnd.GetChart()->SetPieTitle(_T("小昭"), 3);break;

运行效果如图。

用SetPieTitle可以设置饼的标题。

最后我们在上面的break;这一行前面设置一下饼图的标题。

 
chartWnd.GetChart()->SetTitle(_T("张无忌的内心世界"));

运行效果如图。

请同学们注意一下,饼图每块饼的标题都是可以任意拖动的。当饼标题与对应饼处于分离状态时,饼标题的颜色和饼颜色是一致的;当饼标题与对应饼处于相交状态时,饼标题将变色以便辨认。如图,“小昭”已经改变颜色。

另外,饼图本身也是可以任意拖动的,同学们可以用鼠标试一试。

这节课非常轻松,可以下课了。

这篇关于深入浅出CChart 每日一课——第六课 童心未泯,老狐狸分油饼之饼图的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/388699

相关文章

深入浅出Java中的Happens-Before核心规则

《深入浅出Java中的Happens-Before核心规则》本文解析Java内存模型中的Happens-Before原则,解释其定义、核心规则及实际应用,帮助理解多线程可见性与有序性问题,掌握并发编程... 目录前言一、Happens-Before是什么?为什么需要它?1.1 从一个问题说起1.2 Haht

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

深入浅出SpringBoot WebSocket构建实时应用全面指南

《深入浅出SpringBootWebSocket构建实时应用全面指南》WebSocket是一种在单个TCP连接上进行全双工通信的协议,这篇文章主要为大家详细介绍了SpringBoot如何集成WebS... 目录前言为什么需要 WebSocketWebSocket 是什么Spring Boot 如何简化 We

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟)

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟) 题目描述 给定一个链表,链表中的每个节点代表一个整数。链表中的整数由 0 分隔开,表示不同的区间。链表的开始和结束节点的值都为 0。任务是将每两个相邻的 0 之间的所有节点合并成一个节点,新节点的值为原区间内所有节点值的和。合并后,需要移除所有的 0,并返回修改后的链表头节点。 思路分析 初始化:创建一个虚拟头节点

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数

每日一练7:简写单词(含链接)

1.链接 简写单词_牛客题霸_牛客网 2.题目 3.代码1(错误经验) #include <iostream>#include <string>using namespace std;int main() {string s;string ret;int count = 0;while(cin >> s)for(auto a : s){if(count == 0){if( a <=

【每日刷题】Day113

【每日刷题】Day113 🥕个人主页:开敲🍉 🔥所属专栏:每日刷题🍍 🌼文章目录🌼 1. 91. 解码方法 - 力扣(LeetCode) 2. LCR 098. 不同路径 - 力扣(LeetCode) 3. 63. 不同路径 II - 力扣(LeetCode) 1. 91. 解码方法 - 力扣(LeetCode) //思路:动态规划。 cl

力扣 739. 每日温度【经典单调栈题目】

1. 题目 理解题意: 1.1. 给一个温度集合, 要返回一个对应长度的结果集合, 这个结果集合里面的元素 i 是 当前 i 位置的元素的下一个更高温度的元素的位置和当前 i 位置的距离之差, 若是当前元素不存在下一个更高温度的元素, 则这个位置用0代替; 2. 思路 本题用单调栈来求解;单调栈就适用于来求当前元素左边或者右边第一个比当前元素大或者小的元素;【单调栈:让栈中的元素保持单调

每日一题——第八十一题

打印如下图案: #include<stdio.h>int main() {int i, j;char ch = 'A';for (i = 1; i < 5; i++, ch++){for (j = 0; j < 5 - i; j++){printf(" ");//控制空格输出}for (j = 1; j < 2 * i; j++)//条件j < 2 * i{printf("%c", ch

每日一题,力扣leetcode Hot100之238.除自身以外数组的乘积

乍一看这个题很简单,但是不能用除法,并且在O(N)时间复杂度完成或许有点难度。 考虑到不能用除法,如果我们要计算输出结果位置i的值,我们就要获取这个位置左边的乘积和右边的乘积,那么我新设立两个数组L和R。 对于L来说,由于表达的是位置i左边的数的乘积,那么L[0]=1,因为第一个数字左边没数那么为了不影响乘积初始值就设置为1,那么L[1]=L[0]*nums[0],那么L[i]=L[i-1