复合式统计图绘制方法(7)

复合式统计图绘制方法(7)
常用的统计图有条形图、柱形图、折线图、曲线图、饼图、环形图、扇形图。
前几类图比较容易绘制,饼图环形图绘制较难。
在统计图的应用方面,有时候有两个关联的统计学的样本值要用统计图来表达,一张统计图不能表达清楚,就要二张图来表达。由此就产生了复合式的统计图,它能将两个需要表达的统计概念统一在一张图表上阐述清楚。

在网络科技发展进步的当下,原来一些传统的统计图表都有了进一步的创新。以前企业的PPT都依赖微软的各应用软件来制作图表,现时企业的PPT展示的图表应用不再满足于Excle,Word的图表绘制方法,进而使用一些第三方应用软件来制作新颖漂亮的图表。由此而有许多图表制作的应用软件面市。这些图表很吸引眼球,我对此也很感兴趣,故试着写了一些各种式样图表的绘制方法,供有同好的同行参考和评论。

新样式的统计图有复合式,堆叠式,展开式等等,不一而足。在美工艺术方面有许多独到新颖的样式,给人一个赏心悦目的感受。

今在此提供一种复合式统计图的绘制方法供参考。

本方法采用C语言的最基本功能:
(1)绘图功能画线,画圆,画长方形。
(2)界面美工设计,界面文字打印输出。
代码中有详细的注释,通俗易懂,一看就会。

//在统计图表的样本值的计算方面,样本值的量的表现是一个方面,重点是量的对比,这是体现统计图目的的主要意义。其中最基本的是完成与计划的对比。

//介绍一个基本的计算方法:
//单个商品按类相加=单个商品销售总量
//分组6个商品总量相加=商品销售总量
//占比分析:单个商品销售总量/商品销售总量
//商品*单价=销售额
//6个商品类销售额相加=商品销售总额
//单个销售额/销售总额=单个商品类占比
//占比分析:单个商品类销售总额/商品销售总额


下面是绘制复合式统计图的代码:
//变量: 可设置成全局变量或私有变量
Canvas cs ;     //画布,绘制图表载体
float pi=3.1415926535 ;
float a ;            //三角函数 sin (a), cos (a), 
float r ;             //圆半径 radius
int i, j, n ;
float x0,y0,x1,y1,x2,y2 ;  //作图
float dx1,dy1,dx,dy ;             //中心坐标
string ss, ss1, ss2,ss3 ;         //打印文字
 int p[6] ;        //set data   or  input  data
 double pn ;   //显示数据,计算
  int cr, cg, cb ;     //设置颜色 setColor (a,r,g,b) 
 int  p1[16],  p2[16], p3[16] ;
 int ppn ;   //计算
 int tb ;      //set tab
 int k0, k1 ;    //圆720线 起终点
 double sum1, sum2, sum3, sum ;  //统计计算
 double sum4, sum5, sum6 ;

0b1bd1a0ad8a48e2823507191ca1f2c1.png 

