艺术统计图表绘制方法(双环套图)

艺术统计图表绘制方法(双环套图)
在网络科技发展进步的当下,原来一些传统的统计图表都有了进一步的创新。以前企业的PPT都依赖微软的各应用软件来制作图表,现时企业的PPT展示的图表应用不再满足于Excle,Word等的图表绘制方法,进而使用一些第三方应用软件来制作新颖漂亮的图表。由此而有许多图表制作的应用软件面市。这些图表很吸引眼球,我对此也很感兴趣,故试着写了一些各种式样图表的绘制方法,供有同好的同行参考和评论。

新样式的统计图除了有复合式,堆叠式,展开式等等,还加入了新的概念,新的形式。新的名称是信息图表,把各种需要表达的东西,如理念含义,样本值的数量,统计的目的,多重信息等等用图像图表图案组合起来,展现给受众。此类信息图主要是表达,展示和传播。在美工艺术方面创意创新,有许多独到新颖的样式,给人一个赏心悦目的感受。

在统计图表的样本值的计算方面,样本值的量的表现是一个方面,重点是量的对比,以及量的表现方法,这是体现统计图表目的的主要意义。
今在此提供一种新颖漂亮的统计图的绘制方法供参考。

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

de2ef07ba4f64070b1ef4aaec09c7372.png
2cc103b27f174f018571e73ce97f0f17.png

 

//*************************    
ArtGraphics7 (){  //艺术统计图:双环套艺术图
      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,220,250,250);
      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 
 
  //艺术统计图样例: 图例 (双环套艺术图)
        cs.SetFillMode (1);//0不填色,1填色
        cs.SetStrokeWidth(2);    //线
        cs.SetTextStyle (0);  //1 粗体字
 
