C++培训:程序员的表白神器!

  这篇代码是程序员的福利,拜拜的一个神奇,各位,拿去,不谢!表白成功啦记得请小编吃饭就是!

  烟花源代码

  #include<graphics.h>

  #include <conio.h>

  #include<math.h>

  #include<time.h>

  #include<stdio.h>

  #include<Mmsystem.h>

  #pragma comment ( lib, "Winmm.lib" )

  /***** 宏定义区 ******/

  #define NUM 13 // 烟花种类数量宏定义

  #define PI 3.1415926548

  /***** 结构定义区 **********/

  // 烟花结构

  struct FIRE

  {

  int r; // 当前爆炸半径

  int max_r; // 爆炸中心距离边缘最大半径

  int x, y; // 爆炸中心在窗口的坐标

  int cen_x, cen_y; // 爆炸中心相对图片左上角的坐标

  int width, height; // 图片的宽高

  int xy[240][240]; // 储存图片像素点

  bool show; // 是否绽放

  bool draw; // 开始输出像素点

  DWORD t1, t2, dt; // 绽放速度

  }Fire[NUM];

  // 烟花弹结构

  struct JET

  {

  int x, y; // 喷射点坐标

  int hx, hy; // 最高点坐标------将赋值给 FIRE 里面的 x, y

  int height; // 烟花高度

  bool shoot; // 是否可以发射

  DWORD t1, t2, dt; // 发射速度

  IMAGE img[2]; // 储存花弹一亮一暗图片

  byte n : 1; // 图片下标

  }Jet[NUM];

  /**** 函数申明区 ****/

  void welcome();

  void Init(int); // 初始化烟花

  void Load(); // 加载烟花图片

  void Shoot(); // 发射烟花

  void Chose(DWORD&); // 筛选烟花

  void Style(DWORD&); // 发射样式

  void Show(DWORD*); // 绽放烟花

  // 主函数

  void main()

  {

  initgraph(1200, 800);

  srand(time(0));

  // 播放背景音乐

  mciSendString("open ./fire/bk.mp3 alias bk", 0, 0, 0);

  mciSendString("play bk repeat", 0, 0, 0);

  welcome();

  DWORD t1 = timeGetTime(); // 筛选烟花计时

  DWORD st1 = timeGetTime(); // 播放花样计时

  DWORD* pMem = GetImageBuffer(); // 获取窗口显存指针

  for (int i = 0; i < NUM; i++) // 初始化烟花

  {

  Init(i);

  }

  Load(); // 将烟花图片信息加载进相应结构中

  BeginBatchDraw(); // 开始批量绘图

  while (!kbhit())

  {

  Sleep(10);

  // 随机选择 4000 个像素点擦除

  for (int clr = 0; clr < 1000; clr++)

  {

  for (int j = 0; j < 2; j++)

  {

  int px1 = rand() % 1200;

  int py1 = rand() % 800;

  if (py1 < 799) // 防止越界

  pMem[py1 * 1200 + px1] = pMem[py1 * 1200 + px1 + 1] = BLACK; // 对显存赋值擦出像素点

  }

  }

  Chose(t1); // 筛选烟花

  Shoot(); // 发射烟花

  Show(pMem); // 绽放烟花

  Style(st1); // 花样发射

  FlushBatchDraw(); // 显示前面的所有绘图操作

  }

  }

  void welcome()

  {

  //setfillstyle(0);

  setcolor(YELLOW);

  for (int i = 0; i < 50; i++)

  {

  int x = 600 + int(180 * sin(PI * 2 * i / 60));

  int y = 200 + int(180 * cos(PI * 2 * i / 60));

  cleardevice();

  settextstyle(i, 0, "楷体");

  outtextxy(x, y, "烟花");

  outtextxy(x, y-50, "制作人:小魔王");

  outtextxy(x - 130, y + 100, "用代码将梦想照进现实!");

  Sleep(25);

  }

  getchar();

  cleardevice();

  settextstyle(25, 0, "楷体");

  outtextxy(400, 150, "什么都没有总比现在的好");

  outtextxy(400, 200, "有一点点希望");

  outtextxy(400, 250, "就得有多少的期望?");

  outtextxy(400, 300, "又他妈的换来多少失望?");

  outtextxy(400, 350, "烟花再美又怎么样?");

  outtextxy(400, 400, "女孩自己要懂得自己挣钱");

  outtextxy(400, 450, "会开车会打扮");

  outtextxy(400, 500, "车子有油");

  outtextxy(400, 550, "手机有电");

  outtextxy(400, 600, "钱包有钱");

  outtextxy(400, 650, "再光鲜亮丽的副驾驶也不及自己握方向盘");

  getchar();

  }

  // 初始化烟花参数

  void Init(int i)

  {

  // 分别为:烟花中心到图片边缘的最远距离、烟花中心到图片左上角的距离 (x、y) 两个分量

  int r[13] = { 120, 120, 155, 123, 130, 147, 138, 138, 130, 135, 140, 132, 155 };

  int x[13] = { 120, 120, 110, 117, 110, 93, 102, 102, 110, 105, 100, 108, 110 };

  int y[13] = { 120, 120, 85, 118, 120, 103, 105, 110, 110, 120, 120, 104, 85 };

  /**** 初始化烟花 *****/

  Fire[i].x = 0; // 烟花中心坐标

  Fire[i].y = 0;

  Fire[i].width = 240; // 图片宽

  Fire[i].height = 240; // 图片高

  Fire[i].max_r = r[i]; // 最大半径

  Fire[i].cen_x = x[i]; // 中心距左上角距离

  Fire[i].cen_y = y[i];

  Fire[i].show = false; // 是否绽放

  Fire[i].dt = 5; // 绽放时间间隔

  Fire[i].t1 = timeGetTime();

  Fire[i].r = 0; // 从 0 开始绽放

  /**** 初始化烟花弹 *****/

  Jet[i].x = -240; // 烟花弹左上角坐标

  Jet[i].y = -240;

  Jet[i].hx = -240; // 烟花弹发射最高点坐标

  Jet[i].hy = -240;

  Jet[i].height = 0; // 发射高度

  Jet[i].t1 = timeGetTime();

  Jet[i].dt = rand() % 10; // 发射速度时间间隔

  Jet[i].n = 0; // 烟花弹闪烁图片下标

  Jet[i].shoot = false; // 是否发射

  }

  // 加载图片

  void Load()

  {

  /**** 储存烟花的像素点颜色 ****/

  IMAGE fm, gm;

  loadimage(&fm, "./fire/flower.jpg", 3120, 240);

  for (int i = 0; i < 13; i++)

  {

  SetWorkingImage(&fm);

  getimage(&gm, i * 240, 0, 240, 240);

  SetWorkingImage(&gm);

  for (int a = 0; a < 240; a++)

  for (int b = 0; b < 240; b++)

  Fire[i].xy[a][b] = getpixel(a, b);

  }

  /**** 加载烟花弹 ************/

  IMAGE sm;

  loadimage(&sm, "./fire/shoot.jpg", 200, 50);

  for (int i = 0; i < 13; i++)

  {

  SetWorkingImage(&sm);

  int n = rand() % 5;

  getimage(&Jet[i].img[0], n * 20, 0, 20, 50); // 暗

  getimage(&Jet[i].img[1], (n + 5) * 20, 0, 20, 50); // 亮

  }

  SetWorkingImage(); // 设置回绘图窗口

  }

  // 在一定范围内筛选可发射的烟花,并初始化发射参数,输出烟花弹到屏幕,播放声音

  void Chose(DWORD& t1)

  {

  DWORD t2 = timeGetTime();

  if (t2 - t1 > 100)

  {

  int n = rand() % 20;

  if (n < 13 && Jet[n].shoot == false && Fire[n].show == false)

  {

  /**** 重置烟花弹,预备发射 *****/

  Jet[n].x = rand() % 1200;

  Jet[n].y = rand() % 100 + 600;

  Jet[n].hx = Jet[n].x;

  Jet[n].hy = rand() % 400;

  Jet[n].height = Jet[n].y - Jet[n].hy;

  Jet[n].shoot = true;

  putimage(Jet[n].x, Jet[n].y, &Jet[n].img[Jet[n].n], SRCINVERT);

  /**** 播放每个烟花弹的声音 *****/

  char c1[50], c2[30], c3[30];

  sprintf(c1, "open ./fire/shoot.mp3 alias s%d", n);

  sprintf(c2, "play s%d", n);

  sprintf(c3, "close n%d", n);

  mciSendString(c3, 0, 0, 0);

  mciSendString(c1, 0, 0, 0);

  mciSendString(c2, 0, 0, 0);

  }

  t1 = t2;

  }

  }

  // 扫描烟花弹并发射

  void Shoot()

  {

  for (int i = 0; i < 13; i++)

  {

  Jet[i].t2 = timeGetTime();

  if (Jet[i].t2 - Jet[i].t1 > Jet[i].dt && Jet[i].shoot == true)

  {

  /**** 烟花弹的上升 *****/

  putimage(Jet[i].x, Jet[i].y, &Jet[i].img[Jet[i].n], SRCINVERT);

  if (Jet[i].y > Jet[i].hy)

  {

  Jet[i].n++;

  Jet[i].y -= 5;

  }

  putimage(Jet[i].x, Jet[i].y, &Jet[i].img[Jet[i].n], SRCINVERT);

  /**** 上升到高度的 3 / 4,减速 *****/

  if ((Jet[i].y - Jet[i].hy) * 4 < Jet[i].height)

  Jet[i].dt = rand() % 4 + 10;

  /**** 上升到最大高度 *****/

  if (Jet[i].y <= Jet[i].hy)

  {

  // 播放爆炸声

  char c1[50], c2[30], c3[30];

  sprintf(c1, "open ./fire/bomb.wav alias n%d", i);

  sprintf(c2, "play n%d", i);

  sprintf(c3, "close s%d", i);

  mciSendString(c3, 0, 0, 0);

  mciSendString(c1, 0, 0, 0);

  mciSendString(c2, 0, 0, 0);

  putimage(Jet[i].x, Jet[i].y, &Jet[i].img[Jet[i].n], SRCINVERT); // 擦掉烟花弹

  Fire[i].x = Jet[i].hx + 10; // 在烟花弹中间爆炸

  Fire[i].y = Jet[i].hy; // 在最高点绽放

  Fire[i].show = true; // 开始绽放

  Jet[i].shoot = false; // 停止发射

  }

  Jet[i].t1 = Jet[i].t2;

  }

  }

  }

  // 显示花样

  void Style(DWORD& st1)

  {

  DWORD st2 = timeGetTime();

  if (st2 - st1 >20000) // 一首歌的时间

  {

  // 心形坐标

  int x[13] = { 60, 75, 91, 100, 95, 75, 60, 45, 25, 15, 25, 41, 60 };

  int y[13] = { 65, 53, 40, 22, 5, 4, 20, 4, 5, 22, 40, 53, 65 };

  for (int i = 0; i < NUM; i++)

  {

  //cleardevice();

  /**** 规律分布烟花弹 ***/

  Jet[i].x = x[i] * 10;

  Jet[i].y = (y[i] + 75) * 10;

  Jet[i].hx = Jet[i].x;

  Jet[i].hy = y[i] * 10;

  Jet[i].height = Jet[i].y - Jet[i].hy;

  Jet[i].shoot = true;

  Jet[i].dt = 7;

  putimage(Jet[i].x, Jet[i].y, &Jet[i].img[Jet[i].n], SRCINVERT); // 显示烟花弹

  /**** 设置烟花参数 ***/

  Fire[i].x = Jet[i].x + 10;

  Fire[i].y = Jet[i].hy;

  Fire[i].show = false;

  Fire[i].r = 0;

  /**** 播放发射声音 ***/

  char c1[50], c2[30], c3[30];

  sprintf(c1, "open ./fire/shoot.mp3 alias s%d", i);

  sprintf(c2, "play s%d", i);

  sprintf(c3, "close n%d", i);

  mciSendString(c3, 0, 0, 0);

  mciSendString(c1, 0, 0, 0);

  mciSendString(c2, 0, 0, 0);

  }

  st1 = st2;

  }

  }

  // 绽放烟花

  void Show(DWORD* pMem)

  {

  // 烟花个阶段绽放时间间隔,制作变速绽放效果

  int drt[16] = { 5, 5, 5, 5, 5, 6, 25, 25, 25, 25, 55, 55, 55, 55, 55 };

  for (int i = 0; i < NUM; i++)

  {

  Fire[i].t2 = timeGetTime();

  // 增加爆炸半径,绽放烟花,增加时间间隔做变速效果

  if (Fire[i].t2 - Fire[i].t1 > Fire[i].dt && Fire[i].show == true)

  {

  if (Fire[i].r < Fire[i].max_r)

  {

  Fire[i].r++;

  Fire[i].dt = drt[Fire[i].r / 10];

  Fire[i].draw = true;

  }

  if (Fire[i].r >= Fire[i].max_r - 1)

  {

  Fire[i].draw = false;

  Init(i);

  }

  Fire[i].t1 = Fire[i].t2;

  }

  // 如果该号炮花可爆炸,根据当前爆炸半径画烟花,颜色值接近黑色的不输出。

  if (Fire[i].draw)

  {

  for (double a = 0; a <= 6.28; a += 0.01)

  {

  int x1 = (int)(Fire[i].cen_x + Fire[i].r * cos(a)); // 相对于图片左上角的坐标

  int y1 = (int)(Fire[i].cen_y - Fire[i].r * sin(a));

  if (x1 > 0 && x1 < Fire[i].width && y1 > 0 && y1 < Fire[i].height) // 只输出图片内的像素点

  {

  int b = Fire[i].xy[x1][y1] & 0xff;

  int g = (Fire[i].xy[x1][y1] >> 8) & 0xff;

  int r = (Fire[i].xy[x1][y1] >> 16);

  // 烟花像素点在窗口上的坐标

  int xx = (int)(Fire[i].x + Fire[i].r * cos(a));

  int yy = (int)(Fire[i].y - Fire[i].r * sin(a));

  // 较暗的像素点不输出、防止越界

  if (r > 0x20 && g > 0x20 && b > 0x20 && xx > 0 && xx < 1200 && yy > 0 && yy < 800)

  pMem[yy * 1200 + xx] = BGR(Fire[i].xy[x1][y1]); // 显存操作绘制烟花

  }

  }

  Fire[i].draw = false;

  }

  }

  }

  这个代码是我朋友的朋友给她的,这个上面我只是改了一段文字,因为我觉得烟花是很漂亮,但是她的美都是很短暂.....

  初学编程可以看看这段话

  请不要做浮躁的人

  很多人都会问,可以自学c/c++吗?

  1、自学首先具备条件是时间充足,兴趣个毅力很关键。

  2、因为你是在家自己练习,没有很好的学习编程的环境和资源,在学习的过程中会走很多弯路,所以兴趣和毅力是支撑你学下去的动力。

  3不要看到别人的回复第一句话就说:给个代码吧!你应该想想为什么。当你自己想

  出来再参考别人的提示,你就知道自己和别人思路的差异。

  4看帮助,不要因为很难而自己是初学者所以就不看;帮助永远是最好的参考手册,

  虽然帮助的文字有时候很难看懂,总觉得不够直观。

  5读懂的书,请仔细看;看不懂的书,请硬着头皮看;别指望看第一遍书就能记住和掌握什么——请看第二遍、第三遍;把在书中看到的有意义的例子扩充;并将其切实的运用到自己的工作中!