//*************************  
compound7 (){  //复合式统计图  7  饼图加凸显扇形
      cs.ClearDraw (0,src);   //清屏
      clearOutput();
      selectStyle () ; //图例样式选项设置
      cs.SetFillMode (1);//0不填色,1填色
         cs.SetColor (255,250,250,250);
      cs.DrawRect (0,4,720,600);   //back board
         cs.SetColor (255,140,140,140);
      cs.DrawRect (24,24,706,586);   //back      
         cs.SetColor (255,250,250,240);
      cs.DrawRect (20,20,700,580);   //back 
      cs.SetFillMode (0);//0不填色,1填色
         cs.SetColor (255,0,0,250);
      cs.DrawRect (20,20,700,580);   //back 
      cs.DrawRect (26,25,694,575);   //back 
 
  //复合式统计图样例:
  //图例 (饼图加凸显扇形)
     cs.SetFillMode (1);//0不填色,1填色
            dx=330;  dy=270 ;   //center
         cs.SetColor (255,250,200,230);
     cs.DrawRect (50,80,150,310);   //样本值标底
     //cs.DrawRect (590,245,675,530);   //样本值标底
     cs.SetColor(255,250,220,240);
     cs.DrawCircle(dx,dy,170);    //center 图案底色
          cs.SetStrokeWidth(1);    //线
          cs.SetTextStyle (0);  //1 粗体字
          cs.SetTextSize (24);
          cs.SetColor(255,0,0,250);
        cs.DrawText ("Group ",65,110);
           cs.SetTextSize (20);
        cs.DrawText (" A",55,140);
        cs.DrawText (" B",55,170);
        cs.DrawText (" C",55,200);
        cs.DrawText (" D",55,230);
        cs.DrawText (" E",55,260);
        cs.DrawText (" F",55,290);
        cs.DrawText ("Group F",600,450);
 
 //先绘制饼图,
 //图例样本值:input data   
   p1[1]=1430; p1[2]=1700; p1[3]=1620; p1[4]=1500;  
   p1[5]=1750; p1[6]=2000;  //部门 10000
        k[0]=80;     //k=180,12点钟方向为0位
                            //k=0, 3点钟方向为0位
        k[1]=k[0]+p1[1]*72/1000 ;   //样本值合计10000
        k[2]=k[1]+p1[2]*72/1000 ;   //转换成整圆720线
        k[3]=k[2]+p1[3]*72/1000 ;
        k[4]=k[3]+p1[4]*72/1000 ;         
        k[5]=k[4]+p1[5]*72/1000 ;
        k[6]=k[5]+p1[6]*72/1000 ;
 //绘制饼图
           cs.SetStrokeWidth(2);    //线
           dx=330;  dy=270 ;   //center
            r=160 ;
    for (n=1; n<=6 ; n++){   //data=6
       for (i= k[n-1]; i<=k[n]; i++){  
             a=pi/360*i ;   // a/2 绘出的是半圆
       if (n==1) cs.SetColor(255,250,120,200);
       if (n==2) cs.SetColor(255,250,180,0);
       if (n==3) cs.SetColor(255,0,250,0);
       if (n==4) cs.SetColor(255,0,220,250);
       if (n==5) cs.SetColor(255,180,80,230);
       if (n==6) cs.SetColor(255,0,120,250);
            x0=(float)(r*cos (a))+dx ;     //r=radius
            y0=(float)(- r*sin (a))+dy ;     //逆时针
     cs.DrawLine (dx,dy, x0,y0);      
             //动画显示逐线绘出  加色标
     cs.DrawRect (80,n*30+90 ,140,n*30+115); 
           pn=p1[n]*10 ;     //保留1位小数
           pn=pn/1000 ; 
           ss1=doubleToString (pn)+"%" ;
           ss2=intToString (p1[n]) ;
       cs.SetColor(255,250,250,0);
        cs.DrawText(ss2, 88,n*30+110);   //色标
     cs.SetColor(255,250,250,250);  //图上标p1(n)
            ma=pi/360*((k[n-1]+k[n])/2) ;
            x1=(float)((r-45)*cos (ma))+dx ;     
            y1=(float)(-(r-45)*sin (ma))+dy ;
          cs.DrawText (ss1,x1-27,y1+10);     //标字
                 cs.Update ();   }    } //show 饼图

//绘制凸显扇形:先消隐第6块,再绘制第6块凸显扇形 ,再绘制展开扇形。
//上列代码第6块可不绘出,此设计主要是为表现动画式展示绘制过程,
       for (i= k[5]; i<=k[6]; i++){  //擦除
            a=pi/360*i ;   // a/2 绘出的是半圆
        cs.SetColor(255,250,230,240);
            x0=(float)(r*cos (a))+dx ;     //r=radius
            y0=(float)(- r*sin (a))+dy ;     //逆时针
        cs.DrawLine (dx,dy, x0,y0);      }  //擦除
//再绘制凸显的第6块
       for (i= k[5]; i<=k[6]; i++){  
              dx=330+15 ; dy=270 ;
            a=pi/360*i ;   // a/2 绘出的是半圆
         cs.SetColor(255,0,120,250);
            x0=(float)(r*cos (a))+dx ;     //r=radius
            y0=(float)(- r*sin (a))+dy ;     //逆时针
         cs.DrawLine (dx,dy, x0,y0);    
        cs.SetColor(255,250,250,250);  //图上标p1(n)
            ma=pi/360*((k[5]+k[6])/2) ;
            x1=(float)((r-45)*cos (ma))+dx ;     
            y1=(float)(-(r-45)*sin (ma))+dy ;
         cs.DrawText (ss1,x1-27,y1+10);     //标字
            cs.Update () ;      } //动画逐线绘出,标字

//再绘制凸显第6块的扇形展开图
//第6块数据分析:总数2000
    p[1]=500; p[2]=500; p[3]=400; p[4]=600;  
           k0=k[5];     p[0]=0 ;
           cs.SetStrokeWidth(3);    //线
      for (n=1; n<=4 ; n++){   //data=4
           k0=k0+p[n-1]*72/1000 ; 
           k1=k0+p[n]*72/1000 ; 
        for (i= k0; i<=k1; i++){  
              dx=330+15 ; dy=270 ;  r=160 ;
              a=pi/360*i ;   // a/2 绘出的是半圆
              cr=0 ;  cg=90+n*30 ; cb=250-n*10 ;
            cs.SetColor (255,cr,cg,cb) ;  //渐变色
            x0=(float)(180*cos (a))+dx ;     //r=radius
            y0=(float)(- 180*sin (a))+dy ;     //逆时针
            x1=(float)(260*cos (a))+dx ;     //r=radius
            y1=(float)(- 260*sin (a))+dy ;     //逆时针
        cs.DrawLine (x1,y1, x0,y0);    
            cs.Update () ;      }   //动画逐线绘出,渐变色
        cs.DrawRect (610,435-n*30 ,665,460-n*30); 
           pn=p[n]*10 ;     //保留1位小数
           pn=pn/1000 ; 
           ss1=doubleToString (pn)+"%" ;
           ss2=intToString (p[n]) ;
        cs.SetColor(255,250,250,0);
        cs.DrawText(ss2, 620,455-n*30);   //色标
     cs.SetColor(255,250,250,250);  //图上标p1(n)
            ma=pi/360*((k0+k1)/2) ;
            x1=(float)(230*cos (ma))+dx ;     
            y1=(float)(- 230*sin (ma))+dy ;
          cs.DrawText (ss1,x1-27,y1+10);     //标字
                 cs.Update ();       } //绘出加标值

 //draw 凸显标志线
          cs.SetStrokeWidth(2);
          cs.SetColor(255,250,0,0);
               a=pi/360*k[5] ;
            x0=(float)(300*cos (a))+dx ;     //r=radius
            y0=(float)(- 300*sin (a))+dy ;     //逆时针
           cs.DrawLine (dx,dy, x0,y0);    
           cs.DrawLine (x0,y0,x0+75,y0);    
                 a=pi/360*(k[0]-2);
            x1=(float)(260*cos (a))+dx ;     //r=radius
            y1=(float)(- 260*sin (a))+dy ;     //逆时针
            cs.DrawLine (dx,dy, x1,y1);    
  
//题标:  艺术立体字制作
        cs.SetFillMode (1);//0不填色,1填色
        cs.SetTextStyle (1);
        cs.SetStrokeWidth(1);
        cs.SetTextSize (28);
        cs.SetColor(255,0,0,250);      
      cs.DrawText ("Art Graphics 📊",480,60) ;
      cs.SetTextSize (40);
         ss="复合统计图:饼图加凸显扇形" ;
      cs.SetColor(255,50,120,20);      //立体字
           cs.DrawText (ss,114,544);    //阴影
      cs.SetColor(255,0,250,0);
           cs.DrawText (ss,110,540);    //本字
      cs.SetFillMode (0);//0不填色,1填色
      cs.SetColor(255,250,150,0);
           cs.DrawText (ss,110,540);    //框线
       cs.Update ();
}//compound7 ()


