制作一个钟表

用EasyX制作的一个简易钟表,需设置字符集属性为多字节字符集。效果如下所示:
在这里插入图片描述
GIF图会有些闪动,在实际中这种闪动几乎不可见。

#define  _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<graphics.h>
#include<math.h>
#include<stdlib.h>
#define width   900					//屏幕的宽
#define high    600					//屏幕的高
#define P 3.1415926					//圆周率typedef struct CLOCKDATA
{int center_x , center_y ;		//表盘中心,即针的其起点int secondLong ;				//秒针的长度int secondEnd_x,secondEnd_y;	//秒针终点的位置float secondAngle;				//秒针单位转动角度int minuteLong;					//分针的长度int minuteEnd_x, minuteEnd_y;	//分针终点的位置float minuteAngle;				//分针单位转动角度int hourLong;					//分针的长度int hourEnd_x, hourEnd_y;		//时针终点的位置float hourAngle;				//时针单位转动角度int R_dial;						//表盘半径int scale;						//刻度到表盘中心的距离SYSTEMTIME time;				//系统时间
}Clock;void showDial(Clock *clock);		//打印表盘
void Init(Clock *clock);			//初始化
void UpdatePtrPos(Clock *clock);	//更新指针的位置
void showHour(Clock *clock);		//显示时针
void showMinute(Clock *clock);		//显示分针
void showSecond(Clock *clock);		//显示秒针
void  showTime(Clock *clock);		//显示时间void showDial(Clock *clock)
{setlinecolor(WHITE);									//设置划线颜色circle(clock->center_x, clock->center_y, clock->R_dial);//画表盘的圆//显示0、3、6、9刻度,用黄边红圆表示setfillcolor(RED);setcolor(YELLOW);int cir1_x = clock->center_x;int cir1_y = clock->center_y - clock->secondLong - 25;fillcircle(cir1_x, cir1_y, 5);							//画填充圆setfillcolor(RED);setcolor(YELLOW);int cir2_x = clock->center_x + clock->secondLong + 25;int cir2_y = clock->center_y;fillcircle(cir2_x, cir2_y, 5);setfillcolor(RED);setcolor(YELLOW);int cir3_x = clock->center_x;int cir3_y = clock->center_y + clock->secondLong + 25;fillcircle(cir3_x, cir3_y, 5);setfillcolor(RED);setcolor(YELLOW);int cir4_x = clock->center_x- clock->secondLong - 25;int cir4_y = clock->center_y ;fillcircle(cir4_x, cir4_y, 5);
}void Init(Clock *clock)
{initgraph(width, high);			//生成显示钟表的窗口clock->center_x = width / 2;	//表盘中心坐标clock->center_y = high / 2;clock->secondLong = width / 5;	//秒针长度clock->minuteLong = width / 6;	//分针长度clock->hourLong = width / 7;	//时针长度clock->R_dial = width / 4;		//表盘半径clock->scale = width / 4 + 30;showDial(clock);			
}void  UpdatePtrPos(Clock *clock)
{GetLocalTime(&(clock->time));	//获取时间//秒针转动clock->secondAngle = (float)(clock->time.wSecond * 2 * P / 60);  //根据时间秒数计算出秒针角度clock->secondEnd_x = (int)(clock->center_x + clock->secondLong*sin(clock->secondAngle));//计算秒针终点坐标clock->secondEnd_y = (int)(clock->center_y - clock->secondLong*cos(clock->secondAngle));//分针转动clock->minuteAngle = (float)(clock->time.wMinute * 2 * P / 60);//根据时间分钟数计算出秒针角度clock->minuteEnd_x = (int)(clock->center_x + clock->minuteLong*sin(clock->minuteAngle));clock->minuteEnd_y = (int)(clock->center_y - clock->minuteLong*cos(clock->minuteAngle));//时针转动clock->hourAngle = (float)(clock->time.wHour * 2 * P / 12);//根据时间小时数计算出秒针角度clock->hourEnd_x = (int)(clock->center_x + clock->hourLong*sin(clock->hourAngle));clock->hourEnd_y = (int)(clock->center_y - clock->hourLong*cos(clock->hourAngle));
}void showHour(Clock *clock)  //用红色显示时针
{setlinestyle(PS_SOLID,2);setcolor(RED);line(clock->center_x, clock->center_y, clock->hourEnd_x, clock->hourEnd_y);
}void showMinute(Clock *clock)//用蓝色显示时针
{setlinestyle(PS_SOLID, 2);setcolor(BLUE);line(clock->center_x, clock->center_y, clock->minuteEnd_x, clock->minuteEnd_y);
}void showSecond(Clock *clock)//用白色显示时针
{setlinestyle(PS_SOLID, 2);setcolor(WHITE);line(clock->center_x, clock->center_y, clock->secondEnd_x, clock->secondEnd_y);FlushBatchDraw();Sleep(10);setcolor(BLACK);line(clock->center_x, clock->center_y, clock->secondEnd_x, clock->secondEnd_y);if (clock->time.wSecond == 0)//每到一分钟就清空一次表盘{clearcircle(clock->center_x, clock->center_y, clock->secondLong); }
}void  showTime(Clock *clock)
{char  year[10] = " ", month[10] = " ",day[10] = " ", week[10] = " ";char  hour[10] = " ", minute[10] = " ", second[10] = " ";sprintf(year, "%d /", clock->time.wYear);sprintf(month, "%d /", clock->time.wMonth);sprintf(day, "%d ", clock->time.wDay);sprintf(week, "星期 %d", clock->time.wDayOfWeek);sprintf(hour, "%d 时", clock->time.wHour);if (clock->time.wMinute<10)sprintf(minute, "0%d 分", clock->time.wMinute);elsesprintf(minute, "%d 分", clock->time.wMinute);if (clock->time.wSecond<10)sprintf(second, "0%d 秒", clock->time.wSecond);elsesprintf(second, "%d 秒", clock->time.wSecond);settextstyle(15, 15, "楷体");setcolor(WHITE);outtextxy(clock->center_x - 125, clock->center_y + clock->R_dial + 15, hour);outtextxy(clock->center_x -25, clock->center_y + clock->R_dial + 15, minute);outtextxy(clock->center_x +75, clock->center_y + clock->R_dial + 15, second);outtextxy(clock->center_x - 150, clock->center_y + clock->R_dial + 50,year);outtextxy(clock->center_x - 50, clock->center_y + clock->R_dial + 50,month);outtextxy(clock->center_x +50, clock->center_y + clock->R_dial + 50,day);outtextxy(clock->center_x + 150, clock->center_y + clock->R_dial + 50, week);if (clock->time.wMilliseconds == 0)//每到一秒就清空一次显示时间的区域{clearrectangle(clock->center_x - 160, clock->center_y + clock->R_dial + 5, clock->center_x + 250, clock->center_y + clock->R_dial + 70);}}int  main()
{Clock clock;Init(&clock);while (1){UpdatePtrPos(&clock); //更新钟表时分秒针位置showSecond(&clock);showMinute(&clock);showHour(&clock);showTime(&clock);}EndBatchDraw();system("pause");return  0;
}

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

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

相关文章

趣谈MySQL历史,以及MariaDB初体验

作者 | 王磊来源 | Java中文社群&#xff08;ID&#xff1a;javacn666&#xff09;转载请联系授权&#xff08;微信ID&#xff1a;GG_Stone&#xff09;MySQL 是一个跨世纪的伟大产品&#xff0c;它最早诞生于 1979 年&#xff0c;距今已经有 40 多年的历史了&#xff0c;而如今…

算法图解:如何判断括号是否有效?

作者 | 王磊来源 | Java中文社群&#xff08;ID&#xff1a;javacn666&#xff09;转载请联系授权&#xff08;微信ID&#xff1a;GG_Stone&#xff09;今天要讲的这道题是 bilibili 今年的笔试真题&#xff0c;也是一道关于栈的经典面试题。经过前面文章的学习&#xff0c;我想…

让人省心的事件委托

事件委托:利用冒泡的原理把实践添加到父元素级别上&#xff0c;触发执行效果。 时间委托优点&#xff1a; 1.提高性能&#xff0c;不用for循环遍历所有li&#xff0c;节省性能。 2.新添加的元素还会有原来之前的事件。 先看时间委托提高的性能吧&#xff0c;一个常…

最新版MySQL在MacOS上的实践!

作者 | 王磊来源 | Java中文社群&#xff08;ID&#xff1a;javacn666&#xff09;转载请联系授权&#xff08;微信ID&#xff1a;GG_Stone&#xff09;在 MacOS 上安装最新版的 MySQL 有三种方法&#xff1a;使用 Docker 安装&#xff1b;使用 Homebrew 运行 brew install mys…

忘记MySQL密码怎么办?一招教你搞定!

作者 | 王磊来源 | Java中文社群&#xff08;ID&#xff1a;javacn666&#xff09;转载请联系授权&#xff08;微信ID&#xff1a;GG_Stone&#xff09;在安装完 MySQL 或者是在使用 MySQL 时&#xff0c;最尴尬的就是忘记密码了&#xff0c;墨菲定律也告诉我们&#xff0c;如果…

一文详解「队列」,手撸队列的3种方法!

作者 | 王磊来源 | Java中文社群&#xff08;ID&#xff1a;javacn666&#xff09;转载请联系授权&#xff08;微信ID&#xff1a;GG_Stone&#xff09;本文已收录至我的 Github《算法图解》系列&#xff1a;https://github.com/vipstone/algorithm前面我们介绍了栈&#xff08…

自定义设置一个屏保程序

用C语言写一个简单的窗口程序&#xff0c;目的是生成一个可视化的图形窗口&#xff0c;需要用到EasyX库&#xff0c;可在文章末尾的网盘链接中下载。该程序退出需左击鼠标&#xff0c;否则无法退出。 #include<stdio.h> #include<stdlib.h> #include<windows.h…

漫画:如何找到链表的倒数第n个结点?

————— 第二天 —————什么意思呢&#xff1f;我们以下面这个链表为例&#xff1a;给定链表的头结点&#xff0c;但并不知道链表的实际长度&#xff0c;要求我们找到链表的倒数第n个结点。假设n3&#xff0c;那么要寻找的结点就是元素1&#xff1a;如何利用队列呢&…

cacti添加I/O监控

首先下载snmpdiskio-0.9.6.zip,文件不好找&#xff0c;我已经放在本文章的附件里面。解压snmpdiskio-0.9.6.zip复制partition.xml到cacti/resource/snmp_queries/下面[roottest]# cp partition.xml /home/wwwroot/default/cacti/resource/snmp_queries/分别导入模板文件&#x…

磊哥私藏书单分享,160买400的书!

程序员的节日&#xff08;10.24&#xff09;到了&#xff0c;当当的活动也搞起来了&#xff0c;作为有上进心的你&#xff0c;怎么可能停止学习和进步呢&#xff1f;所以磊哥在当当满 400 元减 200 元的基础上&#xff0c;有要了一个减 40 的劵&#xff0c;也就是只需要花 160 …

linux——回射服务器

回射服务器即客户端发送一段数据给服务器&#xff0c;服务器再将这段数据原封不动的发送给客户端&#xff0c;原理很简单&#xff0c;原理图如下&#xff1a; 以TCP协议为例&#xff0c;客户端、服务器代码如下&#xff1a; ** 服务器&#xff1a; ** #include <stdio.h…

Android 5.0 API 的变化——开发人员注意

Android 5.0 API变化译自 http://developer.android.com/intl/zh-cn/about/versions/android-5.0.html —— By NashLegendSample示例在这里找&#xff1a;https://github.com/googlesamples/原译文在我的github上&#xff1a;https://github.com/NashLegend/ProjectBabel/blob…

Java中的5大队列,你知道几个?

作者 | 王磊来源 | Java中文社群&#xff08;ID&#xff1a;javacn666&#xff09;转载请联系授权&#xff08;微信ID&#xff1a;GG_Stone&#xff09;本文已收录至 https://github.com/vipstone/algorithm 《算法图解》系列。通过前面文章的学习《一文详解「队列」&#xff0…

linux——回射服务器多并发(多进程)

多并发原理如图&#xff0c;多个客户端连接一个服务器&#xff0c;无论哪个客户端发送数据给服务器&#xff0c;服务器都能把数据准确的返回给这个客户端。 在socket编程中&#xff0c;socket这种文件描述符被默认设置为阻塞&#xff0c;故而read函数和accept函数时阻塞函数&a…

算法图解:如何用两个栈实现一个队列?

作者 | 王磊来源 | Java中文社群&#xff08;ID&#xff1a;javacn666&#xff09;转载请联系授权&#xff08;微信ID&#xff1a;GG_Stone&#xff09;本文已收录至 https://github.com/vipstone/algorithm 《算法图解》系列。队列和栈是计算机中两个非常重要的数据结构&#…

「递归算法」看这一篇就够了|多图

前言递归是一种非常重要的算法思想&#xff0c;无论你是前端开发&#xff0c;还是后端开发&#xff0c;都需要掌握它。在日常工作中&#xff0c;统计文件夹大小&#xff0c;解析xml文件等等&#xff0c;都需要用到递归算法。它太基础太重要了&#xff0c;这也是为什么面试的时候…

linux——服务器与客户端实现聊天功能

先联想一下聊天的场景&#xff0c;假设甲和乙在聊天&#xff0c;他们每个人都能够发送给对方一句话甚至多句话&#xff0c;也能接收到对方发来的一句或多句话&#xff0c;也就是说&#xff0c;甲在发送一句话给乙的时候&#xff0c;同时也能接收到乙发来的信息&#xff0c;而且…

有关链表的小技巧,我都给你总结好了

链表链表是数据结构里一个很基础但是又很爱考的线性结构&#xff0c;链表的操作相对来说比较简单&#xff0c;但是非常适合考察面试者写代码的能力&#xff0c;以及对 corner case 的处理&#xff0c;还有指针的应用很容易引起 NPE (null pointer exception)。综合以上原因&…

ActiveReports 9实战教程(1): 手把手搭建环境Visual Studio 2013 社区版

ActiveReports 9刚刚发布3天&#xff0c;微软就发布了 Visual Studio Community 2013 开发环境。Visual Studio Community 2013 提供完整功能的 IDE &#xff0c;可开发 Windows、Android 和 iOS 应用。支持&#xff1a;C, Python, HTML5, JavaScript, 和 C#,VB, F# 语言的开发…

第 1-1 课:Java 程序是如何执行的?

了解任何一门语言的精髓都是先俯览其全貌&#xff0c;从宏观的视角把握全局&#xff0c;然后再深入每个知识点逐个击破&#xff0c;这样就可以深入而快速的掌握一项技能。同样学习 Java 也是如此&#xff0c;本节就让我们先从整体来看一下 Java 中的精髓。 Java 介绍 Java 诞…