统计图玫瑰图绘制方法

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

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

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

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

相关文章

axure9.0 工具使用思考

原型设计软件【AxureRP】快速原型设计工具原型设计软件【AxureRP】快速原型设计工具原型设计软件【AxureRP】快速原型设计工具原型设计软件【AxureRP】快速原型设计工具原型设计软件【AxureRP】快速原型设计工具原型设计软件【AxureRP】快速原型设计工具原型设计软件【AxureRP】…

Kafka3.x进阶

来源&#xff1a;B站 目录 Kafka生产者生产经验——生产者如何提高吞吐量生产经验——数据可靠性生产经验——数据去重数据传递语义幂等性生产者事务 生产经验——数据有序生产经验——数据乱序 Kafka BrokerKafka Broker 工作流程Zookeeper 存储的 Kafka 信息Kafka Broker 总…

预告 | 飞凌嵌入式即将亮相第八届瑞芯微开发者大会(RKDC2024)

2024年3月7~8日&#xff0c;第八届瑞芯微开发者大会&#xff08;RKDC2024&#xff09;将在福州举办&#xff0c;本届大会以“AI芯片AI应用AloT”为主题&#xff0c;邀请各行业的开发者共启数智化未来。 本届大会亮点颇多&#xff0c;不仅有13大芯片应用展示、9场产品和技术论坛…

洛谷 【算法1-2】排序

【算法1-2】排序 - 题单 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 鄙人不才&#xff0c;刷洛谷&#xff0c;迎蓝桥&#xff0c;【算法1-2】排序 已刷&#xff0c;现将 AC 代码献上&#xff0c;望有助于各位 P1271 选举学生会 【深基9.例1】选举学生会 - 洛谷 题目 解答…

YOLOv9 | 利用YOLOv9训练自己的数据集 -> 推理、验证(源码解读 + 手撕结构图)

一、本文介绍 本文给大家带来的是全新的SOTA模型YOLOv9的基础使用教程&#xff0c;需要注意的是YOLOv9发布时间为2024年2月21日&#xff0c;截至最近的日期也没有过去几天&#xff0c;从其实验结果上来看&#xff0c;其效果无论是精度和参数量都要大于过去的一些实时检测模型&…

智能水浸传感器拆解指导,水浸传感器有哪些种类?

很多朋友听说过智能水浸传感器&#xff0c;当我们的厨房或者卫生间发生漏水&#xff0c;只要提前安装放置好一个水浸传感器&#xff0c;哪怕我们身处外地也能发现并及时处理。除此之外&#xff0c;数据中心、机房、仓库、实验室、工厂、档案馆等也是智能水浸传感器的常见应用场…

如何图片无损放大?分享两个无损放大方法

在数字化时代的洪流中&#xff0c;我们时常被细微之处的美丽所打动——那些精致的画面&#xff0c;那些清晰的细节。然而&#xff0c;随着图片的放大&#xff0c;我们常常面临一个难题&#xff1a;清晰度的损失。此时&#xff0c;图片无损放大软件能够在不损失图片质量的前提下…

宝塔面板安装了mysql5.7和phpMyadmin,但是访问phpMyadmin时提示502 Bad Gateway

操作流程截图如下&#xff1a; 原因是没有选择php版本 选择php版本 下一页找到phpMyAdmin&#xff0c;选择设置 目前只有纯净态&#xff0c;说明没有php环境&#xff0c;前去安装php环境 点击安装&#xff0c;选择版本&#xff0c;这里选择的是7.4版本&#xff0c;编译安…

设计模式六:策略模式

1、策略模式 策略模式定义了一系列的算法&#xff0c;并将每一个算法封装起来&#xff0c;使每个算法可以相互替代&#xff0c;使算法本身和使用算法的客户端分割开来&#xff0c;相互独立。 策略模式的角色&#xff1a; 策略接口角色IStrategy&#xff1a;用来约束一系列具体…

抖音爬虫批量视频提取功能介绍|抖音评论提取工具

抖音爬虫是指通过编程技术从抖音平台上获取视频数据的程序。在进行抖音爬虫时&#xff0c;需要注意遵守相关法律法规和平台规定&#xff0c;以确保数据的合法获取和使用。 一般来说&#xff0c;抖音爬虫可以实现以下功能之一&#xff1a;批量视频提取。这个功能可以用于自动化地…