//**** END *****************
 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/447547.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

运动想象 (MI) 迁移学习系列 (5) : SSMT

运动想象迁移学习系列:SSMT 0. 引言1. 主要贡献2. 网络结构3. 算法4. 补充4.1 为什么设置一种新的适配器&#xff1f;4.2 动态加权融合机制究竟是干啥的&#xff1f; 5. 实验结果6. 总结欢迎来稿 论文地址&#xff1a;https://link.springer.com/article/10.1007/s11517-024-0…

天府锋巢直播产业基地:直播带岗,成都直播基地奔向产业化

天府锋巢直播产业基地位于成都市天府新区科学城板块&#xff0c;是一座集直播带岗、电商孵化、产业培训、供应链整合等多功能于一体的现代化全域直播产业基地。近年来&#xff0c;随着成都直播产业的蓬勃发展&#xff0c;成都积极响应市场需求&#xff0c;致力于打造出西部地区…

linux进程间通信-共享内存

一、共享内存是什么 在Linux系统中&#xff0c;共享内存是一种IPC&#xff08;进程间通信&#xff09;方式&#xff0c;它可以让多个进程在物理内存中共享一段内存区域。 这种共享内存区域被映射到多个进程的虚拟地址空间中&#xff0c;使得多个进程可以直接访问同一段物理内存…