时间: 2024-10-12 09:16:00

C++培训:程序员的表白神器!的相关文章

【程序员小幽默5则】程序员的赚钱神器~~~

为什么Java开发人员要戴眼镜? --因为他们无法C# 复制-粘贴,我有神器在手,赚钱就这样简单! 每当我看到有人使用如此多的#话题标签,我就忍不住了... 极客杰作--电脑床 程序员是一个有机体,然后,问题来了... 来源:http://www.evget.com/article/2014/10/28/21749.html 更多幽默:谁说Mac不支持Windows?

调试大叔V1.0.1(2017.09.01)|http/s接口调试、数据分析程序员辅助开发神器

2017.09.01 - 调试大叔 V1.0.1*支持http/https协议的get/post调试与反馈:*可保存请求协议的记录:*内置一批动态参数,可应用于URL.页头.参数:*可自由管理cookie:*支持请求的代理与模拟环境参数设置:*时间戳管理(取网络当前时间戳.转成日期.转成倒计时):*支持拖放文件到本程序窗计算文件的MD5.SHA1.CRC32值:*集成常见编码解码(Ansi与Utf8互转.URL加解密.UniCode转中文);*集成常用符号与其UniCode值:*集成常用数学计算

程序员的表白情书“520”大声喊出来

不如就把这些感性的细枝末节放大吧,用代码写下520的"告白书" "自从遇见了你,就不停地想你. 编一个死循环, 让我们一直走,一直走." "我就是我,是颜色不一样的烟火 每个人都是独一无二的,写给自己的情诗." "我一直在寻找 找到了你 便找到了整个世界" "我是个说谎者 我总是说,我不爱你" "我曾是孤单的飞鸟,飘荡在远方的天空 如今我已飞得太久 才知道你就是春天" "自从遇

