统计图玫瑰图绘制方法

统计图玫瑰图绘制方法
常用的统计图有条形图、柱形图、折线图、曲线图、饼图、环形图、扇形图。
前几类图比较容易绘制,饼图环形图绘制较难。
还有一种玫瑰图的绘制也较难,今提供玫瑰图的绘制方法供参考。

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

0da18da223cc4fa1a2a6d1567b3f1728.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 ;   //显示数据
 
//*************************  

RoseChart10 (){      //玫瑰图绘制方法
    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);     //圆心图例底色
 int cr,cg,cb;      //* set color(a,r,g,b)
      for (i=1; i<=11 ; i++){  //可采用底图圆渐变色
               cb=200-i*25 ;  
               L=cb+40 ;
          cs.SetColor(255,80,0,cb);
          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.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) ;                 

   
//***************************************
//6个数据的堆叠式  玫瑰图绘制方法:
//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]+120 ;    //半径依数值大小
       for (i= n*120+20; i<=n*120+100; i++){  
              cs.SetColor(200,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+74); //色标
   //** 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]+80 ;    //半径依数值大小
       for (i= n*120+20; i<=n*120+100; i++){  
              cs.SetColor(200,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+234); //色标
   //** 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]+40 ;    //半径依数值大小
       for (i= n*120+20; i<=n*120+100; i++){  
              cs.SetColor(150,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+394); //色标
   //** 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 ();      }   }

       cs.SetFillMode (0);//0不填色,1填色
        cs.SetStrokeWidth(2);
        cs.SetColor(255,250,0,0);    //指标定量线
        cs.DrawCircle(dx,dy,215);  
        cs.SetColor(255,0,250,0);    //指标定量线
        cs.DrawCircle(dx,dy,180);  
        cs.SetColor(255,250,250,0);    //指标定量线
        cs.DrawCircle(dx,dy,140);  

 
//draw title 打印题标文字
      cs.SetFillMode (1);//0不填色,1填色
      cs.SetTextStyle (1);
      cs.SetStrokeWidth(1);
           cs.SetTextSize (26);
      cs.SetColor(255,0,0,250);   //图标或企业标
      cs.DrawText ("Rose 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 ();
}//RoseChart10 ()


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

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

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

相关文章

C++ 学习之Set容器

C++ Set容器构造和赋值 在C++中,std::set是一个用于存储唯一元素的有序集合容器。下面介绍一下std::set容器的构造和赋值操作: 构造 std::set 默认构造函数: std::set<int> mySet; // 创建一个空的set使用初始化列表构造: std::set<int> mySet

测试开源C#人脸识别模块DlibDotNet

百度“C# 换脸”找到参考文献4&#xff0c;发现其中使用DlibDotNet检测并识别人脸&#xff08;之前主要用的是ViewFaceCore&#xff09;&#xff0c;DlibDotNet是Dlib的.net封装版本&#xff0c;后者为开源C工具包&#xff0c;支持机器学习算法、图像处理等算法以支撑各类高级应…

Camtasia Studio2024官方版电脑屏幕录制及视频编辑软件功能使用全面介绍

Camtasia Studio——屏幕录制与视频编辑的全能之选 Camtasia Studio是一款集屏幕录制和视频编辑于一体的强大软件&#xff0c;它凭借直观的操作界面和丰富的功能&#xff0c;成为了许多教育工作者、内容创作者以及视频编辑爱好者的首选工具。 Camtasia2024win-安装包下载如下:…

树-王道-复试

树 1.度&#xff1a; 树中孩子节点个数&#xff0c;所有结点的度最大值为 树的度 2.有序树&#xff1a; 逻辑上看&#xff0c;树中结点的各子树从左至右是有次序的&#xff0c;不能互换。 **3.**树的根节点没有前驱&#xff0c;其他节点只有一个前驱 **4.**所有节点可有零个或…

电路设计(26)——速度表的multisim仿真

1.设计要求 设计一款电路&#xff0c;能够实时显示当前速度。 用输入信号模拟行驶的汽车&#xff0c;信号频率的1hz代表汽车速度的1m/s。最后速度显示&#xff0c;以km/h为单位。 2.电路设计 当输入信号频率为40HZ时&#xff0c;显示的速度应该为144KM/h&#xff0c;仿真结果为…

3D模型库免费下载有什么好处?

对于设计师来说&#xff0c;高质量的免费的3D模型库是必不可少的资源&#xff0c;能帮他们能够获取到各种类型的3D模型&#xff0c;从而提高工作效率&#xff0c;更好的完成作品。那么3D模型库免费下载对设计师有什么好处? 1.降低门槛&#xff1a;对于初学者或预算有限的设计师…

第3.5章:StarRocks数据导入——Broker Load

注&#xff1a;本篇文章阐述的是StarRocks-3.2版本的Broker Load导入机制 一、概述 Broker Load导入方式支持从HDFS类的外部存储系统&#xff08;例如&#xff1a;HDFS、阿里OSS、腾讯COS、华为云OBS等&#xff09;&#xff0c;支持Parquet、ORC、CSV、及 JSON 四种文件格式&a…

git 使用总结

文章目录 git merge 和 git rebasegit mergegit rebase总结 git merge 和 git rebase git merge git merge 最终效果说明&#xff1a; 假设有一个仓库情况如下&#xff0c;现需要进行 merge&#xff1a; merge 操作流程&#xff1a; merge 的回退操作&#xff1a; git reba…

LabVIEW高效核磁测井仪器多线程优化

LabVIEW高效核磁测井仪器多线程优化 为提高核磁测井仪器的测试效率与性能&#xff0c;开发了基于LabVIEW的多线程优化模型。该研究针对传统的核磁测井仪器软件&#xff0c;在多任务调度测试和并行技术需求上存在的效率不高和资源利用率低的问题&#xff0c;提出了一个多线程优…

Python3基础之import和from import的用法和区别

一、模块和包 1、模块 一个 python 的文件就叫做模块&#xff08;module&#xff09;&#xff0c;如 xxx.py。模块就是一组功能的集合体&#xff0c;我们的程序可以导入模块来复用模块里的功能。 2、包 一个包含有__init__.py 文件的目录或文件夹就叫做包(package)。在 pych…

【51单片机】初学者必会项目——按键控制LED流水灯模式(定时器&中断系统的应用)(10)

前言 大家好吖&#xff0c;欢迎来到 YY 滴单片机系列 &#xff0c;热烈欢迎&#xff01; 本章主要内容面向接触过单片机的老铁 主要内容含&#xff1a; 欢迎订阅 YY滴C专栏&#xff01;更多干货持续更新&#xff01;以下是传送门&#xff01; YY的《C》专栏YY的《C11》专栏YY的…

盘点全网好用的ai伪原创工具

在信息内容发展的今天&#xff0c;写作在我们每个人的生活当中息息相关。可能写作对于有的人来说很简单&#xff0c;但对于有些人来说可能也会很难&#xff0c;幸运的是&#xff0c;我们在这个技术发达的今天&#xff0c;对于很多难题都是可以迎刃而解的&#xff0c;即使对于那…

nginx服务基础用法(概念、安装、热升级)

目录 一、I/O模型概述 1、I/O概念 1.1 计算机的I/O 1.2 Linux的I/O 2、零拷贝技术 3、同步/异步&#xff08;消息反馈机制&#xff09; 4、阻塞/非阻塞 5、网络I/O模型 5.1 阻塞型 I/O 模型&#xff08;blocking IO&#xff09; 5.2 非阻塞型 I/O 模型 (nonblocking …

win系统下安装mysql5.7并配置环境变量、设置root用户和服务启动的详细操作教程

本篇文章主要讲解&#xff1a;win系统下安装mysql5.7并配置环境变量、设置root用户和服务启动的详细操作教程 日期&#xff1a;2024年2月22日 作者&#xff1a;任聪聪 一、mysql5.7版本的下载 官方下载地址&#xff1a;https://downloads.mysql.com/archives/community/ 步骤…

Spring框架@Autowired注解进行字段时,使用父类类型接收子类变量,可以注入成功吗?(@Autowired源码跟踪)

一、 前言 平常我们在使用spring框架开发项目过程中&#xff0c;会使用Autowired注解进行属性依赖注入&#xff0c;一般我们都是声明接口类型来接收接口实现变量&#xff0c;那么使用父类类型接收子类变量&#xff0c;可以注入成功吗&#xff1f;答案是肯定可以的&#xff01;…

linux下执行文件包含^M,将window文件格式内容转为linux格式

查看文件内容 cat -v jvm_options 报错信息 ./bin/install-plugin.sh: /bigdata/opt/s/seatunnelsgg/apache-seatunnel-2.3.4/mvnw: /bin/sh^M: bad interpreter: No such file or directory install connector : connector-selectdb-cloud安装工具 yum install -y dos2uni…

一文了解LM317T的引脚介绍、参数解读

LM317T是一种线性稳压器件&#xff0c;它具有稳定输出电压的特性。LM317T可以通过调整其输出电阻来确保输出电压的稳定性&#xff0c;因此被广泛应用于各种电子设备中。 LM317T引脚图介绍 LM317T共有3个引脚&#xff0c;分别是&#xff1a; 输入引脚&#xff08;输入电压V_in&…

本地配置多个git账户及ll设置

本地配置多个git账户 清除全局配置将命令行&#xff0c;切换到ssh目录生成GitLab和Gitee的公钥、私钥去对应的代码仓库添加 SSH Keys添加私钥ll设置 管理密钥验证仓库配置关于gitgitee.com: Permission denied (publickey) 清除全局配置 此步骤可以不做&#xff0c;经测试不影…

测试环境搭建整套大数据系统(六:搭建sqoop)

一&#xff1a;下载安装包 https://archive.apache.org/dist/sqoop/ 二&#xff1a;解压修改配置。 tar -zxvf sqoop-1.4.7.bin__hadoop-2.6.0.tar.gz -C /opt cd /opt mv sqoop-1.4.7.bin__hadoop-2.6.0/ sqoop-1.4.7修改环境变量 vi /etc/profile#SQOOP_HOME export SQOOP_…

成功经营社区店的商业模式与案例分析

随着互联网的发展&#xff0c;线上购物已经成为了人们生活中不可或缺的一部分。然而&#xff0c;实体店依然具有不可替代的优势&#xff0c;特别是在社区环境中。 社区店不仅能够为居民提供便利的购物体验&#xff0c;还能为店主带来稳定的收入。 本人在社区开鲜奶吧已经5年时…