【Python可视化系列】一文教你绘制雷达图(源码)

这是我的第234篇原创文章。 一、引言 雷达图是以从同一点开始的轴上表示的三个或更多个定量变量的二维图表的形式显示多变量数据的图形方法&#xff0c;也称为蜘蛛图或星形图。雷达图通常用于综合分析多个指标&#xff0c;具有完整&#xff0c;清晰和直观的优点。通常由多个等…

Constrained Iterative LQR 自动驾驶中使用的经典控制算法

Motion planning 运动规划在自动驾驶领域是一个比较有挑战的部分。它既要接受来自上层的行为理解和决策的输出,也要考虑一个包含道路结构和感知所检测到的所有障碍物状态的动态世界模型。最终生成一个满足安全性和可行性约束并且具有理想驾驶体验的轨迹。 通常,motion plann…

遥感影像植被波谱特征总结

植被跟太阳辐射的相互关系有别于其他物质&#xff0c;如裸土、水体等&#xff0c;比如植被的“红边”现象&#xff0c;即在<700nm附近强吸收&#xff0c;>700nm高反射。很多因素影响植被对太阳辐射的吸收和反射&#xff0c;包括波长、水分含量、色素、养分、碳等。 研究…

Kubernetes--ingress实现七层负载

目录 一、传统方式&#xff1a;不借助ingress实现七层代理 二、nginx-ingress 三、使用ingress实现七层代理 四、部署ingrss-nginx及功能 五、样例 1.Ingress-nginx HTTP代理访问 2.Ingress HTTPS代理访问&#xff08;会话卸载层&#xff09; 3.Nginx进行BasicAuth&…

亚马逊店铺解决和预防订单下滑的技巧

1. 保持账号的良好表现。不要销售侵权产品&#xff0c;发货要及时&#xff0c;能有追踪号的就带可查询追踪号&#xff0c;能发FBA的就通过FBA发货。 2. 持续做好产品优化工作&#xff0c;及时留意大环境的变化和平台政策变动。遇到编辑权限受限&#xff0c;可开case咨询或申请…

【数据库】软件测试之MySQL数据库练习题目

有表如下&#xff1a; Student 学生表 SC 成绩表 Course 课程表 Teacher 老师表 每个学生可以学习多门课程&#xff0c;每一个课程都有得分&#xff0c;每一门课程都有老师来教&#xff0c;一个老师可以教多个学生 1、查询姓‘朱’的学生名单 select * from Student whe…

vb机试考试成绩分析与统计,设计与实现(高数概率统计)-141-(代码+程序说明)

转载地址http://www.3q2008.com/soft/search.asp?keyword141 前言: 为何口出狂言,作任何VB和ASP的系统, 这个就是很好的一个证明 :) 又有些狂了... 数据库操作谁都会,接触的多了也没什么难的,VB编程难在哪?算法上,这个是一个算法题的毕业设计,里面涉及到对试卷的 平均分,最…