520 爱的宣言(程序员的表白)

有趣的事,Python永远不会缺席! 如需转发,请注明出处:小婷儿的python https://www.cnblogs.com/xxtalhr/p/10896958.html 链接:https://pan.baidu.com/s/1qlbyJRijZWXtcCMksdBGHA 提取码:qxyf 复制这段内容后打开百度网盘手机App,操作更方便哦 一.文件运行下载 解压文件,点击运行html文件,即可出现视频效果(右键点击html文件,用txt打开,可以编辑视频中的文字哦) 二.下载 视频效果链

黑客与程序员的必备神器APK-内附下载链接(不定期更新)

集合下载地址: https://tc5.us/dir/20175339-37318146-5207dd 一个简洁的安卓文件管理器 Android Explorecom.amaze.filemanager_54.apk.zip:https://tc5.us/dir/20175339-37318146-5207dd 来自华为的文件管理器 HiDisk com.huawei.hidisk_文件管理.apk.zip:https://tc5.us/dir/20175339-37318146-5207dd

成为专业程序员路上用到的各种优秀资料、神器及框架

最近想着怎么把自己的知识体系进行整理起来,使用思维导图进行描述,对自己以后的发展也有一个更深的认识,更快的提升自己:看到了下面这篇文章,感觉非常实用,从语言到框架都非常全面,自己也可以继续补充,也是对自己知识体系的一个补充吧. 前言 成为一名专业程序员的道路上,需要坚持练习.学习与积累,技术方面既要有一定的广度,更要有自己的深度. 笔者作为一位tool mad,将工作以来用到的各种优秀资料.神器及框架整理在此,毕竟好记性不如烂键盘,此项目可以作为自己的不时之需. 本人喜欢折腾,记录的东西也比较杂

