| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179 |
- package jme3test.terrain;
- import com.jme3.app.SimpleApplication;
- import com.jme3.app.state.ScreenshotAppState;
- import com.jme3.asset.plugins.HttpZipLocator;
- import com.jme3.asset.plugins.ZipLocator;
- import com.jme3.bullet.BulletAppState;
- import com.jme3.bullet.collision.shapes.CapsuleCollisionShape;
- import com.jme3.bullet.collision.shapes.HeightfieldCollisionShape;
- import com.jme3.bullet.control.CharacterControl;
- import com.jme3.bullet.control.RigidBodyControl;
- import com.jme3.input.KeyInput;
- import com.jme3.input.controls.ActionListener;
- import com.jme3.input.controls.KeyTrigger;
- import com.jme3.material.Material;
- import com.jme3.math.ColorRGBA;
- import com.jme3.math.Vector3f;
- import com.jme3.terrain.geomipmap.TerrainGrid;
- import com.jme3.terrain.geomipmap.TerrainGridListener;
- import com.jme3.terrain.geomipmap.TerrainLodControl;
- import com.jme3.terrain.geomipmap.TerrainQuad;
- import com.jme3.terrain.geomipmap.lodcalc.DistanceLodCalculator;
- import java.io.File;
- public class TerrainGridSerializationTest extends SimpleApplication {
- private TerrainGrid terrain;
- private boolean usePhysics = true;
- public static void main(final String[] args) {
- TerrainGridSerializationTest app = new TerrainGridSerializationTest();
- app.start();
- }
- private CharacterControl player3;
- @Override
- public void simpleInitApp() {
- File file = new File("TerrainGridTestData.zip");
- if (!file.exists()) {
- assetManager.registerLocator("http://jmonkeyengine.googlecode.com/files/TerrainGridTestData.zip", HttpZipLocator.class);
- } else {
- assetManager.registerLocator("TerrainGridTestData.zip", ZipLocator.class);
- }
- this.flyCam.setMoveSpeed(100f);
- ScreenshotAppState state = new ScreenshotAppState();
- this.stateManager.attach(state);
- this.terrain= (TerrainGrid) assetManager.loadModel("TerrainGrid/TerrainGrid.j3o");
-
- this.rootNode.attachChild(this.terrain);
-
- TerrainLodControl control = new TerrainLodControl(this.terrain, getCamera());
- control.setLodCalculator( new DistanceLodCalculator(65, 2.7f) ); // patch size, and a multiplier
- this.terrain.addControl(control);
-
- final BulletAppState bulletAppState = new BulletAppState();
- stateManager.attach(bulletAppState);
- this.getCamera().setLocation(new Vector3f(0, 256, 0));
- this.viewPort.setBackgroundColor(new ColorRGBA(0.7f, 0.8f, 1f, 1f));
- if (usePhysics) {
- CapsuleCollisionShape capsuleShape = new CapsuleCollisionShape(0.5f, 1.8f, 1);
- player3 = new CharacterControl(capsuleShape, 0.5f);
- player3.setJumpSpeed(20);
- player3.setFallSpeed(10);
- player3.setGravity(10);
- player3.setPhysicsLocation(new Vector3f(cam.getLocation().x, 256, cam.getLocation().z));
- bulletAppState.getPhysicsSpace().add(player3);
- terrain.addListener(new TerrainGridListener() {
- public void gridMoved(Vector3f newCenter) {
- }
- public Material tileLoaded(Material material, Vector3f cell) {
- return material;
- }
- public void tileAttached(Vector3f cell, TerrainQuad quad) {
- //workaround for bugged test j3o's
- while(quad.getControl(RigidBodyControl.class)!=null){
- quad.removeControl(RigidBodyControl.class);
- }
- quad.addControl(new RigidBodyControl(new HeightfieldCollisionShape(quad.getHeightMap(), terrain.getLocalScale()), 0));
- bulletAppState.getPhysicsSpace().add(quad);
- }
- public void tileDetached(Vector3f cell, TerrainQuad quad) {
- bulletAppState.getPhysicsSpace().remove(quad);
- quad.removeControl(RigidBodyControl.class);
- }
- });
- }
-
- this.initKeys();
- }
- private void initKeys() {
- // You can map one or several inputs to one named action
- this.inputManager.addMapping("Lefts", new KeyTrigger(KeyInput.KEY_A));
- this.inputManager.addMapping("Rights", new KeyTrigger(KeyInput.KEY_D));
- this.inputManager.addMapping("Ups", new KeyTrigger(KeyInput.KEY_W));
- this.inputManager.addMapping("Downs", new KeyTrigger(KeyInput.KEY_S));
- this.inputManager.addMapping("Jumps", new KeyTrigger(KeyInput.KEY_SPACE));
- this.inputManager.addListener(this.actionListener, "Lefts");
- this.inputManager.addListener(this.actionListener, "Rights");
- this.inputManager.addListener(this.actionListener, "Ups");
- this.inputManager.addListener(this.actionListener, "Downs");
- this.inputManager.addListener(this.actionListener, "Jumps");
- }
- private boolean left;
- private boolean right;
- private boolean up;
- private boolean down;
- private final ActionListener actionListener = new ActionListener() {
- @Override
- public void onAction(final String name, final boolean keyPressed, final float tpf) {
- if (name.equals("Lefts")) {
- if (keyPressed) {
- TerrainGridSerializationTest.this.left = true;
- } else {
- TerrainGridSerializationTest.this.left = false;
- }
- } else if (name.equals("Rights")) {
- if (keyPressed) {
- TerrainGridSerializationTest.this.right = true;
- } else {
- TerrainGridSerializationTest.this.right = false;
- }
- } else if (name.equals("Ups")) {
- if (keyPressed) {
- TerrainGridSerializationTest.this.up = true;
- } else {
- TerrainGridSerializationTest.this.up = false;
- }
- } else if (name.equals("Downs")) {
- if (keyPressed) {
- TerrainGridSerializationTest.this.down = true;
- } else {
- TerrainGridSerializationTest.this.down = false;
- }
- } else if (name.equals("Jumps")) {
- TerrainGridSerializationTest.this.player3.jump();
- }
- }
- };
- private final Vector3f walkDirection = new Vector3f();
- @Override
- public void simpleUpdate(final float tpf) {
- Vector3f camDir = this.cam.getDirection().clone().multLocal(0.6f);
- Vector3f camLeft = this.cam.getLeft().clone().multLocal(0.4f);
- this.walkDirection.set(0, 0, 0);
- if (this.left) {
- this.walkDirection.addLocal(camLeft);
- }
- if (this.right) {
- this.walkDirection.addLocal(camLeft.negate());
- }
- if (this.up) {
- this.walkDirection.addLocal(camDir);
- }
- if (this.down) {
- this.walkDirection.addLocal(camDir.negate());
- }
- if (usePhysics) {
- this.player3.setWalkDirection(this.walkDirection);
- this.cam.setLocation(this.player3.getPhysicsLocation());
- }
- }
- }
|