AI编程已有公司纳入绩效,你的AI编程工具是什么?

自从ChatGPT带动全球AI热潮&#xff0c;AI席卷着各行各业。编程界也不例外&#xff0c;最出名的摸过OpenAI与GitHub联合开发的Github Copilot。Github Copilot带动了一大堆AI编程工具的出现。后来Github Copilot付费了&#xff0c;再加上网络方面的问题&#xff0c;在国内使用G…

基于PHP的店家服务与管理交互平台

目 录 摘 要 I Abstract II 引 言 1 1相关技术 3 1.1 PHP 3 1.2 ThinkPHP框架 3 1.2.1 Struts结构 3 1.2.2 MVC 3 1.2 Tomcat服务器 3 1.3 MySQL数据库 3 1.4 LayUI框架 4 1.5 ECharts 4 1.6 本章小结 4 2 系统分析 5 2.1 功能需求 5 2.2 用例分析 6 2.3 非功能需求 8 2.4 本章…

MySQL--索引类型详解

索引的类型 主键索引&#xff1a; PRIMARY KEY&#xff0c;当一张表的某个列是主键的时候&#xff0c;该列就是主键索引&#xff0c;一张表只允许有一个主键索引&#xff0c;主键所在的列不能为空。 创建主键索引的SQL语法&#xff1a; # 给user表中的id字段创建名为id_ind…

【Datawhale学习笔记】从大模型到AgentScope

从大模型到AgentScope AgentScope是一款全新的Multi-Agent框架&#xff0c;专为应用开发者打造&#xff0c;旨在提供高易用、高可靠的编程体验&#xff01; 高易用&#xff1a;AgentScope支持纯Python编程&#xff0c;提供多种语法工具实现灵活的应用流程编排&#xff0c;内置…

数字化车间MES管理系统如何降低如何降低企业生产成本

数字工厂管理系统在降低制造企业生产成本方面发挥了重要的作用。通过优化物流和信息流&#xff0c;实现生产过程的自动化、智能化和可视化&#xff0c;数字工厂管理系统将从三个方面来降低生产成本。 1、数字工厂管理系统可以通过减少库存量来降低企业的生产成本。数字工厂管理…

GEE:计算一个遥感影像的空像素占比

作者:CSDN @ _养乐多_ 本文将介绍,如何在 Google Earth Engine (GEE) 平台计算一个遥感影像的空像素占比,其中,包含获取研究区内所有像素的总数的代码,以及获取非空像素的总数的代码。 结果如下图所示, 文章目录 一、核心函数1.1 获取研究区内所有像素的总数1.2 获取非…

【面试精讲】Java线程6种状态和工作原理详解,Java创建线程的4种方式

Java线程6种状态和工作原理详解&#xff0c;Java创建线程的4种方式 目录 一、Java线程的六种状态 二、Java线程是如何工作的&#xff1f; 三、BLOCKED 和 WAITING 的区别 四、start() 和 run() 源码分析 五、Java创建线程的所有方式和代码详解 1. 继承Thread类 2. 实现…

管理类联考-复试-管理类知识-其他常见词汇

文章目录 其他常见词汇营销4P、营销4C营销STP理论破窗效应价格歧视/区别定价定价策略——撇脂定价策略定价策略——渗透定价策略 心理账户机会成本看不见的手市场失灵马太效应鲶鱼效应禀赋效应&#xff08;马克杯实验&#xff09;羊群效应帕累托原则长尾理论 其他常见词汇 营销…

安装Mysql时报错[Warning] TIMESTAMP with implicit DEFAULT

win10安装mysql5.7.26(免安装版本)过程中 在执行mysqld --initialize命令时 报错&#xff1a; [Warning]解决方法&#xff1a; [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see document…

LINE社群运营教学

LINE 社群就是一个大型的公开聊天室&#xff0c;通过LINE社群不需要将对方添加为好友就可以聊天。它主要是以「兴趣」作为区分&#xff0c;所以商家可以在社群中找到不少潜在客户。尤其是面向台湾、日本、泰国这些地区的商家&#xff0c;LINE在这些地区的普及度很高&#xff0c…