//绘制双环套图:
      cs.SetStrokeWidth(2);    //线
        cs.SetColor(255,250,0,0);  
        cs.DrawCircle (360, 260, 5);      //圆底色
  
 //先画右上半环
            dx=460 ;  dy=260 ;  r=160 ;
       for (i= 0; i<=360 ; i++ ){  //绘制面上色
                a=pi/360*i ;   
            x0=(float)(r*cos (a))+dx ;     //r=radius
            y0=(float)(-r*sin (a))+dy ;      //逆时针 
            x1=(float)((r-120)*cos (a))+dx ;     //r=radius
            y1=(float)(-(r-120)*sin (a))+dy ;      //逆
            cr=255-i/5 ;  cg=0 ;  cb=200 ;
            cs.SetColor(255,cr, cg, cb );
               cs.DrawLine (x1,y1,x0,y0) ;  
               cs.Update () ;     }   
 //再画左下半环
            dx=260 ;  dy=260 ;  r=160 ;
       for (i= 0; i<=360 ; i++){  //绘制面上色
                a=pi/360*i ;   
            x0=(float)(r*cos (a))+dx ;     //r=radius
            y0=(float)(r*sin (a))+dy ;      //顺时针 
            x1=(float)((r-120)*cos (a))+dx ;     //r=radius
            y1=(float)((r-120)*sin (a))+dy ;      //顺时针
            cr=i/5+180;  cg=0 ;  cb=0 ;
            cs.SetColor(255,cr, cg, cb );
               cs.DrawLine (x1,y1,x0,y0) ;  
               cs.Update () ;     }   
  
   //再画右下半环
            dx=460 ;  dy=260 ;  r=160 ;
       for (i= 0; i<=360 ; i++ ){  //绘制面上色
                a=pi/360*i ;   
            x0=(float)(r*cos (a))+dx ;     //r=radius
            y0=(float)(r*sin (a))+dy ;      //顺时针 
            x1=(float)((r-120)*cos (a))+dx ;     //r=radius
            y1=(float)((r-120)*sin (a))+dy ;      //顺
            cr=i/3+130 ;   cg=i/3+130;  cb=220-i/2 ;
            cs.SetColor(255,cr, cg, cb );
               cs.DrawLine (x1,y1,x0,y0) ;  
               cs.Update () ;     }   
   //再画左上半环
            dx=260 ;  dy=260 ;  r=160 ;
       for (i= 0; i<=360 ; i++ ){  //绘制面上色
                a=pi/360*i ;   
            x0=(float)(r*cos (a))+dx ;     //r=radius
            y0=(float)(-r*sin (a))+dy ;      //逆时针 
            x1=(float)((r-120)*cos (a))+dx ;     //r=radius
            y1=(float)(-(r-120)*sin (a))+dy ;      //逆
            cr=250 ;  cg=250-i/3 ;  cb=0 ;
            cs.SetColor(255,cr, cg, cb);
               cs.DrawLine (x1,y1,x0,y0) ;
              cs.Update () ;    }   //动画式演示绘制

 

              cs.SetColor(255,250,250,250);      
              cs.SetStrokeWidth(5);    
         cs.DrawLine (260,120,260,200) ;
         cs.DrawLine (460,120,460,200) ;
         cs.DrawLine (260,320,260,400) ;
         cs.DrawLine (460,320,460,400) ;
                cs.SetColor(255,0,0,200);      
                cs.SetStrokeWidth(2);    
         cs.DrawLine (260,120,260,200) ;
         cs.DrawLine (460,120,460,200) ;
         cs.DrawLine (260,320,260,400) ;
         cs.DrawLine (460,320,460,400) ;
          cs.SetTextSize (40);
          cs.DrawText ("📱",270,170) ;  
          cs.DrawText ("💻",270,370) ;  
          cs.DrawText ("📺",400,170) ;  
          cs.DrawText ("📷",400,370) ;  

        cs.SetFillMode (1);//0不填色,1填色
            cs.SetColor(255,250,0,0);  
        cs.DrawCircle (140,145, 5);      
        cs.DrawCircle (580,145, 5);     
        cs.DrawCircle (140,375, 5);      
        cs.DrawCircle (580,375, 5);     
        cs.DrawLine (40,145,140,145) ;
        cs.DrawLine (580,145,680,145) ;
        cs.DrawLine (40,375,140,375) ;
        cs.DrawLine (580,375,680,375) ;

              cs.SetTextStyle (0);
              cs.SetTextSize (16);
              cs.SetColor(255,200,0,200);  
         cs.DrawText ("put text here ",150,170) ;  
         cs.DrawText ("text text",150,190) ;  
         cs.DrawText ("text text",150,210) ;  
            cs.SetColor(255,250,250,0);  
         cs.DrawText ("put text here ",150,310) ;  
         cs.DrawText ("text text",150,330) ;  
         cs.DrawText ("text text",150,350) ;  
         cs.DrawText ("put text here ",480,170) ;  
         cs.DrawText ("text text",480,190) ;  
         cs.DrawText ("text text",480,210) ;  
            cs.SetColor(255,0,250,0);  
         cs.DrawText ("put text here ",480,310) ;  
         cs.DrawText ("text text",480,330) ;  
         cs.DrawText ("text text",480,350) ;  


              cs.SetTextStyle (1);
              cs.SetTextSize (24);
            cs.SetColor(255,0,0,200);  
         cs.DrawText ("Text ✏",50,135) ;  
         cs.DrawText ("Text ✏",50,400) ;  
         cs.DrawText ("✏ Text",590,135) ;  
         cs.DrawText ("✏ Text",590,400) ;  
  
             cs.SetColor(255,50,120,200);      
              cs.SetTextSize (40);
          cs.DrawText ("A",124,244) ;  
          cs.DrawText ("D",124,314) ;  
          cs.DrawText ("C",574,244) ;  
          cs.DrawText ("B",574,314) ;  
              cs.SetColor(255,0,250,0);      
          cs.DrawText ("A",120,240) ;  
          cs.DrawText ("D",120,310) ;  
          cs.DrawText ("C",570,240) ;  
          cs.DrawText ("B",570,310) ;  
       cs.SetFillMode (0);//0不填色,1填色
             cs.SetColor(255,250,180,0);      
          cs.DrawText ("A",120,240) ;  
          cs.DrawText ("D",120,310) ;  
          cs.DrawText ("C",570,240) ;  
          cs.DrawText ("B",570,310) ;  
  
  
//题标:  艺术立体字制作
        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,514);    //阴影
      cs.SetColor(255,0,250,0);
           cs.DrawText (ss,110,510);    //本字
      cs.SetFillMode (0);//0不填色,1填色
      cs.SetColor(255,250,150,0);
           cs.DrawText (ss,110,510);    //框线
       cs.Update ();
}//ArtGraphics7 ()
    

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

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

stitcher类实现多图自动拼接

