From c591260ab5dc0c79a20ce2c230411dde82640970 Mon Sep 17 00:00:00 2001 From: "rem..om" Date: Sat, 9 Mar 2013 08:54:10 +0000 Subject: [PATCH] WaterFilter : the size of the reflection map can now be changed at run time. git-svn-id: https://jmonkeyengine.googlecode.com/svn/trunk@10476 75d07b2b-3a1a-0410-a2c5-0572b91ccdca --- .../com/jme3/water/WaterFilter.java | 5 + .../test/jme3test/water/TestPostWater.java | 95 +++++++++++-------- 2 files changed, 60 insertions(+), 40 deletions(-) diff --git a/engine/src/core-effects/com/jme3/water/WaterFilter.java b/engine/src/core-effects/com/jme3/water/WaterFilter.java index 515270c95..fba95f44b 100644 --- a/engine/src/core-effects/com/jme3/water/WaterFilter.java +++ b/engine/src/core-effects/com/jme3/water/WaterFilter.java @@ -853,6 +853,11 @@ public class WaterFilter extends Filter { */ public void setReflectionMapSize(int reflectionMapSize) { this.reflectionMapSize = reflectionMapSize; + reflectionPass.init(renderManager.getRenderer(), reflectionMapSize, reflectionMapSize, Format.RGBA8, Format.Depth); + reflectionCam.resize(reflectionMapSize, reflectionMapSize, true); + reflectionProcessor.setReflectionBuffer(reflectionPass.getRenderFrameBuffer()); + material.setTexture("ReflectionMap", reflectionPass.getRenderedTexture()); + } /** diff --git a/engine/src/test/jme3test/water/TestPostWater.java b/engine/src/test/jme3test/water/TestPostWater.java index 7bbe39ebb..bdd6a717f 100644 --- a/engine/src/test/jme3test/water/TestPostWater.java +++ b/engine/src/test/jme3test/water/TestPostWater.java @@ -5,6 +5,7 @@ import com.jme3.audio.AudioNode; import com.jme3.audio.LowPassFilter; import com.jme3.effect.ParticleEmitter; import com.jme3.effect.ParticleMesh; +import com.jme3.input.KeyInput; import com.jme3.input.controls.ActionListener; import com.jme3.input.controls.KeyTrigger; import com.jme3.light.DirectionalLight; @@ -38,6 +39,7 @@ import java.util.List; /** * test + * * @author normenhansen */ public class TestPostWater extends SimpleApplication { @@ -59,8 +61,8 @@ public class TestPostWater extends SimpleApplication { @Override public void simpleInitApp() { - setDisplayFps(false); - setDisplayStatView(false); + setDisplayFps(false); + setDisplayStatView(false); Node mainScene = new Node("Main Scene"); rootNode.attachChild(mainScene); @@ -79,22 +81,22 @@ public class TestPostWater extends SimpleApplication { flyCam.setMoveSpeed(50); //cam.setLocation(new Vector3f(-700, 100, 300)); - //cam.setRotation(new Quaternion().fromAngleAxis(0.5f, Vector3f.UNIT_Z)); + //cam.setRotation(new Quaternion().fromAngleAxis(0.5f, Vector3f.UNIT_Z)); cam.setLocation(new Vector3f(-327.21957f, 61.6459f, 126.884346f)); cam.setRotation(new Quaternion(0.052168474f, 0.9443102f, -0.18395276f, 0.2678024f)); - + cam.setRotation(new Quaternion().fromAngles(new float[]{FastMath.PI * 0.06f, FastMath.PI * 0.65f, 0})); Spatial sky = SkyFactory.createSky(assetManager, "Scenes/Beach/FullskiesSunset0068.dds", false); sky.setLocalScale(350); - + mainScene.attachChild(sky); cam.setFrustumFar(4000); //cam.setFrustumNear(100); - - + + //private FilterPostProcessor fpp; @@ -102,9 +104,9 @@ public class TestPostWater extends SimpleApplication { water = new WaterFilter(rootNode, lightDir); FilterPostProcessor fpp = new FilterPostProcessor(assetManager); - + fpp.addFilter(water); - BloomFilter bloom=new BloomFilter(); + BloomFilter bloom = new BloomFilter(); //bloom.getE bloom.setExposurePower(55); bloom.setBloomIntensity(1.0f); @@ -112,16 +114,16 @@ public class TestPostWater extends SimpleApplication { LightScatteringFilter lsf = new LightScatteringFilter(lightDir.mult(-300)); lsf.setLightDensity(1.0f); fpp.addFilter(lsf); - DepthOfFieldFilter dof=new DepthOfFieldFilter(); + DepthOfFieldFilter dof = new DepthOfFieldFilter(); dof.setFocusDistance(0); - dof.setFocusRange(100); + dof.setFocusRange(100); fpp.addFilter(dof); // - - // fpp.addFilter(new TranslucentBucketFilter()); - // - - // fpp.setNumSamples(4); + + // fpp.addFilter(new TranslucentBucketFilter()); + // + + // fpp.setNumSamples(4); water.setWaveScale(0.003f); @@ -135,22 +137,21 @@ public class TestPostWater extends SimpleApplication { //water.setFoamHardness(0.6f); water.setWaterHeight(initialWaterHeight); - uw=cam.getLocation().y