【真正福利】成为专业程序员路上用到的各种优秀资料、神器及框架

转载,原地址:http://www.cnblogs.com/jasondan/p/6380597.html 据说看到好文章不推荐的人,服务器容易宕机!本文版权归翟士丹(Stan Zhai)和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接,否则保留追究法律责任的权利. 好东西不是随便收集下,发篇博文,骗些点赞的!积累了5年多的东西,是时候放出来跟大家见见面了. 或许有的园友在14年的时候收藏过我的一篇"工欲善其事.必先利其器"的博文,时隔3年,已经

成为专业程序员路上有用的各种优秀资料、神器及框架

目录 资料篇 技术站点 必看书籍 大牛博客 GitHub篇 工具篇 平台工具 常用工具 第三方服务 爬虫相关(好玩的工具) 安全相关 Web服务器性能/压力测试工具/负载均衡器 大数据处理/数据分析/分布式工具 Web前端 语言篇 Scala Java Python Swift .NET C & C++ 其他 游戏开发相关 日志聚合,分布式日志收集 RTP,实时传输协议与音视频 资料篇 技术站点 在线学习:Coursera.edX.Udacity.MIT公开课.MOOC学院.慕课网 Hacker

[转载]程序员路上用到的各种优秀资料、神器及框架

好东西不是随便收集下,发篇博文,骗些点赞的!积累了5年多的东西,是时候放出来跟大家见见面了. 或许有的园友在14年的时候收藏过我的一篇"工欲善其事.必先利其器"的博文,时隔3年,已经做了N多更新,那篇文章也已被我删除,迁移至GitHub,重新进行管理. 这篇文章,大家可以推荐.收藏,让更多的人在园内看到,让福利普照. 因为这篇文章,我以后不会更新. 但项目依旧会更新,所以,更好的做法是,请到GitHub上Star:be-a-professional-programmer 前言 成为一名