在书上看到的粒子系统的示例分享给大家参考,希望可以帮助大家学习安卓!
首先是MyRenderer.java
package com.boring.ParticleActivity; import java.nio.ByteBuffer; import java.nio.ByteOrder; import java.nio.FloatBuffer; import java.util.Random; import javax.microedition.khronos.egl.EGLConfig; import javax.microedition.khronos.opengles.GL10; import android.opengl.GLSurfaceView.Renderer; import android.opengl.GLUtils; public class MyRenderer implements Renderer{ private int[] textures = new int[1]; // 随机数 private Random random = new Random(); // 定义最大的粒子数 private static final int MAX_PARTICLES = 1000; // 减速粒子 private float slowdown = 0.5f; // X方向的速度 private float xspeed = 80; // Y方向的速度 private float yspeed = 80; // 沿Z轴缩放 private float zoom = -30.0f; // 循环变量 private int loop; // 创建一个名为Particle的数组,存储MAX_PARTICLES个元素 private Particle particles[] = new Particle[MAX_PARTICLES]; // 存储12种不同颜色 private float colors[][] = { { 1.0f, 0.75f, 0.5f }, { 1.0f, 0.75f, 0.5f }, { 1.0f, 1.0f, 0.5f }, { 0.75f, 1.0f, 0.5f }, { 0.5f, 1.0f, 0.5f }, { 0.5f, 1.0f, 0.75f }, { 0.5f, 1.0f, 1.0f }, { 0.5f, 0.75f, 1.0f }, { 0.5f, 0.5f, 1.0f }, { 0.75f, 0.5f, 1.0f }, { 1.0f, 0.5f, 1.0f }, { 1.0f, 0.5f, 0.75f } }; // vertexBuffer private FloatBuffer vertexBuffer; // texCoordBuffer private FloatBuffer texCoordBuffer; // vertex private float[] vertex = new float[12]; // texCoord private float[] texCoord = new float[8]; // LoadBuffer public void LoadBuffer(GL10 gl) { ByteBuffer vertexByteBuffer = ByteBuffer .allocateDirect(vertex.length * 4); vertexByteBuffer.order(ByteOrder.nativeOrder()); vertexBuffer = vertexByteBuffer.asFloatBuffer(); vertexBuffer.put(vertex); vertexBuffer.position(0); ByteBuffer texCoordByteBuffer = ByteBuffer .allocateDirect(texCoord.length * 4); texCoordByteBuffer.order(ByteOrder.nativeOrder()); texCoordBuffer = texCoordByteBuffer.asFloatBuffer(); texCoordBuffer.put(texCoord); texCoordBuffer.position(0); } public void onDrawFrame(GL10 gl) { // LoadBuffer LoadBuffer(gl); // 清除屏幕和颜色缓存 gl.glClear(GL10.GL_COLOR_BUFFER_BIT | GL10.GL_DEPTH_BUFFER_BIT); // 重置模型变换矩阵 gl.glLoadIdentity(); // 开启顶点纹理状态 gl.glEnableClientState(GL10.GL_VERTEX_ARRAY); gl.glEnableClientState(GL10.GL_TEXTURE_COORD_ARRAY); gl.glVertexPointer(3, GL10.GL_FLOAT, 0, vertexBuffer); gl.glTexCoordPointer(2, GL10.GL_FLOAT, 0, texCoordBuffer); // 循环所有的粒子 for (loop = 0; loop < MAX_PARTICLES; loop++) { // 如果粒子为激活的 if (particles[loop].active) { // 返回X轴的位置 float x = particles[loop].x; // 返回Y轴的位置 float y = particles[loop].y; // 返回Z轴的位置 float z = particles[loop].z + zoom; // 设置粒子颜色 gl.glColor4f(particles[loop].r, particles[loop].g, particles[loop].b, particles[loop].life); // 开始准备绘制"三角地带" texCoordBuffer.clear(); vertexBuffer.clear(); texCoordBuffer.put(1.0f); texCoordBuffer.put(1.0f); vertexBuffer.put(x + 0.5f); vertexBuffer.put(y + 0.5f); vertexBuffer.put(z); texCoordBuffer.put(1.0f); texCoordBuffer.put(0.0f); vertexBuffer.put(x + 0.5f); vertexBuffer.put(y); vertexBuffer.put(z); texCoordBuffer.put(0.0f); texCoordBuffer.put(1.0f); vertexBuffer.put(x); vertexBuffer.put(y + 0.5f); vertexBuffer.put(z); texCoordBuffer.put(0.0f); texCoordBuffer.put(0.0f); vertexBuffer.put(x); vertexBuffer.put(y); vertexBuffer.put(z); // 绘制 gl.glDrawArrays(GL10.GL_TRIANGLE_STRIP, 0, 4); // 更新X坐标的位置 particles[loop].x += particles[loop].xi / (slowdown * 1000); // 更新Y坐标的位置 particles[loop].y += particles[loop].yi / (slowdown * 1000); // 更新Z坐标的位置 particles[loop].z += particles[loop].zi / (slowdown * 1000); // 更新X轴方向速度大小 particles[loop].xi += particles[loop].xg; // 更新Y轴方向速度大小 particles[loop].yi += particles[loop].yg; // 更新Z轴方向速度大小 particles[loop].zi += particles[loop].zg; // 减少粒子的生命值 particles[loop].life -= particles[loop].fade; // 如果粒子生命小于0 if (particles[loop].life < 0.0f) { float xi, yi, zi; xi = xspeed + (float) ((rand() % 60) - 32.0f); yi = yspeed + (float) ((rand() % 60) - 30.0f); zi = (float) ((rand() % 60) - 30.0f); initParticle(loop, random.nextInt(12), xi, yi, zi); } } } // 关闭顶点纹理状态 gl.glDisableClientState(GL10.GL_TEXTURE_COORD_ARRAY); gl.glDisableClientState(GL10.GL_VERTEX_ARRAY); gl.glFinish(); } @Override public void onSurfaceChanged(GL10 gl, int width, int height) { // ratio float ratio; if (height == 0) { height = 1; } ratio = (float) width / (float) height; gl.glViewport(0, 0, (int) width, (int) height); gl.glMatrixMode(GL10.GL_PROJECTION); gl.glLoadIdentity(); gl.glFrustumf(-ratio, ratio, -1, 1, 1.0f, 200.0f); gl.glMatrixMode(GL10.GL_MODELVIEW); // 重置模型矩阵 gl.glLoadIdentity(); } @Override public void onSurfaceCreated(GL10 gl, EGLConfig arg1) { // 黑色背景 gl.glClearColor(0, 0, 0, 0); // 关闭深度测试 gl.glDisable(GL10.GL_DEPTH_TEST); // 阴影平滑 gl.glShadeModel(GL10.GL_SMOOTH); // 启用混合 gl.glEnable(GL10.GL_BLEND); // 精细修正 gl.glHint(GL10.GL_PERSPECTIVE_CORRECTION_HINT, GL10.GL_NICEST); // 启用纹理 gl.glEnable(GL10.GL_TEXTURE_2D); // 创建纹理 gl.glGenTextures(1, textures, 0); // 绑定纹理 gl.glBindTexture(GL10.GL_TEXTURE_2D, textures[0]); // 生成纹理 // GLUtils.texImage2D(GL10.GL_TEXTURE_2D, 0, LoadImage.bitmap, 0); // 线性滤波 gl.glTexParameterf(GL10.GL_TEXTURE_2D, GL10.GL_TEXTURE_MAG_FILTER, GL10.GL_LINEAR); gl.glTexParameterf(GL10.GL_TEXTURE_2D, GL10.GL_TEXTURE_MIN_FILTER, GL10.GL_LINEAR); for (loop = 0; loop < MAX_PARTICLES; loop++) { float xi, yi, zi; xi = (float) ((rand() % 50) - 26.0f) * 10.0f; yi = zi = (float) ((rand() % 50) - 25.0f) * 10.0f; // 初始化粒子 initParticle(loop, random.nextInt(12), xi, yi, zi); } } public int rand() { return Math.abs(random.nextInt(1000)); } // initParticle初始化粒子 public void initParticle(int num, int color, float xDir, float yDir, float zDir) { Particle par = new Particle(); // 使所有粒子为激活状态 par.active = true; // 所有粒子生命值为最大 par.life = 1.0f; // 随机生成衰率(0~99)/1000+0.003f par.fade = rand() % 100 / 1000.0f + 0.003f; // 赋予粒子颜色分量r,g,b // r par.r = colors[color][0]; // g par.g = colors[color][1]; // b par.b = colors[color][2]; // 设定粒子方向xi,yi,zi // xi par.xi = xDir; // yi par.yi = yDir; // zi par.zi = zDir; // x,y,z方向加速度 // xg par.xg = 0.0f; // yg par.yg = -0.5f; // zg par.zg = 0.0f; particles[loop] = par; } }
接下来是Particle.java
package com.boring.ParticleActivity; public class Particle { boolean active; // 是否激活 float life; // 粒子生命 float fade; // 衰减速度 float r; // 红色值 float g; // 绿色值 float b; // 蓝色值 float x; // X位置 float y; // Y位置 float z; // Z位置 float xi; // X方向 float yi; // Y方向 float zi; // Z方向 float xg; // X 方向重力加速度 float yg; // Y 方向重力加速度 float zg; // Z 方向重力加速度 }
接下来是ParticleActivity.java
package com.boring.ParticleActivity; import android.app.Activity; import android.content.res.Resources; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.opengl.GLSurfaceView; import android.os.Bundle; public class ParticleActivity extends Activity { /** Called when the activity is first created. */ private GLSurfaceView glSurfaceView; private MyRenderer myRenderer; public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); LoadImage.load(getResources()); myRenderer = new MyRenderer(); glSurfaceView = new GLSurfaceView(this); glSurfaceView.setRenderer(myRenderer); setContentView(glSurfaceView); } } class LoadImage { public static Bitmap bitmap; public static void load(Resources res) { bitmap = BitmapFactory.decodeResource(res, R.drawable.mm); } }
AndroidManifest.xml配置
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.boring.ParticleActivity" android:versionCode="1" android:versionName="1.0"> <uses-sdk android:minSdkVersion="7" /> <application android:icon="@drawable/icon" android:label="@string/app_name"> <activity android:name=".ParticleActivity" android:label="@string/app_name"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> </application> </manifest>
相关推荐
"第八章粒子系统"这个文件可能包含了实现这些特效的具体代码示例。学习这个例子,你可以理解如何配置粒子发射器、定义粒子行为,以及如何将粒子系统集成到osg场景中。通过实践,你可以进一步掌握粒子系统的灵活性,...
use.fla`、`粒子系统09_use.fla`、`粒子系统12_use.fla`、`粒子系统13_use.fla`、`粒子系统14_use.fla`:这些文件包含了不同应用场景的粒子系统源码,开发者可以通过查看和分析这些代码,了解粒子系统如何实现特定...
值得注意的是,粒子系统脚本不支持代码后跟注释的写法。 #### 粒子系统结构 粒子系统的基本结构包括粒子发生器、粒子属性变换器和粒子脚本。这些组件相互配合,共同决定了粒子的行为和外观特性。粒子系统脚本通常...
`Emitter examples readme.txt` 文件是示例的说明文档,可能包含如何使用粒子系统的指导、代码示例以及对各个示例的描述。通过阅读这个文件,用户可以了解到如何配置发射器参数,如粒子的生命周期、速度、颜色变化、...
在"Sample16_4"这个文件中,很可能包含了实现粒子系统的示例代码,可能包括了粒子类的定义、OpenGL ES的设置、着色器的编写以及渲染循环的实现。开发者可以通过研究这个案例,了解如何在实际项目中应用上述知识。 ...
在"ParticleSystem"这个压缩包中,可能包含了源代码、资源文件和编译项目设置,开发者可以通过阅读和修改这些文件来理解粒子系统的实现细节,学习如何在Direct3D中创建和管理粒子,以及如何利用公告牌技术优化性能。...
通过分析和理解代码,开发者不仅可以掌握粒子系统的基本概念,还能提升在实际项目中应用这些技术的能力。同时,这个烟花模拟示例也能激发对计算机图形学的兴趣,为进一步探索高级特效和游戏开发打下基础。
在提供的压缩包文件中,很可能是包含了一个完整的代码示例,你可以通过阅读和运行这个代码来学习如何实际操作。代码可能会包含以下几个部分:初始化Direct3D设备的函数,更新粒子状态的函数,绘制粒子的函数,以及主...
9. **OpenGLParticles_Gravity**:这个文件名可能包含一个示例项目,演示了如何在OpenGL ES 2.0环境中实现带有重力的粒子系统。代码可能包含了粒子数据结构、重力计算逻辑、GLSL着色器代码以及渲染循环的实现。 ...
【基于粒子系统的火焰算法】是一种在计算机图形学中模拟真实火焰动态效果的技术。粒子系统是一种离散模拟方法,常用于模拟复杂且难以精确建模的自然现象,如烟雾、水、火焰等。在这个项目中,我们将深入探讨如何利用...
### iOS 5中的UIKit粒子系统教程 #### 一、引言 随着iOS 5的发布,苹果为开发者们带来了全新的UIKit框架更新,其中最引人注目的特性之一就是内置的粒子系统支持。以往,要在iOS应用中实现粒子效果,开发者往往需要...
在计算机图形学领域,粒子系统是一种广泛用于创建复杂视觉效果的技术。在WPF(Windows Presentation Foundation)框架中,利用C#编程语言,我们可以实现丰富的粒子效果,如火焰、烟雾、水滴等。本资源就是一套使用...
### Unity物理引擎与粒子系统详解 #### 一、物理引擎 **物理引擎**在游戏开发中扮演着极其重要的角色,特别是在需要模拟现实世界物理特性的游戏中。Unity中的物理引擎能够帮助开发者实现逼真的物体交互效果,如...
总的来说,红色漂亮的简单易上手自定义粒子特效代码提供了一个学习和实践粒子系统的好机会。无论你是初学者还是经验丰富的开发者,理解并掌握这一技术都能为你的项目增添生动且引人注目的视觉元素。通过深入研究提供...
以下是一个简化版的爱心粒子系统QML代码示例: ```qml import QtQuick 2.0 import QtQuick.Particles 2.0 Rectangle { width: 640 height: 480 color: "black" ParticleSystem { id: particleSystem ...
在Android游戏开发中,粒子系统(Particle System)是一种强大的视觉效果工具,用于创建各种复杂的动态图形,如火焰、烟雾、雪花、爆炸..."Sample_7_2"的代码分析和实践将帮助你深入理解粒子系统的工作原理和实现细节。
该方法利用粒子系统技术、三次贝塞尔曲线的绘制方法以及动画效果的处理技巧,实现了高质量的爱心效果,具有一定的实用性和趣味性。同时,本文还提供了一份详细的Python代码示例,给读者提供了便利。
在这个基于Direct3D的粒子系统中,我们将深入探讨其核心概念、实现方法以及如何使用提供的源代码和资源文件。 首先,我们要了解Direct3D,它是Microsoft开发的图形应用程序编程接口(API),用于处理3D图形和游戏...
文件名“粒子系统”可能包含源代码、示例项目或者详细文档,通过深入研究这些文件,开发者不仅可以了解到粒子系统的运作机制,还能掌握实际项目中的优化技巧,这对于提升游戏画面表现力和优化性能都至关重要。...
- 源代码:用于实现粒子系统和火焰渲染的编程语言(可能是C++、C#、Python或其他语言)的代码文件。 - 资源文件:可能包括纹理图像、音频文件或其他与火焰效果相关的媒体资源。 - 配置文件:用于设置火焰效果的参数...