泡泡屏保

原创 2007年09月27日 21:52:00
我的网站 :http://www.tigerion.cn
/* 泡泡屏保 */
#include <stdio.h>
#include <graphics.h>
#include <math.h>
#include <stdlib.h>
#include <dos.h>
#include <time.h>
#include <bios.h>
#define MAX 12
typedef struct
  {
     float x,y;
     float  vx,vy;
     int color;
  }ball;
void main()
  {
       int gd=DETECT,gm,i,j,k,t;
       ball ba[MAX];
     
       float dt=7e-2;
       int issuit(ball *,int i);
       void hitpro(ball*,int ,int);
        registerbgidriver(EGAVGA_driver);
          initgraph(&gd,&gm,"");
          srand(time(NULL));
         
          for(i=0;i<MAX;i++)
             {
                   ba[i].x=(rand()%5+1)*116;
                   ba[i].y=(rand()%3+1)*116;
                if (!issuit(ba,i)) {i--; continue;}
                ba[i].vx=rand()%50-25;
                ba[i].vy=rand()%50-25;
                ba[i].color=i+1;
             }
          ba[6].color=14;
          ba[7].color=13;  
         
          while(!bioskey(1))
             {
                for(i=0;i<MAX;i++)
                      {
                           ba[i].x+=ba[i].vx*dt;
                           ba[i].y+=ba[i].vy*dt;
                      }
              for(j=0;j<MAX;j++)
                 {
                    for(k=j+1;k<MAX;k++)  hitpro(ba,j,k);
                     if (ba[j].x<51||ba[j].x>589) ba[j].vx=-ba[j].vx;
                    if (ba[j].y<51||ba[j].y>429) ba[j].vy=-ba[j].vy;
                 }
              cleardevice();
                   for(i=0;i<4*MAX;i++)
                      {
                          t=i%MAX;
                          setcolor(ba[t].color);
                          circle(ba[t].x,ba[t].y,50);
                      }     
                  delay(2000);
             }
        closegraph();    
  }
int issuit( ball *b1,int n)
  {
       int i,a,b,c,d;
          a=b1[n].x;
          b=b1[n].y;
          for(i=0;i<n;i++)
             {
                   c=b1[i].x;
                   d=b1[i].y;
                   if (a==c&&b==d) return 0;
             }
          return 1;  
  } 
void hitpro(ball *ba,int j ,int k )
  {
       float r,a,b,c,d,tx1,tx2,ty1,ty2,tem;
        tem=(ba[k].x-ba[j].x)*(ba[k].x-ba[j].x)+(ba[k].y-ba[j].y)*(ba[k].y-ba[j].y);
        r=sqrt(tem);
        if (r>102.0) return ;
       a=(ba[k].x-ba[j].x)/r;
       b=(ba[k].y-ba[j].y)/r;
       c=-b;
       d=a;
       r=sqrt(c*c+d*d);
       c/=r;
       d/=r;
       tx1=ba[j].vx*a+ba[j].vy*b;
       ty1=ba[j].vx*c+ba[j].vy*d;
       tx2=ba[k].vx*a+ba[k].vy*b;
       ty2=ba[k].vx*c+ba[k].vy*d;
       ba[j].vx=tx2*a+ty1*c;
       ba[j].vy=tx2*b+ty1*d;
       ba[k].vx=tx1*a+ty2*c;
       ba[k].vy=tx1*b+ty2*d;
  } 

我的网站 :http://www.tigerion.cn
 

相关文章推荐

翻出过去的一个多彩泡泡屏保特效(JS+CSS版)

整理文件时翻出一个好久前做的泡泡屏保的特效,纯JS+CSS做的。回想了下,是去年年初时看见XP下那个流行的泡泡屏保,突然想移植到JS版本来。但有做着才发现有不少麻烦的问题解决不好,于是没继续。 ...

仿Win7屏保泡泡移动

一个泡泡的随机运动using System; using System.Collections.Generic; using System.ComponentModel; using System.D...

璇彩泡泡屏保V3.0

  • 2012年11月02日 10:30
  • 577KB
  • 下载

七彩泡泡屏保1.0

  • 2007年05月17日 16:45
  • 308KB
  • 下载

Android FrameWork深入分析DreamManagerService实现自己的系统屏保

Framework分析DreamService,实现自己的系统屏保现在有一个需求是在手机一段时间不用的情况下,显示自己的系统屏保功能 下面是涉及到的代码 /frameworks/base/servi...
  • szqsdq
  • szqsdq
  • 2017年07月03日 18:23
  • 380

璇彩泡泡屏保

  • 2007年06月12日 17:25
  • 382KB
  • 下载

pb七彩泡泡屏保.scr

  • 2012年04月19日 16:58
  • 988KB
  • 下载

做了个屏保,学会了两个api函数

FindWindow,Win32 API函数。   FindWindow函数返回与指定字符创相匹配的窗口类名或窗口名的最顶层窗口的窗口句柄。这个函数不会查找子窗口。   函数原型:   HWND...
  • c0c0cf
  • c0c0cf
  • 2012年06月20日 15:07
  • 589

可以用于XP的音符七彩泡泡屏保

  • 2009年03月24日 21:46
  • 291KB
  • 下载

C#编写的仿屏保的泡泡碰撞源码

  • 2012年12月24日 14:52
  • 1.16MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:泡泡屏保
举报原因:
原因补充:

(最多只允许输入30个字)