菜鸟奉献你一个520表白神器
爱情总是那么神圣,烂漫,每个人都会有无限的向往,即便是程序员(自我笑下),忽然我想起周星驰的那些话“曾经有一段爱情摆在我面前。。。。。。。。。我希望是一万年”,于是我试着做了表白程序。
实现原理:原理比较的简单,主要是运用windows API来实现,程序初步实现的功能是显示文字,图像,歌曲(重复),燃放烟花(循环),程序的实现过程大概可以描述为烟花燃放的一个过程(初始化,上升,爆炸,循环),具体实现方法不再复述了,代码比较简单。
工具:VS2013 Eaxy(冬至版)[使用TC库,不是VC库,用Eaxy]
主要代码:
#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 // 烟花种类数量宏定义
/***** 结构定义区 **********/
// 烟花结构
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 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);
//setfillstyle(0);
settextstyle(50, 0, "楷体");
setcolor(YELLOW);
outtextxy(480, 100, "My Dear");
outtextxy(400, 200, "愿你悲伤有人分担!");
outtextxy(400, 280, "愿你孤独有人陪伴!");
getchar();
cleardevice();
settextstyle(25, 0, "楷体");
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(700, 660, "——谢新明");
getchar();
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 Init(int i)
{
修改密码qq
// 分别为:烟花中心到图片边缘的最远距离、烟花中心到图片左上角的距离 (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);
发布评论