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

2024-03-04 15:12

本文主要是介绍复合式统计图绘制方法(4),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

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

本方法采用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 ;

 57215fe215644de4af7e67a881730dcc.png

//*************************  
compound4 (){

 //复合式统计图 4  堆叠式饼图加条形图
      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 

//图例样本值:input data   
       cs.SetFillMode (1);//0不填色,1填色
       dx=360;  dy=280 ;   r=210;  //center, radius
 //分组 4 。data : 计划p(n) 4 ,完成 p1(n)  4 
     p[1]=180; p[2]=170; p[3]=160 ;  p[4]=150;  //计划
     p1[1]=190;   p1[2]=180; 
     p1[3]=165 ;  p1[4]=145;  //完成
 
  //复合式统计图样例:
  //图例 (堆叠式饼图 加 条形图)
      cs.SetColor(255,250,230,240);
      cs.DrawCircle(dx,dy,190);    //center 图案底色
           cs.SetStrokeWidth(1);    //线
     for (i=1; i<=8 ; i++){   //底图雷达线
            a=pi/360*i*90 ;     //720度八分线
            cs.SetColor(255,250,0,0); //设色
            x0=(float)(195*cos (a))+dx;     //r=radius
            y0=(float)(- 195*sin (a))+dy;  
            cs.DrawLine (dx,dy,x0,y0) ;    }  //八分线
        cs.SetTextStyle (1);  //粗体字
        cs.SetTextSize (22);
        cs.SetColor(255,0,0,250);
        cs.DrawText ("Group 完成",48,90);
        cs.DrawText (" A",45,128);
        cs.DrawText (" B",45,168);
        cs.DrawText (" C",45,208);
        cs.DrawText (" D",45,248);
        cs.DrawText ("计划 ",608,260);

 //绘制饼图,以分样圆面积来表示量
            cs.SetStrokeWidth(2);    //线
    for (n=1; n<=4 ; n++){   //data=3
           r=210-n*30 ;     //r=radius
           pn=p1[n]/2*72/10+180;     //12点方向为0位
     for (i=180 ; i<=pn; i++){  //画图案 颜色可自定
           a=pi/360*i ;  
       if (n==1) cs.SetColor(205,190,230,250); //设色
       if (n==2) cs.SetColor(205,170,210,250);
       if (n==3) cs.SetColor(205,150,190,250);
       if (n==4) cs.SetColor(205,130,170,250);
           x0=(float)(r*cos (a))+dx;     //r=radius
           y0=(float)(- r*sin (a))+dy;    //逆时针
   cs.DrawRect (75,n*40+65,155,n*40+95); //色标
   cs.DrawLine (dx,dy,x0,y0) ;  //绘出图案,动画式显示
  
     //* print data as "87%",  加"%"
     //* input data 转换,百分比计算
         ppn=p1[n]*100/p[n] ;     //比值 %
         ppn=(int)ppn ;
            ss1=doubleToString (ppn)+"%" ;       //% 
            ss2=intToString (p1[n]) ;     //完成样本值
            cs.SetTextSize (20);
            cs.SetColor(255,120,50,250);
                 tb=0 ;
            if (ppn<100) tb=10 ;   //tab 居中或右齐
       cs.DrawText (ss1,80+tb,n*40+85);
       cs.DrawText (ss2,dx-40,dy-185+n*30);
  
            x1=630 ;    y1=90 ;    //绘制计划条形图
            x2=x1-p[n]+i/5 ;  y2=n*35+y1 ;
            cs.SetColor(155,250,200,230);
            cs.DrawCircle (x2+15,y2-15,15) ;  

              cs.SetColor(255,0,0,250);
         ss3=intToString (p[n]) ;     //计划样本值
         cs.DrawText (ss3,610,y2-10);   
              cs.Update () ;    }      }
 
            cs.SetStrokeWidth(1);
     for (i=1; i<=8 ; i++){   //底图标志线
            a=pi/360*i*90 ;     //720度八分线
            cs.SetColor(255,250,0,0); //设色
            x0=(float)(195*cos (a))+dx;     //r=radius
            y0=(float)(- 195*sin (a))+dy;  
            cs.DrawLine (dx,dy,x0,y0) ;    }  //八分线

//题标:  艺术立体字制作
        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 (42);
         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 ();
}//compound4 ()

 

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

