统计图扇形图绘制方法

news2024/9/17 7:23:47

统计图扇形图绘制方法
常用的统计图有条形图、柱形图、折线图、曲线图、饼图、环形图、扇形图。
前几类图比较容易绘制,饼图环形图绘制较难。
还有一种扇形图的绘制也较难,扇形图的各个变类,饼图、环形图、半圆图、玫瑰图等都是统计图扇形的变化而产生的类。
不去管这些,今提供扇形图的绘制方法供参考。

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

0183f0df5b234db4b2ffe75c96ccf7dd.png

 

下面是绘制扇形图的代码:
//变量: 可设置成全局变量或私有变量
Canvas cs ;     //画布,绘制图表载体
float pi=3.1415926535 ;
float a ;            //三角函数 sin (a), cos (a), 
float r ;             //圆半径 radius
int i, j, n ;
float x0,y0,x1,y1 ;  //作图坐标
float dx,dy ;             //中心坐标
string ss, ss1, ss2 ;         //打印文字
 int p[6] ;        //set data or  input  data
double pn ;   //显示数据
 
//*************************  
RadarChart9 (){    //9. 雷达图扇形图绘制方法
      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,240,240,250);
      cs.DrawRect (20,20,700,580);   //back 
      cs.SetFillMode (0);//0不填色,1填色
      cs.SetColor (255,0,0,240);
      cs.DrawRect (20,20,700,580);   //框线
      cs.DrawRect (24,24,696,576);   //框线
       cs.SetStrokeWidth(0);    //雷达图底线
              dx=360;  dy=280 ;     //center
      cs.SetFillMode (1);//0不填色,1填色

       cs.SetColor(255,80,20,250);  
            //此底色可采用渐变色
       cs.DrawCircle(dx,dy,215);     //圆心图例底色
 
      for (i=1; i<=11 ; i++){  //可采用底图圆渐变色
              colorb=200-i*25 ;  L=colorb+40 ;
          cs.SetColor(255,80,0,colorb);
          cs.DrawCircle(dx,dy,L);       }  //底图色
               cs.SetColor(255,80,0,40);
           cs.DrawCircle(dx,dy,15);     //圆心补色

          cs.SetTextStyle (1);
          cs.SetStrokeWidth(1);
          cs.SetColor(255,250,0,0);
          cs.SetTextSize (16);
     for (i=1; i<=10 ; i++){   //画标线圆和标值
            a=pi/360*i ;
            x0=(float)(200*cos (a))+dx ;
            y0=(float)(200*sin (a))+dy ;
        cs.SetFillMode (0);//0不填色,1填色
        cs.SetColor(255,250,250,250);
        cs.DrawCircle(dx,dy,i*20);  
            x1=(float)(i*20*cos (a))+dx ;
            y1=(float)(i*20*sin (a))+dy ;
             ss=intToString (i);
         cs.SetFillMode (1);//0不填色,1填色
         cs.SetColor(255,250,250,0);
         cs.DrawText(ss,x1-5,285);         }  

         cs.SetFillMode (1);//0不填色,1填色
         cs.SetStrokeWidth(1);
         cs.SetTextSize (18);
         cs.SetColor(255,250,0,0);
    for (i=0; i<=5 ; i++){   //标线六角射线
          a=pi/360*i*120 ;   
          x0=(float)(220*cos(a))+dx ;
          y0=(float)(-220*sin(a))+dy ;
          cs.DrawLine (x0,y0,dx,dy);   
          a=pi/360*i*120+120 ;       //标字
          x1=(float)(225*cos(a))+dx-5 ;
          y1=(float)(-225*sin(a))+dy+5 ;  //逆时针
               ss=intToString (i+1) ;
          cs.DrawText (ss,x1,y1) ;              }  

   //draw 色标
          cs.SetColor (255,220,200,250);
          cs.DrawRect (550,80,685,180);   //标底
              cs.SetColor (255,250,0,0);
          cs.DrawRect (630,90,670,110);   //red 
          cs.DrawText ("Group A", 560,105) ;                 
              cs.SetColor (255,0,250,0);
          cs.DrawRect (630,120,670,140);   //green
          cs.DrawText ("Group B", 560,135) ;                 
              cs.SetColor (255,250,250,0);
          cs.DrawRect (630,150,670,170);   //yellow 
          cs.DrawText ("Group C", 560,165) ;                 
  
