Win32_GDI_五星红旗绘制
五星红旗画法
- 设置矩形长与高的比为3:2
- 把矩形分为四个相等的长方形

- 把左上角宽分为15份,高分为10份

- 定位大五角星圆心位置,x为宽的5份,y为高的5份
- 计算五角星五个点的坐标
|
void SetFivePoints(POINT* pts,int nCount,int r, int angle, POINT pOrg) { for (int i=0;i<nCount;i++) { //POINT pt1; // 第一个点在正上方,所以角度为90 pts[i].x = pOrg.x + (LONG)(r*cos((angle+i*72 )* PI / 180)); pts[i].y = pOrg.y - (LONG)(r*sin((angle+i*72) * PI / 180)); } } |
pts为点坐标数组
nCount 为数组个数
r 为半径
angle 为角度
pOrg 为圆点坐标
- 用画多边形画五角星
|
POINT pts[5] = { 0 }; SetFivePoints(pts, 5, nHeight*3, 90, pOrg); POINT pNewPts[5] = { pts[0],pts[2],pts[4],pts[1],pts[3] }; Polygon(hdc, pNewPts, 5); |
画线是从第一点到到3,再到5,再到2,再到4的顺序画的,
所有要重新调整数组中坐标位置

- 用相同方法绘制其他四个小五角星
- 第一个小星坐标为宽的10份,高的2份位置, 第一点起始角度为70
第二个小星坐标为宽的12份,高的4份位置,第一点起始角度为120
第三个小星坐标为宽的12份,高的7份位置,起始角度为90
每四个小星坐标为宽的10份,高的9份位置,起始角度为70
|
// 定位第一个小五星圆心 POINT ptOrg1 = { nWidth * 10,nHeight * 2 }; // 调整第一点的起始角度 SetFivePoints(pts, 5, nHeight, 70, ptOrg1); POINT pNewPts1[5] = { pts[0],pts[2],pts[4],pts[1],pts[3] }; Polygon(hdc, pNewPts1, 5); // 定位第二个小五星圆心 ptOrg1 = { nWidth * 12,nHeight * 4 }; SetFivePoints(pts, 5, nHeight, 120, ptOrg1); POINT pNewPts2[5] = { pts[0],pts[2],pts[4],pts[1],pts[3] }; Polygon(hdc, pNewPts2, 5); // 定位第三个小五星圆心 ptOrg1 = { nWidth * 12,nHeight * 7 }; SetFivePoints(pts, 5, nHeight, 90, ptOrg1); POINT pNewPts3[5] = { pts[0],pts[2],pts[4],pts[1],pts[3] }; Polygon(hdc, pNewPts3, 5); // 定位第四个小五星圆心 ptOrg1 = { nWidth * 10,nHeight * 9 }; SetFivePoints(pts, 5, nHeight, 70, ptOrg1); POINT pNewPts4[5] = { pts[0],pts[2],pts[4],pts[1],pts[3] }; Polygon(hdc, pNewPts4, 5); |

最后去掉辅助线
效果为:

Win32_GDI_五星红旗绘制的更多相关文章
- Html5 绘制五星红旗
Html5+JavaScript 在Canvas上绘制五星红旗,具体思路如下图所示: 绘制思路在上图中已有说明,具体代码如下: <script type="text/javascrip ...
- HTML5 canvas 绘制五星红旗
这个例子并不是自己写的,在网上找的案列,仿照写的,,,自己真的公布董这些算法,看完这个例子还是有一点模糊,,, 如果谁看的比较明白,指点一下,,,多谢!!!! <!doctype html> ...
- GDI+绘制五星红旗
五星红旗是由红色背景,加5个黄色五角星组成.绘制一个五星红旗的思路,就是先定义一个五角星的自定义控件,然后通过设置五角星的大小.位置.旋转角度等属性,组合成一个五星红旗. 五角星自定义控件代码: pu ...
- 通过CSS绘制五星红旗
任务要求: 1.创建一个div作为红旗旗面,用CSS控制其比例宽高比为3:2,背景为红色. 2.再创建五个小的div,用CSS控制其大小和位置. 3.用CSS同时控制每个小div的大小.边框和位置,同 ...
- canvas绘制五星红旗
代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8& ...
- HTML5用canvas绘制五星红旗
在HTML5一览中,我们提到html 5被冠以很多高帽,其中最高的一顶.备受争议的就是"Flash杀手".IT评论界老喜欢用这个词了,杀手无处不在.不管是不是杀手,HTML 5引进 ...
- 用canvas绘制标准的五星红旗
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- iOS可视化动态绘制连通图
上篇博客<iOS可视化动态绘制八种排序过程>可视化了一下一些排序的过程,本篇博客就来聊聊图的东西.在之前的博客中详细的讲过图的相关内容,比如<图的物理存储结构与深搜.广搜>.当 ...
- 【AR实验室】OpenGL ES绘制相机(OpenGL ES 1.0版本)
0x00 - 前言 之前做一些移动端的AR应用以及目前看到的一些AR应用,基本上都是这样一个套路:手机背景显示现实场景,然后在该背景上进行图形学绘制.至于图形学绘制时,相机外参的解算使用的是V-SLA ...
- 使用UIBezierPath绘制图形
当需要画图时我们一般创建一个UIView子类, 重写其中的drawRect方法 再drawRect方法中利用UIBezierPath添加画图 UIBezierPath的使用方法: (1)创建一个Bez ...
随机推荐
- Docker安装InfluxDB1.x和InfluxDB2.x以及与SpringBoot整合
两者区别: 1.x 版本使用 influxQL 查询语言,2.x 和 1.8+(beta) 使用 flux 查询语法:相比V1 移除了database 和 RP,增加了bucket. V2具有以下几个 ...
- Freertos学习:在Posix环境仿真FreeRTOS
--- title: rtos-freertos-在Posix环境仿真FreeRTOS date: 2020-06-11 16:22:34 categories: tags: - freertos - ...
- 解码技术债:AI代码助手与智能体的革新之道
技术债 技术债可能来源于多种原因,比如时间压力.资源限制.技术选型不当等.它可以表现为代码中的临时性修补.未能彻底解决的设计问题.缺乏文档或测试覆盖等.虽然技术债可以帮助快速推进项目进度,但长期来看, ...
- 网易数帆实时数据湖 Arctic 的探索和实践
作者 | 蔡芳芳 采访嘉宾 | 马进 网易数帆平台开发专家 数据中台也要从离线为主走向实时化,湖仓一体是第一步. 数据从离线到实时是当前一个很大的趋势,但要建设实时数据.应用实时数据还面临两个难题.首 ...
- ComfyUI进阶:Comfyroll插件 (一)
ComfyUI进阶:Comfyroll插件 (一) 前言: 学习ComfyUI是一场持久战,而Comfyroll Studio 是一款功能强大的自定义节点集合,专为 ComfyUI 用户打造,旨在提供 ...
- AT_abc182_d 题解
洛谷链接&Atcoder 链接 本篇题解为此题较简单做法及较少码量,并且码风优良,请放心阅读. 题目简述 从数轴的原点开始向正方向走. 第一次向前走 \(a_1\) 步,第二次向前走 \(a_ ...
- 前缀函数及 Knuth–Morris–Pratt 算法学习笔记
\(\text{1 引言 Preface}\) 对于形如以下的问题: 给予一个模式串 \(T\) 和主串 \(S\),在主串中寻找 \(T\). 我们称之为字符串匹配. 很显然朴素算法时间复杂度是 \ ...
- hadoop 查看日志
告警和日志信息监控 hadoop集群启动 su - hadoop #切换到hadoop用户 [hadoop@master ~]$ start-all.sh #启动 zookeeper集群启动 zkSe ...
- 【H5】12 表单 其一 第一个表单
本系列的第一篇文章提供了您第一次创建HTML表单的经验, 包括设计一个简单表单,使用正确的HTML元素实现它, 通过CSS添加一些非常简单的样式,以及如何将数据发送到服务器. HTML表单是什么? H ...
- 【FastDFS】环境搭建 02 测试
自带工具测试: 编辑客户端配置文件: vim client.conf 配置完成后,随便上传一个图片到root目录下 运行FastFDS文件上传程序,并将客户端配置文件作为加载参数1,要上传的图片文件位 ...