效果展示 第一组&#xff1a; 第二组&#xff1a; 第三组&#xff1a; 第四组&#xff1a; 运行代码 import os import sys import cv2 import numpy as npdef Stitch(imgs,savePath): stitcher cv2.Stitcher.create(cv2.Stitcher_PANORAMA)(result, pano) stitcher.st…

大语言模型(LLM)token解读

1. 什么是token&#xff1f; 人们经常在谈论大模型时候&#xff0c;经常会谈到模型很大&#xff0c;我们也常常会看到一种说法&#xff1a; 参数会让我们了解神经网络的结构有多复杂&#xff0c;而token的大小会让我们知道有多少数据用于训练参数。 什么是token&#xff1f;比…

阿里云 -- 连接云服务器ECS、管理云服务器ECS、WordPress 页面配置

连接云服务器ECS 1. 远程连接云服务器ECS&#xff0c;点击实例最右侧操作列的远程连接按钮&#xff0c;并在弹出的对话框中点击立即登录 2. 登录云服务器ECS&#xff0c;通过密码认证方式&#xff0c;输入用户名和密码 提示&#xff1a;新创建的ECS实例状态即使为运行中&#…

校园app开发流程-uniapp开发-支持APP小程序H5-源码交付-跑腿-二手市场-交友论坛等功能,学校自由选择!

随着科技的不断发展&#xff0c;智慧校园系统和跑腿外卖小程序已经成为当今社会的热门话题。作为未来的重要趋势之一&#xff0c;科技在教育领域中的应用越来越广泛。本文将探讨智慧校园系统和跑腿外卖小程序的开发过程&#xff0c;并阐述如何利用科技“育”见未来 一、智慧校…

vue组件如何使用?

今天我随便试两个组件 第一个轮播图 在minn.js 引入 import { createApp } from vue; import { Swipe, SwipeItem } from vant; const app createApp(); app.use(Swipe); app.use(SwipeItem); <van-swipe class"my-swipe" :autoplay"3000" indica…

STM32学习笔记(6_8)- TIM定时器的编码器接口代码

无人问津也好&#xff0c;技不如人也罢&#xff0c;都应静下心来&#xff0c;去做该做的事。 最近在学STM32&#xff0c;所以也开贴记录一下主要内容&#xff0c;省的过目即忘。视频教程为江科大&#xff08;改名江协科技&#xff09;&#xff0c;网站jiangxiekeji.com 现在开…

os.walk()寻找指定文件

#T2 dcm文件从原位置批量复制到新文件夹F:/467289/ import os import numpy as np path /Users/yxk/Desktop/Debug_test/file# for root, dirs, files in os.walk(path): # for file in files: # if file.endswith(.dcm): # print(file)# def findPa…

微信小程序的页面交互练习——实现比较两数大小功能

前提&#xff1a;配置好页面后 一、在wxml里面搭建好框架&#xff1a; <navigation-bar title"Weixin" back"{{false}}" color"black" background"#FFF"></navigation-bar> <scroll-view class"scrollarea"…

Win11电脑cpu温度过高怎么办呢

Win11电脑cpu温度过高怎么办呢&#xff1f;有时候我们感觉电脑发烫&#xff0c;担心电脑过烫会不会损坏。正常情况下&#xff0c;cpu的温度在45~65度之间&#xff0c;但不排除电脑同时开了太多软件&#xff0c;或者在玩吃鸡、英雄联盟等的大型游戏而导致温度超过85度。只要最高…

设计模式——行为型——策略模式Strategy

Q&#xff1a;策略模式的特点 A&#xff1a; 具体算法从具体的业务方法中独立出来策略模式是同行为的不同实现 Q&#xff1a;什么时候使用策略模式 A&#xff1a;多个if-else使用策略模式 收费对象类 public class CashContext {private CashStrategy cashStrategy;public…

Mysql---安全值守常用语句

文章目录 目录 文章目录 一.用户权限设置 用户设置 元数据查询 Union联合查询 分组查询 字符串函数 总结 一.用户权限设置 用户设置 #用户创建 create user "用户名""%主机名" identified by "密码" #用户删除 drop user 用户名 #用户查询…

LVS负载均衡-DR模式配置

LVS&#xff1a;Linux virtual server ,即Linux虚拟服务器 LVS自身是一个负载均衡器&#xff08;Director&#xff09;&#xff0c;不直接处理请求&#xff0c;而是将请求转发至位于它后端的真实服务器real server上。 LVS是四层&#xff08;传输层 tcp/udp&#xff09;负载均衡…