这篇关于复合式统计图绘制方法(4)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施:

webm怎么转换成mp4?这几种方法超多人在用!

webm怎么转换成mp4?WebM作为一种新兴的视频编码格式,近年来逐渐进入大众视野,其背后承载着诸多优势,但同时也伴随着不容忽视的局限性,首要挑战在于其兼容性边界,尽管WebM已广泛适应于众多网站与软件平台,但在特定应用环境或老旧设备上,其兼容难题依旧凸显,为用户体验带来不便,再者,WebM格式的非普适性也体现在编辑流程上,由于它并非行业内的通用标准,编辑过程中可能会遭遇格式不兼容的障碍,导致操

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

【北交大信息所AI-Max2】使用方法

BJTU信息所集群AI_MAX2使用方法 使用的前提是预约到相应的算力卡,拥有登录权限的账号密码,一般为导师组共用一个。 有浏览器、ssh工具就可以。 1.新建集群Terminal 浏览器登陆10.126.62.75 (如果是1集群把75改成66) 交互式开发 执行器选Terminal 密码随便设一个(需记住) 工作空间:私有数据、全部文件 加速器选GeForce_RTX_2080_Ti

【WebGPU Unleashed】1.1 绘制三角形

一部2024新的WebGPU教程,作者Shi Yan。内容很好,翻译过来与大家共享,内容上会有改动,加上自己的理解。更多精彩内容尽在 dt.sim3d.cn ,关注公众号【sky的数孪技术】,技术交流、源码下载请添加微信号:digital_twin123 在 3D 渲染领域,三角形是最基本的绘制元素。在这里,我们将学习如何绘制单个三角形。接下来我们将制作一个简单的着色器来定义三角形内的像素

Flutter 进阶:绘制加载动画

绘制加载动画:由小圆组成的大圆 1. 定义 LoadingScreen 类2. 实现 _LoadingScreenState 类3. 定义 LoadingPainter 类4. 总结 实现加载动画 我们需要定义两个类:LoadingScreen 和 LoadingPainter。LoadingScreen 负责控制动画的状态,而 LoadingPainter 则负责绘制动画。

【VUE】跨域问题的概念,以及解决方法。

目录 1.跨域概念 2.解决方法 2.1 配置网络请求代理 2.2 使用@CrossOrigin 注解 2.3 通过配置文件实现跨域 2.4 添加 CorsWebFilter 来解决跨域问题 1.跨域概念 跨域问题是由于浏览器实施了同源策略,该策略要求请求的域名、协议和端口必须与提供资源的服务相同。如果不相同,则需要服务器显式地允许这种跨域请求。一般在springbo

AI(文生语音)-TTS 技术线路探索学习:从拼接式参数化方法到Tacotron端到端输出

AI(文生语音)-TTS 技术线路探索学习:从拼接式参数化方法到Tacotron端到端输出 在数字化时代,文本到语音(Text-to-Speech, TTS)技术已成为人机交互的关键桥梁,无论是为视障人士提供辅助阅读,还是为智能助手注入声音的灵魂,TTS 技术都扮演着至关重要的角色。从最初的拼接式方法到参数化技术,再到现今的深度学习解决方案,TTS 技术经历了一段长足的进步。这篇文章将带您穿越时

模版方法模式template method

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/template-method 超类中定义了一个算法的框架, 允许子类在不修改结构的情况下重写算法的特定步骤。 上层接口有默认实现的方法和子类需要自己实现的方法