C语言如何实现一个闪烁的圣诞树
发表于:2025-02-01 作者:千家信息网编辑
千家信息网最后更新 2025年02月01日,小编给大家分享一下C语言如何实现一个闪烁的圣诞树,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!效果图图1 圣诞树下面来看下
千家信息网最后更新 2025年02月01日C语言如何实现一个闪烁的圣诞树
小编给大家分享一下C语言如何实现一个闪烁的圣诞树,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
效果图
图1 圣诞树
下面来看下源码,如下所示:
#include#include #include #include #include #include #define N 15char str[] = {'*', ' ', '@', ' ', '#', ' ', '\'', ' ', '$', ' ', '%', ' ', '&', ' ', '!'}; void color(int a){ SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), a);} void getCoord(double y, double x){ COORD pos = { x,y }; SetConsoleCursorPosition(GetStdHandle(STD_OUTPUT_HANDLE), pos);} void hideCursor(){ CONSOLE_CURSOR_INFO cursor= { 1, 0 }; SetConsoleCursorInfo(GetStdHandle(STD_OUTPUT_HANDLE), &cursor);} void layer(int x, int y, int num, int col) { color(col); getCoord(x, y); int idx = rand()%N; printf("%c", str[idx]); for(int k = 1; k <= num; ++k) { idx = rand()%N; getCoord(x + k - 1, y); printf("%c", str[idx]); for(int i = 1; i <= (k*2-1)/2; i++) { getCoord(x + k - 1, y - i); idx = rand()%N; printf("%c", str[idx]); getCoord(x + k - 1, y + i); idx = rand()%N; printf("%c", str[idx]); } } } void triangle(int x, int y, int num, int col) { getCoord(x, y); color(col); printf("*"); for(int i = 1; i <= num; ++i) { int x1 = x + i; int y1 = y - i; for(int j = 0; j < i * 2 + 1; ++j) { getCoord(x1, y1 + j); printf("*"); } }} void triangleRight(double x, double y, double num, double col) { getCoord(x, y*2); color(col); printf("*"); for(int i = 1; i <= num; ++i) { double x1 = x - i; double y1 = y - i; for(int j = 0; j < i * 2 + 1; ++j) { getCoord(x1 + j, y1 * 2); printf("*"); } }} void triangleLeft(double x, double y, double num, double col) { getCoord(x, y*2); color(col); printf("*"); for(int i = 1; i <= num; ++i) { double x1 = x - i; double y1 = y + i; for(int j = 0; j < i * 2 + 1; ++j) { getCoord(x1 + j, y1 * 2); printf("*"); } }} void rectangle(int x, int y, int h, int w, int col1, int col2) { color(col1); for(int i = 0; i <= h; ++i) { for(int j = 0; j <= w/2; ++j) { getCoord(x + i, y - j); if(i % 3 || j % 2) printf("*"); else { color(col2); printf("!"); color(col1); } getCoord(x + i, y + j); if(i % 3 || j % 2) printf("*"); else { color(col2); printf("!"); color(col1); } } }} int main() { hideCursor(); int colTop = 4; int colMid = 4; int colEnd = 13; while(true) { colTop = colTop == 4 ? 9 : 4; triangleLeft(5, 27.8, 2, colTop); triangleRight(5, 27.8, 2, colTop); Sleep(100); layer(5, 55, 10, 2); layer(9, 55, 16, 2); layer(14, 55, 26, 2); colMid = colMid == 4 ? 5 : 4; triangle(11, 55, 3, colMid); triangle(19, 60, 3, colMid); triangle(29, 42, 3, colMid); triangle(31, 57, 3, colMid); colEnd = colEnd == 13 ? 1 : 13; rectangle(40, 55, 15, 18, 6, colEnd); Sleep(200); } return 0;}
上面便是圣诞树的简单实现,下面来说下原理:
函数 layer 画出树的层次,根据坐标来输出位置;
void layer(int x, int y, int num, int col)
函数 triangle 画出小三角形,作为点缀;
void triangle(int x, int y, int num, int col)
函数 triangleRight 和 triangleLeft 画出圣诞树顶部的蝴蝶结;
void triangleRight(double x, double y, double num, double col);void triangleLeft(double x, double y, double num, double col);
函数 hideCursor 负责隐藏光标;
void hideCursor()
函数 getCoord 负责确定输出字符的位置;
void getCoord(double y, double x)
函数 color 负责设置输出的颜色;
void color(int a)
主函数的原理如下:
void color(int a)
主函数通过一个 while 循环,不断刷新圣诞树和圣诞树点缀的颜色。
以上是"C语言如何实现一个闪烁的圣诞树"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
函数
圣诞树
篇文章
输出
语言
位置
内容
原理
颜色
三角形
不怎么
不断
光标
坐标
大部分
字符
层次
效果
效果图
更多
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
韩城市委网络安全
组装一台工厂服务器
迷你世界怎么把服务器弄崩溃
青冈天气预报软件开发
嘉兴app软件开发项目
北京房价软件开发区
java网络技术编程
塔罗牌算命软件开发
沭阳巨型网络技术哪家好
福建大数据应用移动终端软件开发
网络安全主管助理面试
国资网络安全培训
杭州 串口服务器
普华永道网络安全部管理人员
mt4哪个服务器可以看原油
网页数据库建立
慧与合作软件开发方向
数据库原理范式的判断方法
北大讲课网络安全
软件开发的情况了解
东莞南城飒思网络技术服务部
狼人杀哪个服务器人多
中经网统计统计数据库
战地4服务器管理者乱踢人
盘古网络技术有限
广州有名的网络安全公司
软件开发人员招聘莆田
福建微型软件开发要多少钱
数据库装载dll文件出错
服务器日常运行管理制度执行