过年了JAVA类编写烟花爆竹——学习分享下笔者的经验_文伟_新浪博客
代码效果!!
——————————————————
import java.applet.Applet;
import java.applet.AudioClip;
import java.awt.*;
import java.awt.image.MemoryImageSource;
import java.util.Random;
@SuppressWarnings("serial")
public class Test extends Applet implements Runnable {
public Test() {
m_mouseX = 0;
m_mouseY = 0;
m_sleepTime = 5;
isError = false;
isInitialized = false;
rand = new Random();
bits = 20000;
bit_px = new double[bits];
bit_py = new double[bits];
bit_vx = new double[bits];
bit_vy = new double[bits];
bit_sx = new int[bits];
bit_sy = new int[bits];
bit_l = new int[bits];
bit_f = new int[bits];
bit_p = new int[bits];
bit_c = new int[bits];
ru = 50;
rv = 50;
}
public void init() {
String s = getParameter("para_bits");
if (s != null)
bits = Integer.parseInt(s);
s = getParameter("para_max");
if (s != null)
bit_max = Integer.parseInt(s);
s = getParameter("para_blendx");
if (s != null)
ru = Integer.parseInt(s);
s = getParameter("para_blendy");
if (s != null)
rv = Integer.parseInt(s);
s = getParameter("para_sound");
if (s != null)
bit_sound = Integer.parseInt(s);
m_nAppX = getSize().width;
m_nAppY = getSize().height;
m_centerX = m_nAppX / 2;
m_centerY = m_nAppY / 2;
m_mouseX = m_centerX;
m_mouseY = m_centerY;
resize(m_nAppX, m_nAppY);
pixls = m_nAppX * m_nAppY;
pixls2 = pixls - m_nAppX * 2;
pix0 = new int[pixls];
offImage = new MemoryImageSource(m_nAppX, m_nAppY, pix0, 0, m_nAppX);
offImage.setAnimated(true);
dbImg = createImage(offImage);
for (int i = 0; i < pixls; i++)
pix0[i] = 0xff000000;
sound1 = getAudioClip(getDocumentBase(), "firework.au");
sound2 = getAudioClip(getDocumentBase(), "syu.au");
for (int j = 0; j < bits; j++)
bit_f[j] = 0;
isInitialized = true;
start();
}
private boolean stop;
public void run() {
while (!isInitialized)
try {
Thread.sleep(200L);
} catch (InterruptedException interruptedexception) {
}
do {
for (int j = 0; j < pixls2; j++) {
int k = pix0[j];
int l = pix0[j + 1];
int i1 = pix0[j + m_nAppX];
int j1 = pix0[j + m_nAppX + 1];
int i = (k & 0xff0000) >> 16;
int k1 = ((((l & 0xff0000) >> 16) - i) * ru >> 8) + i;
i = (k & 0xff00) >> 8;
int l1 = ((((l & 0xff00) >> 8) - i) * ru >> 8) + i;
i = k & 0xff;
int i2 = (((l & 0xff) - i) * ru >> 8) + i;
i = (i1 & 0xff0000) >> 16;
int j2 = ((((j1 & 0xff0000) >> 16) - i) * ru >> 8) + i;
i = (i1 & 0xff00) >> 8;
int k2 = ((((j1 & 0xff00) >> 8) - i) * ru >> 8) + i;
i = i1 & 0xff;
int l2 = (((j1 & 0xff) - i) * ru >> 8) + i;
int i3 = ((j2 - k1) * rv >> 8) + k1;
int j3 = ((k2 - l1) * rv >> 8) + l1;
int k3 = ((l2 - i2) * rv >> 8) + i2;
pix0[j] = i3 << 16 | j3 << 8 | k3 | 0xff000000;
}
rend();
offImage.newPixels(0, 0, m_nAppX, m_nAppY);
try {
Thread.sleep(m_sleepTime);
} catch (InterruptedException interruptedexception1) {
}
} while (!stop);
}
public void update(Graphics g) {
paint(g);
}
public void paint(Graphics g) {
g.drawImage(dbImg, 0, 0, this);
}
public void start() {
if (isError)
return;
isRunning = true;
if (runner == null) {
runner = new Thread(this);
runner.start();
}
}
@SuppressWarnings("deprecation")
public void stop() {
if (runner != null) {
runner.stop();
runner = null;
}
}
public boolean mouseMove(Event event, int i, int j) {
m_mouseX = i;
m_mouseY = j;
return true;
}
public boolean mouseDown(Event event, int i, int j) {
m_mouseX = i;
m_mouseY = j;
int k = (int) (rand.nextDouble() * 256D);
int l = (int) (rand.nextDouble() * 256D);
int i1 = (int) (rand.nextDouble() * 256D);
int j1 = k << 16 | l << 8 | i1 | 0xff000000;
int k1 = 0;
for (int l1 = 0; l1 < bits; l1++) {
if (bit_f[l1] != 0)
continue;
bit_px[l1] = m_mouseX;
bit_py[l1] = m_mouseY;
double d = rand.nextDouble() * 6.2800000000000002D;
double d1 = rand.nextDouble();
bit_vx[l1] = Math.sin(d) * d1;
bit_vy[l1] = Math.cos(d) * d1;
bit_l[l1] = (int) (rand.nextDouble() * 100D) + 100;
bit_p[l1] = (int) (rand.nextDouble() * 3D);
bit_c[l1] = j1;
bit_sx[l1] = m_mouseX;
bit_sy[l1] = m_nAppY - 5;
bit_f[l1] = 2;
if (++k1 == bit_max)
break;
}
if (bit_sound > 1)
sound2.play();
return true;
}
public boolean mouseExit(Event event, int i, int j) {
m_mouseX = i;
m_mouseY = j;
return true;
}
// (JAVA世纪网,java2000.net)
void rend() {
boolean flag2 = false;
for (int k = 0; k < bits; k++)
switch (bit_f[k]) {
default:
break;
case 1: // '\001'
bit_vy[k] += rand.nextDouble() / 50D;
bit_px[k] += bit_vx[k];
bit_py[k] += bit_vy[k];
bit_l[k]--;
if (bit_l[k] == 0 || bit_px[k] < 0.0D || bit_py[k] < 0.0D || bit_px[k] > (double) m_nAppX
|| bit_py[k] > (double) (m_nAppY - 3)) {
bit_c[k] = 0xff000000;
bit_f[k] = 0;
} else if (bit_p[k] == 0) {
if ((int) (rand.nextDouble() * 2D) == 0)
bit_set((int) bit_px[k], (int) bit_py[k], -1);
} else {
bit_set((int) bit_px[k], (int) bit_py[k], bit_c[k]);
}
break;
case 2: // '\002'
bit_sy[k] -= 5;
if ((double) bit_sy[k] <= bit_py[k]) {
bit_f[k] = 1;
flag2 = true;
}
if ((int) (rand.nextDouble() * 20D) == 0) {
int i = (int) (rand.nextDouble() * 2D);
int j = (int) (rand.nextDouble() * 5D);
bit_set(bit_sx[k] + i, bit_sy[k] + j, -1);
}
break;
}
if (flag2 && bit_sound > 0)
sound1.play();
}
void bit_set(int i, int j, int k) {
int l = i + j * m_nAppX;
pix0[l] = k;
}
private int m_nAppX;
private int m_nAppY;
private int m_centerX;
private int m_centerY;
private int m_mouseX;
private int m_mouseY;
private int m_sleepTime;
private boolean isError;
boolean isRunning;
boolean isInitialized;
Thread runner;
int pix0[];
MemoryImageSource offImage;
Image dbImg;
int pixls;
int pixls2;
Random rand;
int bits;
double bit_px[];
double bit_py[];
double bit_vx[];
double bit_vy[];
int bit_sx[];
int bit_sy[];
int bit_l[];
int bit_f[];
int bit_p[];
int bit_c[];
int bit_max;
int bit_sound;
int ru;
int rv;
AudioClip sound1;
AudioClip sound2;
}
过年了JAVA类编写烟花爆竹——学习分享下笔者的经验_文伟_新浪博客相关推荐
- 过年了JAVA类编写烟花爆竹——学习分享下笔者的经验
代码效果!! ------------------ import java.applet.Applet; import java.applet.AudioClip; import java.awt.* ...
- 模电学习心得(转载)_史蒂文森sun_新浪博客
个人建议:认真分析几个典型电路,主要掌握晶体管的等效模型,以及在电路中怎么等效.其他的都很容易解决了.只要会等效了,模电就是完全是电路的内容.其实一点都不可怕,开始不要太关注乱七八糟的内容,抓住主要的 ...
- 手把手教你做一个新浪博客发布软件JAVA版本(5)--打开博客发布页面并解析博客内容
前言:很多人用新浪博客引流,但是以前可以用api发布,但是现在已经行不通了,市面上也有诸如新浪博客批量发布软件啦,新浪博客批量发帖啦,新浪博客发布软件啊等等的各种工具,但是小心中枪,一 ...
- Java基础部分快速复习(以前复习的时候放在自己的新浪博客上)
工作后Java基本没有用到,有时候自己也会把基础过一遍,下面的链接是以前重温的时候整理的Java基础最核心部分的知识点和代码示例放在自己的新浪博客上,如果以后有需要,直接从这里进入,可以快速复习,节省 ...
- 新浪博客关闭了吗,不能写博文了,提示:系统繁忙,请稍后再试
新浪博客关闭了吗,不能写博文了,提示:系统繁忙,请稍后再试. 不知道你们大家有没有一直是这样,我从去年开始发现就一直是这样的,最近几天基本上每天分不同的时间段去测试,还是发不了文. 不信你们看看我的博 ...
- 手把手教你做一个新浪博客发布软件JAVA版本(4)--打开博客发布页面
前言:很多人用新浪博客引流,但是以前可以用api发布,但是现在已经行不通了,市面上也有诸如新浪博客批量发布软件啦,新浪博客批量发帖啦,新浪博客发布软件啊等等的各种工具,但是小心中枪,一不 ...
- 某人写的openCV学习笔记_拔剑-浆糊的传说_新浪博客
http://blog.csdn.net/thefutureisour 我的OpenCV学习笔记(25):c++版本的高斯混合模型的源代码完全注释 之前看到过C版本的,感觉写的很长,没有仔细看,但是C ...
- JAVA开源学习者_新浪博客
置顶: 导读:zhuoqun原来是雅虎(中国)和淘宝的一名技术工程师,目前正在一家公司做前端工程师.他最近的一篇博客<开发与研发>引发了业界的讨论和思考.在他看来,"程序开发大概 ...
- 【CS231n】十五、深度学习的高效算法和硬件设计_一只神秘的大金毛_新浪博客...
一.大纲 emmm,硬件及算法加速部分是博主实验室的主要研究领域,总算可以多说点体会而不是疯狂翻译和贴图了. 主讲人是韩松,清华电子系本科,Stanford Phd,深鉴科技创始人之一,主要工作在深度 ...
最新文章
- (更新中)篮球相关英语积累与2020年NBA东部决赛:迈阿密热火与波士顿凯尔特人
- iphone看python文件_Python实战 | 只需 ”三步“ 爬取二手iphone手机信息(转发送源码)...
- mysql-启动、关闭与重启
- Web开发中你注意这些前台开发问题了吗?(前台构架篇)
- Python风格总结:数据结构
- php format tool,iFormatTool
- 滴滴 Web 移动端组件库 cube-ui 开源
- RocketMQ之一:RocketMQ整体介绍
- win10安装wsl2和图形化界面
- qq微信淘宝京东自动转链转发机器人MkStone京东淘宝转链助手
- sv信道模型是什么_信道模型(信道模型分类)
- Foxit PDF SDK for iOS--零基础Cordova开发
- ANYCUBIC Photon Mono 4K光固化打印机快速上手(多次试错的经验积累)
- python-web开发(一)知识储备准备
- MySQL中date、datetime、timestamp、time、year的区别
- CRM一站式管理,助力健身会所C位出道!
- 一些受益匪浅的句子,太哲理了
- 我们遇见了一个什么样的张小龙以及他的77条产品原则
- 盒子模型划分网页模块--播放器图标
- android开发实例之minitwitter登录界面+代码,登录界面_记住密码