【C++精简版回顾】7.析构函数

1.析构函数 class MM { public:MM() {}MM(const char* a) {name new char[strlen(a)1];strcpy(name, a);cout << name << endl;}~MM() {delete[] name;name nullptr;cout << "调用析构函数" << endl;} private:char* name; }; int main(…

论文摘要翻译 ,论文摘要怎么翻译成英文?

论文摘要翻译在学术论文写作中扮演着至关重要的角色&#xff0c;它如同明灯&#xff0c;引领着读者快速理解论文的核心观点与目的。那么&#xff0c;如何才能将论文摘要翻译得恰到好处呢&#xff1f;这其中又蕴含着怎样的奥秘&#xff1f; 专家指出&#xff0c;摘要作为正式论文…

使用uniapp实现小程序获取wifi并连接

一、背景 因业务需求&#xff0c;需要在小程序实现发现wifi和连接wifi。但由于Andriod和IOS有差异&#xff0c;所以实现起来有所区别。 先看官方文档 https://developers.weixin.qq.com/miniprogram/dev/framework/device/wifi.html 把连接基础流程了解后&#xff0c;发现二者…

Jenkins的使用GIT(4)

Jenkins的使用GIT 20211002 我们使用 Jenkins 集成外部 Git 仓库&#xff0c;实现对真实代码的拉取和构建。在这里&#xff0c;我们选用 Coding/Github/Gitee 等都可以作为我们的代码源 1 生成公钥私钥 首先&#xff0c;我们先来配置公钥和私钥。这是 Jenkins 访问 Git 私有库…

springboot大学生体质测试管理系统源码和论文

大学生体质测试管理系统提供给用户一个简单方便体质测试管理信息&#xff0c;通过留言区互动更方便。本系统采用了B/S体系的结构&#xff0c;使用了java技术以及MYSQL作为后台数据库进行开发。系统主要分为系统管理员、教师和用户三个部分&#xff0c;系统管理员主要功能包括首…

【高德地图】Android高德地图初始化定位并显示小蓝点

&#x1f4d6;第3章 初始化定位并显示小蓝点 ✅第1步&#xff1a;配置AndroidManifest.xml✅第2步&#xff1a;设置定位蓝点✅第3步&#xff1a;初始化定位✅完整代码 ✅第1步&#xff1a;配置AndroidManifest.xml 在application标签下声明Service组件 <service android:n…

主流的开发语言和开发环境介绍

个人浅见&#xff0c;不喜勿喷&#xff0c;谢谢 软件开发是一个涉及多个方面的复杂过程&#xff0c;其中包括选择合适的编程语言和开发环境。编程语言是软件开发的核心&#xff0c;它定义了程序员用来编写指令的语法和规则。而开发环境则提供了编写、测试和调试代码的工具和平台…

Shopee提现有哪些要求?提现到个人账户还是公司账户?站斧浏览器

Shopee提现有哪些要求&#xff1f; 中国内地卖家提现至境内同名对公账户/法定代表人个人账户&#xff0c;支持所有主流银行、大部分农村信用社和村镇银行&#xff0c;部分银行需要提供联行号;中国香港卖家提现或付款到香港或全球银行账户&#xff0c;支持所有主流银行。 Shop…

用友NC65与用友NCC对接集成NC65-凭证列表查询打通凭证新增

用友NC65与用友NCC对接集成NC65-凭证列表查询打通凭证新增 数据源平台:用友NC65 用友NC是为集团与行业企业提供的全线管理软件产品&#xff0c;由亚太本土最大的企业管理软件提供商用友公司研发提供&#xff0c;用友NC率先采用J2EE架构和先进开放的集团级开发平台UAP&#xff0…

适用于生物行业的样本管理系统

在生物样本管理系统的应用中&#xff0c;我们首先需要了解生物样本的特点和要求。生物样本具有多样性和易变性&#xff0c;需要被妥善保存和跟踪&#xff0c;以确保其质量和可用性。 因此&#xff0c;一个有效的生物样本管理系统需要具备以下特点&#xff1a; 全面性&#xff1…