//***************************************
//堆叠式扇形图(雷达图)绘制方法:
//input data :  分三组(Group)
//每组6个分值  ( 平均数、百分数或定量的比值 )
int  p1[6],  p2[6], p3[6] ;
int L ;      //高度,长度

//演示的数据是杜撰的,不代表真实的平均数
        cs.SetStrokeWidth(2);    //雷达图线
        cs.SetFillMode (1);//0不填色,1填色
  //Draw Group 1 *************
     p1[0]=70; p1[1]=85; p1[2]=68; p1[3]=94; 
     p1[4]=60; p1[5]=75; 
    for (n=0; n<=5 ; n++){ //data=6, n=0, 0度点起绘出
            r=p1[n]*2 ;    //半径依数值大小
       for (i= n*120; i<=n*120+80; i++){  
              cs.SetColor(240,250,0,0);
              a=pi/360*i ;     
           x0=(float)(r*cos (a))+dx ;     //r=radius
           y0=(float)(-r*sin (a))+dy ;     //逆时针
           cs.DrawLine (dx,dy,x0,y0);     //draw out
      cs.DrawRect (80,n*25+52,120,n*25+73); //色标
   //** print data as ......
          cs.SetTextStyle (0);
          cs.SetTextSize (18);
          cs.SetColor(255,0,0,250);
          s=intToString(n+1)+" >   "+intToString (p1[n]);
          cs.DrawText (s, 55,70+n*25);
               cs.Update ();     }   }

 //Draw Group 2 ************
     p2[0]=78; p2[1]=65; p2[2]=69; p2[3]=70; 
     p2[4]=80; p2[5]=95; 
    for (n=0; n<=5 ; n++){ //data=6, n=0, 0度点起绘出
            r=p2[n]*2 ;    //半径依数值大小
       for (i= n*120+20; i<=n*120+100; i++){  
              cs.SetColor(180,0,250,0);
              a=pi/360*i ;     
           x0=(float)(r*cos (a))+dx ;     //r=radius
           y0=(float)(-r*sin (a))+dy ;     //逆时针
           cs.DrawLine (dx,dy,x0,y0);     //draw out
      cs.DrawRect (80,n*25+213,120,n*25+233); //色标
   //** print data as ......
          cs.SetTextStyle (0);
          cs.SetTextSize (18);
          cs.SetColor(255,0,0,250);
          s=intToString(n+1)+" >   "+intToString (p2[n]);
          cs.DrawText (s, 55,230+n*25);
               cs.Update ();      }   }

//Draw Group 3  ************
     p3[0]=50;  p3[1]=75; p3[2]=88; p3[3]=85; 
     p3[4]=97;  p3[5]=70; 
     for (n=0; n<=5 ; n++){ //data=6, n=0, 0度点起绘出
            r=p3[n]*2 ;    //半径依数值大小
       for (i= n*120+40; i<=n*120+120; i++){  
              cs.SetColor(110,250,250,0);
              a=pi/360*i ;     
           x0=(float)(r*cos (a))+dx ;     //r=radius
           y0=(float)(-r*sin (a))+dy ;     //逆时针
           cs.DrawLine (dx,dy,x0,y0);     //draw out
      cs.DrawRect (80,n*25+373,120,n*25+393); //色标
   //** print data as ......
          cs.SetTextStyle (0);
          cs.SetTextSize (18);
          cs.SetColor(255,0,0,250);
          s=intToString(n+1)+" >   "+intToString (p3[n]);
          cs.DrawText (s, 55,390+n*25);
               cs.Update ();      }   }

    for (i=1; i<=10 ; i++){   //画标线值
         cs.SetTextSize (16);
         cs.SetColor(255,0,200,250);
         ss=intToString (i) ;
         cs.DrawText(ss,dx+i*20-6,284);         }  

