资源简介
池塘夜降彩色雨VC++6.0的实现(前提库文件中包含easyx.h文件若没有可在网上下载)
代码片段和文件信息
#include
#include
#include
#include
#include
#include
#define LEN sizeof(struct rainDrop)
#pragma comment ( lib “Winmm.lib“ )
int rainDropNumber=60;
int downSpeed=20;
struct rainDrop *head;
struct rainCircle
{
int x;
int y;
int r;
int curR;
int rainCircleStep;
};
struct rainDrop
{
int startX;
int startY;
int endY;
int curX;
int curY;
int rainColor;
int rainLineStep;
int rainLineLength;
int status;
struct rainCircle water;
struct rainDrop *next;
};
void initgraphics(void)
{
int gmode gdriver;
gdriver=DETECT;
initgraph(&gdriver&gmode““);
}
struct rainDrop *creatDrop(void)
{
struct rainDrop *p;
p=(struct rainDrop *)malloc(LEN);
p->startX=rand()%640;
p->startY=rand()%430;
p->endY=430+rand()%50;
p->curX=p->startX;
p->curY=p->startY;
p->rainLineStep=8;
p->rainColor=rand()%15+1;
p->rainLineLength=rand()%10+10;
p->status=0;
p->water.x=p->startX;
p->water.y=p->endY;
p->water.r=rand()%40;
p->water.curR=rand()%2;
p->water.rainCircleStep=rand()%2+1;
p->next=NULL;
return(p);
}
void recreatDrop(struct rainDrop *p)
{
p->startX=rand()%640;
p->startY=rand()%430;
p->endY=430+rand()%50;
p->curX=p->startX;
p->curY=p->startY;
p->rainLineStep=8;
p->rainColor=rand()%15+1;
p->rainLineLength=rand()%10+10;
p->status=0;
p->water.x=p->startX;
p->water.y=p->endY;
p->water.r=rand()%40;
p->water.curR=rand()%2;
p->water.rainCircleStep=rand()%2+1;
}
void creatRain(void)
{
struct rainDrop *p1*p2;
int i;
p1=p2=creatDrop();
head=p1;
for(i=0;i {
p2=creatDrop();
p1->next=p2;
p1=p2;
}
}
void updateRainLineData(struct rainDrop *p)
{
if(p->rainLineStep%5==0)
p->rainLineStep++;
p->curY+=p->rainLineStep;
p->startY=p->curY-p->rainLineLength;
}
void drawRainLine(struct rainDrop *p)
{
setcolor(p->rainColor);
line(p->startXp->startYp->curXp->curY);
}
void clearRainLine(struct rainDrop *p)
{
for(double j=0k=0m=0;j<255k<255m<255;j+=0.1k+=0.2m+=0.3)
p->rainColor = RGB(p->rainColor+j p->rainColor+k p->rainColor+m);
setcolor(p->rainColor);
line(p->startXp->startYp->curXp->curY);
}
void rainDropDown(struct rainDrop *p)
{
if(p->curY>=p->endY)
{
clearRainLine(p);
p->status=1;
}
else
{
clearRainLine(p);
updateRainLineData(p);
drawRainLine(p);
}
}
void updateRainCircleData(struct rainDrop *p)
{
p->water.curR+=p->water.rainCircleStep;
}
void drawRainCircle(struct rainDrop *p)
{
for(double j=0k=0m=0;j<255k<255m<255;j+=0.1k+=0.2m+=0.3)
p->rainColor = RGB(p->rainColor+j p->rainColor+k p->rainColor+m);
setcolor(p->rainColor);
circle(p->water.xp->water.yp->water.curR);
}
void clearRainCircle(struct rainDrop *p)
{
setcolor(BLACK);
circle(p->water.xp->water.yp->water.curR);
}
void fallToWater(struct rainDrop *p)
{
if(p->water.curR>=p
相关资源
- 国际象棋的qt源代码
- C++中头文件与源文件的作用详解
- C++多线程网络编程Socket
- VC++ 多线程文件读写操作
- 利用C++哈希表的方法实现电话号码查
- 移木块游戏,可以自编自玩,vc6.0编写
- C++纯文字DOS超小RPG游戏
- 学校超市选址问题(数据结构C语言版
- VC++MFC小游戏实例教程(实例)+MFC类库
- 数据结构,迷宫问题C语言版源代码
- DSDEMO-C演示(数据结构C语言版 严蔚敏
- 连铸温度场计算程序(C++)
- 6自由度机器人运动学正反解C++程序
- Em算法(使用C++编写)
- libstdc++-4.4.7-4.el6.i686.rpm
- VC++实现CMD命令执行与获得返回信息
- 白话C++(全)
- C++标准库第1、2
- 大数类c++大数类
- C++语言编写串口调试助手
- c++素数筛选法
- C++ mqtt 用法
- 商品库存管理系统 C++ MFC
- c++ 多功能计算器
- C++17 In Detail
- 嵌入式QtC++编程课件
- 颜色识别形状识别STM103嵌入式代码
- 数据结构 图的遍历源代码
- 数据结构实验源代码集
- 实验报告:数据结构长整数四则运算
评论
共有 条评论