import org.andengine.engine.camera.Camera;
import org.andengine.engine.options.EngineOptions;
import org.andengine.engine.options.ScreenOrientation;
import org.andengine.engine.options.resolutionpolicy.RatioResolutionPolicy;
import org.andengine.entity.modifier.CardinalSplineMoveModifier;
import org.andengine.entity.modifier.CardinalSplineMoveModifier.CardinalSplineMoveModifierConfig;
import org.andengine.entity.modifier.DelayModifier;
import org.andengine.entity.modifier.LoopEntityModifier;
import org.andengine.entity.modifier.ParallelEntityModifier;
import org.andengine.entity.modifier.RotationModifier;
import org.andengine.entity.modifier.SequenceEntityModifier;
import org.andengine.entity.primitive.Rectangle;
import org.andengine.entity.scene.Scene;
import org.andengine.entity.scene.background.Background;
import org.andengine.entity.util.FPSLogger;
import org.andengine.ui.activity.SimpleBaseGameActivity;
import org.andengine.util.math.MathUtils;
import org.andengine.util.modifier.ease.EaseLinear;
import android.opengl.GLES20;
import android.util.DisplayMetrics;
/**
* CardinalSplineMoveModifier(基数样条移动修改器)。
* demo的效果是依靠矩形的运动创造出一个心形,当然心形是一个不规则的形状,这里就得使用基数样条的概念。
* 盗用百科:
* 基数样条是一组单个曲线按照一定的顺序连接而成的一条较大曲线。样条由一系列点指定,并通过每一个指定的点。
* 由于基数样条平滑地穿过组中的每一个点(不出现尖角),因而它比用直线连接创建的路径更精确。
* 程序中定义了两组X,Y坐标,分别表示心形左右两边的控制点,矩形的移动平滑的穿过几个控制点。
*/
public class CardinalSplineMoveModifierActivity extends SimpleBaseGameActivity
{
private static int winWidth = 854;
private static int winHeight = 480;
private static final float RECTANGLE_SIZE = 25.0f;
//时间(秒)
private static final float DURATION = 4.0f;
private static float[][] controlPointXy1;
private static float[][] controlPointXy2;
@Override
public EngineOptions onCreateEngineOptions()
{
setScreenDisplay();
Camera carmea = new Camera(0, 0, winWidth, winHeight);
return new EngineOptions
(
true,
ScreenOrientation.LANDSCAPE_FIXED,
new RatioResolutionPolicy(winWidth, winHeight),
carmea
);
}
@Override
protected void onCreateResources()
{
}
@Override
protected Scene onCreateScene()
{
this.mEngine.registerUpdateHandler(new FPSLogger());
Scene scene = new Scene();
scene.setBackground(new Background(0, 0, 0));
//创建并添加矩形
for (int j = 0; j < 400; j++)
{
createRectangle(scene);
}
return scene;
}
private void createRectangle(Scene scene)
{
Rectangle rectangle = new Rectangle(-RECTANGLE_SIZE, -RECTANGLE_SIZE, RECTANGLE_SIZE, RECTANGLE_SIZE, this.getVertexBufferObjectManager());
rectangle.setBlendFunction(GLES20.GL_SRC_ALPHA, GLES20.GL_ONE);
//设置矩形颜色(使用了引擎的随机数)
rectangle.setColor(MathUtils.random(0.0f, 1.0f), MathUtils.random(0.0f, 1.0f), MathUtils.random(0.0f, 1.0f), 0.5f);
/*
* 控制点的配置
* CardinalSplineMoveModifierConfig中记录了控制点和张力,CardinalSplineMoveModifier根据配置文件计算出改变的路径。
* 通过源码发现:(控制点)pControlPointCount最小为4个,(张力)pTension取值范围 [-1, 1]
* 其中张力越小,角就越圆,路径越弯,否则张力越大,角就月尖,路径越直
*/
CardinalSplineMoveModifierConfig cardinalSplineMoveModifierConfig1 = new CardinalSplineMoveModifierConfig(controlPointXy1.length, MathUtils.random(-1.0f, 1.0f));
CardinalSplineMoveModifierConfig cardinalSplineMoveModifierConfig2 = new CardinalSplineMoveModifierConfig(controlPointXy2.length, MathUtils.random(-1.0f, 1.0f));
//填充(设置)控制点(跟上面配置的个数要匹配)
for (int i = 0; i < controlPointXy1.length; i++)
{
// pIndex :控制点下标;pX,pY : 控制点左边(x,y)
cardinalSplineMoveModifierConfig1.setControlPoint(i, controlPointXy1[i][0], controlPointXy1[i][1]);
}
//填充(设置)控制点(跟上面配置的个数要匹配)
for (int i = 0; i < controlPointXy2.length; i++)
{
// pIndex :控制点下标;pX,pY : 控制点左边(x,y)
cardinalSplineMoveModifierConfig2.setControlPoint(i, controlPointXy2[i][0], controlPointXy2[i][1]);
}
//顺序实体修改器
SequenceEntityModifier sequenceEntityModifier = new SequenceEntityModifier
(
//延时播放
new DelayModifier(MathUtils.random(0, DURATION * 2f)),
//无限循环,相当于根据控制点从下到上跑完左边,再从下到上跑完右边,然后重复跑
new LoopEntityModifier
(
//顺序执行,先走完左边,再走右边,最后停在终点
new SequenceEntityModifier
(
new ParallelEntityModifier
(
/*
* 基数样条移动修改器
* CardinalSplineMoveModifier:类似于PathModifier,但移动的效果更真实。
* 实体接近弯道时,转弯更流畅,或扭转方向更平滑,这其实看起来相当不错
*/
new CardinalSplineMoveModifier(DURATION, cardinalSplineMoveModifierConfig1, EaseLinear.getInstance()),
new RotationModifier(DURATION, -45, -315)
),
new ParallelEntityModifier
(
/*
* 基数样条移动修改器
* CardinalSplineMoveModifier:类似于PathModifier,但移动的效果更真实。
* 实体接近弯道时,转弯更流畅,或扭转方向更平滑,这其实看起来相当不错
*/
new CardinalSplineMoveModifier(DURATION, cardinalSplineMoveModifierConfig2, EaseLinear.getInstance()),
new RotationModifier(DURATION, 45, 315)
)
)
)
);
rectangle.registerEntityModifier(sequenceEntityModifier);
scene.attachChild(rectangle);
}
/**
* 设置屏幕大小
*/
private void setScreenDisplay()
{
DisplayMetrics displayMetrics = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(displayMetrics);
winWidth = displayMetrics.widthPixels;
winHeight = displayMetrics.heightPixels;
//左边控制点的x,y
controlPointXy1 = new float[][]
{
{2.0f*(winWidth/4)-RECTANGLE_SIZE/2 , 3.5f*(winHeight/4)-RECTANGLE_SIZE/2},
{1.0f*(winWidth/4)-RECTANGLE_SIZE/2 , 2.0f*(winHeight/4)-RECTANGLE_SIZE/2},
{1.5f*(winWidth/4)-RECTANGLE_SIZE/2 , 1.0f*(winHeight/4)-RECTANGLE_SIZE/2},
{2.0f*(winWidth/4)-RECTANGLE_SIZE/2 , 1.5f*(winHeight/4)-RECTANGLE_SIZE/2}
};
//右边控制点的x,y
controlPointXy2 = new float[][]
{
{2.0f*(winWidth/4)-RECTANGLE_SIZE/2 , 3.5f*(winHeight/4)-RECTANGLE_SIZE/2},
{3.0f*(winWidth/4)-RECTANGLE_SIZE/2 , 2.0f*(winHeight/4)-RECTANGLE_SIZE/2},
{2.5f*(winWidth/4)-RECTANGLE_SIZE/2 , 1.0f*(winHeight/4)-RECTANGLE_SIZE/2},
{2.0f*(winWidth/4)-RECTANGLE_SIZE/2 , 1.5f*(winHeight/4)-RECTANGLE_SIZE/2}
};
}
}
相关推荐
在Android游戏开发中,andEngine是一个非常流行的2D游戏引擎,它提供了丰富的功能,包括粒子系统,用于创建各种视觉效果,如火花、烟雾、爆炸等。本篇将深入探讨andEngine中的粒子系统,特别是如何使用px文件来设计...
8. **andenginetexturepackerextension.jar**:纹理打包扩展帮助优化内存使用,通过将多个小图片合并成一个大纹理,减少纹理切换时的GPU内存开销,提高游戏性能。 9. **andenginemodplayerextension.jar**:MOD...
在Android游戏开发中,andEngine是一个非常受欢迎的2D游戏引擎,它提供了丰富的功能和简单易用的API,使得开发者可以快速构建出高质量的游戏。在本篇内容中,我们将深入探讨如何在andEngine中利用SVG(Scalable ...
Jumper Game Tutorial很可能是一个跳跃类的游戏,教导用户如何使用AndEngine来开发类似的游戏。这种类型的游戏通常包括角色控制、障碍物躲避和分数计算等基本元素。AndEngine通过其灵活的精灵(Sprite)系统和场景...
"使用AndEngine的一个DEMO"是基于这个引擎开发的一个示例项目,它展示了AndEngine的基本用法和功能,帮助初学者理解和学习如何在实际中运用AndEngine。 首先,AndEngine的核心是它的Scene类,它是所有游戏内容的...
描述中的链接提供了详细的步骤和代码示例,可以帮助你了解如何初始化和启动一个基本的游戏项目。 场景(Scene)是AndEngine中组织游戏元素的基本单位,你可以将多个场景切换来实现游戏的不同阶段。Scene由一组称为...
综上所述,AndEngine游戏引擎通过提供强大的2D图形处理、物理模拟以及丰富的游戏开发工具,为Android游戏开发者创造了一个高效且易用的开发环境。通过下载并导入AndEngine的JAR文件,开发者可以快速启动项目,利用...
AndEngine 是一个专门为 Android 平台设计的 2D 游戏引擎,它提供了一个强大的游戏开发框架,帮助开发者快速创建高质量的游戏。下面我们将详细介绍 AndEngine 的使用入门。 一、AndEngine 的基本运行原理 ...
在Android游戏开发中,AndEngine是一个非常受欢迎的2D游戏引擎,它允许开发者轻松地创建出高质量的2D游戏。本篇文章将详细讲解AndEngine中精灵(Sprite)及其动作(Animations)的应用,以一个简单的例子为基础,...
本入门篇将带你了解AndEngine的基本概念、架构以及如何开始你的第一个AndEngine项目。 一、AndEngine概述 AndEngine是一个开源的Java库,完全免费,它提供了基本的游戏逻辑、动画处理、物理模拟等功能。其核心优势...
AndEngine是一个开源项目。这使得开发者在遇到问题时可以直接从源码上找到答案,也能按照自己的需要对AndEngine进行修改和扩展。AndEngine的源码在github上托管[2]。 高效 AndEngine主要使用Java语言开发,但在...
AndEngine是一个开源项目。这使得开发者在遇到问题时可以直接从源码上找到答案,也能按照自己的需要对AndEngine进行修改和扩展。AndEngine的源码在github上托管[2]。 高效 AndEngine主要使用Java语言开发,但在...
7. **AndEngine Robotium Extension**:从提供的文件名`AndEngineRobotiumExtensionExampleTest-master`来看,这似乎是一个使用AndEngine与Robotium进行自动化测试的示例项目。Robotium是一个流行的Android自动化...
在AndEngine中,游戏场景是由多个实体(或称为节点)组成的,`attachChild()`就是将一个节点(如精灵、纹理、形状等)添加到父节点(通常是Scene或Group)上的方法,从而将它显示在游戏中。 AndEngine的核心组件...
AndEngine的架构基于一个主循环,这个循环不断更新游戏状态,处理输入,渲染画面。主要组成部分包括Engine、Scene、Entity、Module等。Engine是整个游戏运行的中心,负责管理时间、渲染和处理输入。Scene是游戏的...
8. **易于上手**:AndEngine的设计目标之一就是易用性,它提供了清晰的API文档和活跃的社区支持,使开发者能更快地入门并开发出自己的游戏。 在使用AndEngine时,开发者需要注意以下几点: - **兼容性**:虽然...
总结起来,Andengine是一个强大的2D游戏开发框架,它的核心jar包和一系列扩展库为开发者提供了便捷的游戏开发环境,降低了游戏制作的技术门槛。通过熟练掌握Andengine,开发者能够快速构建出功能丰富、视觉效果出色...
- **AndEngineScriptingExtension**:这是一个脚本扩展,允许开发者使用类似Lua的脚本语言编写游戏逻辑,从而与Java代码分离,提高代码可维护性。 - **AndEnginePhysicsBox2DExtension**:集成Box2D物理引擎,用于...
在Android游戏开发中,AndEngine是一个非常受欢迎的2D游戏引擎,它提供了丰富的功能和简单易用的API,使得开发者可以快速构建出高质量的游戏。在AndEngine中,UI元素的创建是游戏界面交互的重要组成部分,而Button...
AndEngine是一个用于开发Android平台2D游戏的游戏框架,它使用OpenGL ES来进行图形渲染,支持Android 1.6及以上的版本。相比于其他游戏引擎如Libgdx,AndEngine提供了更多的游戏组件和扩展功能,而且默认支持中文...