C语言绘制雷达图的示例代码

 更新时间:2024年02月22日 08:56:06   作者:老花眼猫  
常用的统计图有条形图、柱形图、折线图、曲线图、饼图、环形图、扇形图,其中还有一种雷达图的绘制也较难,本文为大家提供了雷达图的绘制方法,需要的可以参考下

统计图雷达图绘制方法

常用的统计图有条形图、柱形图、折线图、曲线图、饼图、环形图、扇形图。

前几类图比较容易绘制,饼图环形图绘制较难。

还有一种雷达图的绘制也较难,今提供雷达图的绘制方法供参考。

本方法采用C语言的最基本功能:

( 1) 绘图功能画线,画圆,画长方形。

(2) 界面美工设计,界面文字打印输出。

代码中有详细的注释,通俗易懂,一看就会。

效果图

实现代码

下面是绘制雷达图的代码:

//变量: 可设置成全局变量或私有变量
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 ;   //显示数据

3组样例逐步绘出:

RadarChart (){    //8. 雷达图绘制方法
      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.SetFillMode (1);//0不填色,1填色
      cs.SetStrokeWidth(0);    //雷达图底线
              dx=360;  dy=280 ;     //center

int color ;
      for (i=1; i<=11 ; i++){   //底图圆渐变色
               color=200-i*25 ;  L=color+40 ;
          cs.SetColor(255,80,0,color);
          cs.DrawCircle(dx,dy,L);   }  //底图色
          cs.SetColor(255,80,0,40);  
          cs.DrawCircle(dx,dy,20);     //圆心
 
          cs.SetFillMode (0);//0不填色,1填色
          cs.SetColor(255,250,0,0);
          cs.SetTextStyle (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.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.DrawText(ss,x1-8,275);         }  

          cs.SetFillMode (1);//0不填色,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 ;       //标字
          x1=(float)(230*cos(a))+dx-5 ;
          y1=(float)(-230*sin(a))+dy+5 ;  //逆时针
            ss=intToString (i+1) ;
          cs.DrawText (ss,x1,y1) ;                 }  
               cs.SetTextSize (22);
          cs.DrawText ("1. 语文",610,285) ;                 
          cs.DrawText ("2. 数学",610,310) ;                 
          cs.DrawText ("3. 外语",610,335) ;                 
          cs.DrawText ("4. 政治",610,360) ;                 
          cs.DrawText ("5. 理化",610,385) ;                 
          cs.DrawText ("6. 史地",610,415) ;                 
//********************************
 //雷达图绘制方法:
//input data :  分三组,每组6个分数(或平均分数)
int  p1[6],  p2[6], p3[6] ;
int L ;      //高度,长度
//演示的数据是杜撰的,不代表真实的平均数
            cs.SetStrokeWidth(3);    //雷达图线
 //Draw Group 1 *************
     p1[0]=85;   //0位,起点
     p1[1]=85; p1[2]=68; p1[3]=94; 
     p1[4]=60; p1[5]=75; p1[6]=88;
         cs.SetColor(255,250,0,250);  //group 1
          L=p1[1]*2 ;
          a=pi/360 ;   
          x0=(float)(L*cos(a))+dx ;
          y0=(float)(-L*sin(a))+dy ;
          cs.DrawCircle(x0,y0,5);     
              x2=x0;  y2=y0;
   for (i=1; i<=5; i++){   //六角射线点
          L=p1[i+1]*2 ;
          a=pi/360*i*120 ;   
          x1=(float)(L*cos(a))+dx ;
          y1=(float)(-L*sin(a))+dy ;   //逆时针
           cs.DrawCircle(x1,y1,5);     
           cs.DrawLine (x2,y2,x1,y1);   //连线
             x2=x1;  y2=y1 ;    }
           cs.DrawLine (x2,y2,x0,y0);   //连线0点
           cs.Update ();       
     for (i=1; i<=6; i++){   //打印色标
            ss=intToString (i)+" . "+intToString (p1[i]) ;
            cs.DrawText (ss, 60, i*20+60) ;   }
            cs.DrawText ("Group 1 ", 50, 60) ;   
       sleep (1000);     //逐步展示

 //Draw Group 2 ************
     p2[0]=65 ;
     p2[1]=65; p2[2]=69; p2[3]=70; 
     p2[4]=80; p2[5]=95; p2[6]=78;
          cs.SetColor(255,0,200,0);  //group 2
          L=(int)(p2[1]*2) ;
          a=pi/360 ;   
          x0=(float)(L*cos(a))+dx ;
          y0=(float)(-L*sin(a))+dy ;
          cs.DrawCircle(x0,y0,5);     
              x2=x0;  y2=y0;
   for (i=1; i<=5; i++){   //六角射线点
          L=(int)(p2[i+1]*2) ;
          a=pi/360*i*120 ;   
          x1=(float)(L*cos(a))+dx ;
          y1=(float)(-L*sin(a))+dy ;   //逆时针
           cs.DrawCircle(x1,y1,5);     
           cs.DrawLine (x2,y2,x1,y1);   //连线
             x2=x1;  y2=y1 ;        }
          cs.DrawLine (x2,y2,x0,y0);   //连线回0点
           cs.Update ();       
     for (i=1; i<=6; i++){   //打印色标
            ss=intToString (i)+" . "+intToString (p2[i]) ;
            cs.DrawText (ss, 60, i*20+210) ;   }
            cs.DrawText ("Group 2 ", 50, 210) ;   
      sleep (1000);      //逐步展示