//draw title 打印题标文字
      cs.SetFillMode (1);//0不填色,1填色
      cs.SetTextStyle (1);
      cs.SetStrokeWidth(1);
           cs.SetTextSize (26);
      cs.SetColor(255,0,0,250);   //图标或企业标
      cs.DrawText ("Radar Chart 📊",500,60) ;
      cs.SetTextSize (50);
         ss="统计图  -  扇形图" ;
      cs.SetColor(255,50,120,20);      //立体字
           cs.DrawText (ss,164,534);    //阴影
      cs.SetColor(255,0,250,0);
           cs.DrawText (ss,160,530);    //本字
      cs.SetFillMode (0);//0不填色,1填色
      cs.SetColor(255,250,150,0);
           cs.DrawText (ss,160,530);    //框线
       cs.Update ();
}// RadarChart9 ()

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

k8s-heml管理 17

Helm是Kubernetes 应用的包管理工具&#xff0c;主要用来管理 Charts&#xff0c;类似Linux系统的 yum。Helm Chart 是用来封装 Kubernetes 原生应用程序的一系列 YAML 文件。可以在你部署应用的时候自定义应用程序的一些 Metadata&#xff0c;以便于应用程序的分发。 对于应用…

循环购模式:引领电商新时代,重塑消费者价值

在电子商务的浪潮中&#xff0c;循环购模式以其独特的视角和创新的机制&#xff0c;正引领着电商行业进入一个全新的时代。这种模式不仅重塑了消费者的购物体验&#xff0c;更让消费者在享受购物乐趣的同时&#xff0c;实现了个人财富的增值。 一、循环购模式&#xff1a;重新定…

TT语音×个推:流失预测准确率超90%,撬动存量增长个推GeTui 2024-02-23 09:50 浙江

当移动互联网进入存量时代&#xff0c;如何更高效地进行用户全生命周期管理、提升用户生命周期价值&#xff0c;变得尤为重要。TT语音是国内领先的兴趣社交平台&#xff0c;累计注册用户数高达数亿。为了进一步盘活存量用户价值&#xff0c;TT语音从2019年起便与个推合作&#…

Element Plus 的下拉选择器el-option的字体全部蓝色,全部是选中状态

问题 原因 参考官方&#xff1a; Select 选择器 | Element Plus 解决方案1&#xff1a; 给外层el-select增加一个value-key指定值: value-key"ID" <el-select value-key"ID"ref"productName"v-model"selectedProduct.GOODS_DESC"…

eCharts图表点击事件(柱形、label),获取选择项的下标及值

获取选则项的值的话&#xff0c;打印params就能找到了&#xff0c;故主要说明找到对应下标的情况。 柱形点击事件 简单代码 this.myChart echarts.init(this.$refs.chartbox1); this.myChart.off("click"); this.myChart.on("click", (params) > {c…

4.4 MySQL存储1

1、使用前提 安装MySQL数据库&#xff0c;安装pymysql第三方库。 2、使用连接数据库最初步骤 (1) 声明一个连接对象。使用connect()方法声明一个连接对象conn&#xff0c;参数为数据库的一些信息。依次为主机名、用户名、密码、端口号&#xff1b; (2) 获得游标。使用cursor…

intellij idea创建spring项目时没有java 8

一、 引入 当我们用file–》new–》project创建一个项目时&#xff0c;会遇到下面的情况(如图二所示&#xff09;&#xff0c; 图一 图二 java版本仅有21和17可选&#xff0c;而国内大部分还在用java 8 版本&#xff0c;会导致项目无法启动。 二、解决办法 点击serverUrl进…

mysql-多表查询-外连接

一、外连接查询语法 &#xff08;1&#xff09;左外连接 select 所要查询的内容 from 左表 left outer join 右表 on 条件; &#xff08;2&#xff09;右外连接 select 所要查询的内容 from 左表 right outer join 右表 on 条件; 二、示例 用以下两张表示例 左外连接 右外…

3.测试教程 - 基础篇

文章目录 软件测试的生命周期软件测试&软件开发生命周期如何描述一个bug如何定义bug的级别bug的生命周期如何开始第一次测试测试的执行和BUG管理产生争执怎么办&#xff08;处理人际关系&#xff09; 大家好&#xff0c;我是晓星航。今天为大家带来的是 测试基础 相关的讲解…

戏曲文化苑|戏曲文化苑小程序|基于微信小程序的戏曲文化苑系统设计与实现(源码+数据库+文档)

戏曲文化苑小程序目录 目录 基于微信小程序的戏曲文化苑系统设计与实现 一、前言 二、系统功能设计 三、系统实现 1、微信小程序前台 2、管理员后台 &#xff08;1&#xff09;戏曲管理 &#xff08;2&#xff09;公告信息管理 &#xff08;3&#xff09;公告类型管理…