//Draw Group 3  ************
     p3[0]=75 ;
     p3[1]=75; p3[2]=88; p3[3]=85; 
     p3[4]=97; p3[5]=70; p3[6]=68;
          cs.SetColor(255,250,200,0);  //group 3
          L=p3[1]*2 ;
          a=pi/360 ;   
          x0=(float)(L*cos(a))+dx ;
          y0=(float)(-L*sin(a))+dy ;
          cs.DrawCircle(x0,y0,5);     
              x2=x0;  y2=y0;
   for (i=1; i<=5; i++){   //六角射线点
          L=p3[i+1]*2 ;
          a=pi/360*i*120 ;   
          x1=(float)(L*cos(a))+dx ;
          y1=(float)(-L*sin(a))+dy ;   //逆时针
           cs.DrawCircle(x1,y1,5);     
          cs.DrawLine (x2,y2,x1,y1);   //连线
             x2=x1;  y2=y1 ;        }
          cs.DrawLine (x2,y2,x0,y0);   //连线回0点
      for (i=1; i<=6; i++){   //打印色标
            ss=intToString (i)+" . "+intToString (p3[i]) ;
            cs.DrawText (ss, 60, i*20+360) ;   }
            cs.DrawText ("Group 3 ", 50, 360) ;   

//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 ();
}// RadarChart ()

到此这篇关于C语言绘制雷达图的示例代码的文章就介绍到这了,更多相关C语言雷达图内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C语言如何输出中文

    C语言如何输出中文

    这篇文章主要介绍了C语言如何输出中文问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • C++单例模式的几种实现方法详解

    C++单例模式的几种实现方法详解

    这篇文章主要为大家详细介绍了C++单例模式的几种实现方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03
  • C++中const的用法详细总结

    C++中const的用法详细总结

    以下是对C++中const的用法进行了详细的总结分析,需要的朋友可以过来参考下,希望对大家有所帮助
    2013-09-09
  • c语言的cps实现求fibonacci数列示例

    c语言的cps实现求fibonacci数列示例

    这篇文章主要介绍了c语言的cps实现求fibonacci数列示例,需要的朋友可以参考下
    2014-03-03
  • CRC校验原理及其C语言实现详解

    CRC校验原理及其C语言实现详解

    循环冗余校验(Cyclic Redundancy Check, CRC)是一种根据网络数据包或计算机文件等数据产生简短固定位数校验码的一种信道编码技术。本文主要介绍了CRC校验原理及其C语言实现,感兴趣的可以了解一下
    2023-03-03
  • C++入门教程之引用与指针

    C++入门教程之引用与指针

    初学C++时,很容易把指针和引用的用法混在一起,下面这篇文章主要给大家介绍了关于C++入门教程之引用与指针的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-12-12
  • C++ 汉诺塔问题知识点总结

    C++ 汉诺塔问题知识点总结

    在本篇文章里小编给大家整理的是关于C++ 汉诺塔问题知识点内容,有需要的朋友们可以参考下。
    2020-02-02
  • C语言实现图的最短路径Floyd算法

    C语言实现图的最短路径Floyd算法

    这篇文章主要为大家详细介绍了C语言实现图的最短路径Floyd算法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • C++数据结构之AVL树的实现

    C++数据结构之AVL树的实现

    AVL树是高度平衡的而二叉树,它的特点是AVL树中任何节点的两个子树的高度最大差别为1,本文主要给大家介绍了C++如何实现AVL树,需要的朋友可以参考下
    2022-06-06
  • 基于matlab实现DCT数字水印嵌入与提取

    基于matlab实现DCT数字水印嵌入与提取

    数字水印技术是将一些标识信息直接嵌入数字载体当中, 或间接表示在信号载体中, 且不影响原载体的使用价值。本文主要为大家介绍了基于matlab如何实现数字水印的嵌入与提取,感兴趣的可以学习一下
    2022-01-01

最新评论