开源免费大模型框架自己训练可根据关键词提示绘图的软件

开源免费大模型框架自己训练可根据关键词提示绘图的软件!大家都知道&#xff0c;市面上那些可以支持这种业务的大模型都是收费的&#xff0c;如果你是一个资深的大模型爱好者&#xff0c;并且有自己的打算和预算&#xff0c;想自己训练一套属于自己的大模型软件来完成日常的绘图…

什么是MapReduce

1.1 MapReduce到底是什么 Hadoop MapReduce是一个软件框架&#xff0c;基于该框架能够容易地编写应用程序&#xff0c;这些应用程序能够运行在由上千个商用机器组成的大集群上&#xff0c;并以一种可靠的&#xff0c;具有容错能力的方式并行地处理上TB级别的海量数据集。这个定…

编程学习线上提问现场解答流程,零基础学编程从入门到精通

编程学习线上提问现场解答流程 一、前言 之前给大家分享的一款中文编程工具&#xff0c;越来越多的学员使用这个工具学习编程。 在学习中有疑难问题寻求解答流程 1、可以在本平台留言或发私信联系老师 2、可以在群提问及时解答问题 3、通过线上会议的方式&#xff0c;电脑…

2024年必备原型设计工具盘点,助你成为设计大神

原型设计是 UI/UX 设计中至关重要的一步&#xff0c;就像用户体验中的其他环节一样&#xff0c;有无数的原型工具可以帮助你完成原型设计。 如果市场上有太多的原型设计工具让你不知所措&#xff0c;不知道选择哪一个&#xff0c;恭喜你&#xff0c;这个原型设计工具的集合是为…

go-zero微服务入门教程

go-zero微服务入门教程 本教程主要模拟实现用户注册和用户信息查询两个接口。 准备工作 安装基础环境 安装etcd&#xff0c; mysql&#xff0c;redis&#xff0c;建议采用docker安装。 MySQL安装好之后&#xff0c;新建数据库dsms_admin&#xff0c;并新建表sys_user&#…

openEuler安装MySQL客户端、openEuler安装MySQL-client、openEuler部署MySQL-client

MySQL客户端下载链接&#xff1a;https://downloads.mysql.com/archives/community/ mysql-community-client-5.7.30-1.el7.x86_64.rpm mysql-community-common-5.7.30-1.el7.x86_64.rpm mysql-community-libs-5.7.30-1.el7.x86_64.rpm 3个必选 8.0.22以上的版本是4个&…

个人博客系列-项目部署-nginx(3)

使用Nginx uwsgi进行部署django项目 一. 检查项目是否可以运行 启动项目 python manage.py runserver 0.0.0.0:8099输入ip:8099 查看启动页面 出现上述页面表示运行成功 二. 安装uwsgi并配置 2.1 下载uwsgi pip install uwsgi新建文件test.py写入内容&#xff0c;测试一…

Python算法题集_图论(课程表)

Python算法题集_课程表 题207&#xff1a;课程表1. 示例说明2. 题目解析- 题意分解- 优化思路- 测量工具 3. 代码展开1) 标准求解【循环递归全算】2) 改进版一【循环递归缓存】3) 改进版二【循环递归缓存反向计算】4) 改进版三【迭代剥离计数器检测】 4. 最优算法5. 相关资源 本…

GaussDB SQL调优:建立合适的索引

背景 GaussDB是华为公司倾力打造的自研企业级分布式关系型数据库&#xff0c;该产品具备企业级复杂事务混合负载能力&#xff0c;同时支持优异的分布式事务&#xff0c;同城跨AZ部署&#xff0c;数据0丢失&#xff0c;支持1000扩展能力&#xff0c;PB级海量存储等企业级数据库…

Rust之构建命令行程序(四):用TDD(测试-驱动-开发)模式来开发库的功能

开发环境 Windows 11Rust 1.75.0 VS Code 1.86.2 项目工程 这次创建了新的工程minigrep. 用测试-驱动模式来开发库的功能 既然我们已经将逻辑提取到src/lib.rs中&#xff0c;并将参数收集和错误处理留在src/main.rs中&#xff0c;那么为代码的核心功能编写测试就容易多了。我…