Who let the doc out?

- javadoc for com.jme.post
- javadoc for com.jme.post.filters
remain SSAO, Water, shadows and HDR to complete the package

git-svn-id: https://jmonkeyengine.googlecode.com/svn/trunk@7618 75d07b2b-3a1a-0410-a2c5-0572b91ccdca
3.0
rem..om 14 years ago
parent e90d01d6e2
commit 86eb9b5173
  1. 181
      engine/src/core/com/jme3/post/Filter.java
  2. 72
      engine/src/core/com/jme3/post/FilterPostProcessor.java
  3. 11
      engine/src/core/com/jme3/post/SceneProcessor.java
  4. 77
      engine/src/desktop-fx/com/jme3/post/filters/BloomFilter.java
  5. 81
      engine/src/desktop-fx/com/jme3/post/filters/CartoonEdgeFilter.java
  6. 28
      engine/src/desktop-fx/com/jme3/post/filters/ColorOverlayFilter.java
  7. 81
      engine/src/desktop-fx/com/jme3/post/filters/CrossHatchFilter.java
  8. 28
      engine/src/desktop-fx/com/jme3/post/filters/DepthOfFieldFilter.java
  9. 46
      engine/src/desktop-fx/com/jme3/post/filters/FadeFilter.java
  10. 16
      engine/src/desktop-fx/com/jme3/post/filters/FogFilter.java
  11. 78
      engine/src/desktop-fx/com/jme3/post/filters/LightScatteringFilter.java
  12. 39
      engine/src/desktop-fx/com/jme3/post/filters/PosterizationFilter.java
  13. 56
      engine/src/desktop-fx/com/jme3/post/filters/RadialBlurFilter.java
  14. 20
      engine/src/desktop-fx/com/jme3/post/filters/TranslucentBucketFilter.java
  15. 12
      engine/src/desktop-fx/com/jme3/post/ssao/SSAOFilter.java
  16. 33
      engine/src/desktop-fx/com/jme3/water/WaterFilter.java

@ -51,10 +51,16 @@ import java.util.Iterator;
import java.util.List;
/**
* Filter abstract class
* Any Filter must extends this class
* Holds a frameBuffer and a texture
* The getMaterial must return a Material that use a GLSL shader immplementing the desired effect
* Filters are 2D effects applied to the rendered scene.<br>
* The filter is fed with the rendered scene image rendered in an offscreen frame buffer.<br>
* This texture is applied on a fullscreen quad, with a special material.<br>
* This material uses a shader that aplly the desired effect to the scene texture.<br>
* <br>
* This class is abstract, any Filter must extend it.<br>
* Any filter holds a frameBuffer and a texture<br>
* The getMaterial must return a Material that use a GLSL shader immplementing the desired effect<br>
*
* @author Rémy Bouquet aka Nehon
*/
public abstract class Filter implements Savable {
@ -69,6 +75,11 @@ public abstract class Filter implements Savable {
this.name = name;
}
/**
* Inner class Pass
* Pass are like filters in filters.
* Some filters will need multiple passes before the final render
*/
public class Pass {
protected FrameBuffer renderFrameBuffer;
@ -76,28 +87,52 @@ public abstract class Filter implements Savable {
protected Texture2D depthTexture;
protected Material passMaterial;
/**
* init the pass called internally
* @param renderer
* @param width
* @param height
* @param textureFormat
* @param depthBufferFormat
* @param numSamples
*/
public void init(Renderer renderer, int width, int height, Format textureFormat, Format depthBufferFormat, int numSamples) {
Collection<Caps> caps = renderer.getCaps();
if (numSamples > 1 && caps.contains(Caps.FrameBufferMultisample) && caps.contains(Caps.OpenGL31)) {
renderFrameBuffer = new FrameBuffer(width, height, numSamples);
renderedTexture = new Texture2D(width, height, numSamples, textureFormat);
// depthTexture = new Texture2D(width, height, numSamples, depthBufferFormat);
renderedTexture = new Texture2D(width, height, numSamples, textureFormat);
} else {
renderFrameBuffer = new FrameBuffer(width, height, 1);
renderedTexture = new Texture2D(width, height, textureFormat);
// depthTexture = new Texture2D(width, height, depthBufferFormat);
}
renderFrameBuffer.setColorTexture(renderedTexture);
renderFrameBuffer.setDepthBuffer(depthBufferFormat);
// renderFrameBuffer.setDepthTexture(depthTexture);
}
/**
* init the pass called internally
* @param renderer
* @param width
* @param height
* @param textureFormat
* @param depthBufferFormat
*/
public void init(Renderer renderer, int width, int height, Format textureFormat, Format depthBufferFormat) {
init(renderer, width, height, textureFormat, depthBufferFormat, 1);
}
/**
* init the pass called internally
* @param renderer
* @param width
* @param height
* @param textureFormat
* @param depthBufferFormat
* @param numSample
* @param material
*/
public void init(Renderer renderer, int width, int height, Format textureFormat, Format depthBufferFormat, int numSample, Material material) {
init(renderer, width, height, textureFormat, depthBufferFormat, numSample);
passMaterial = material;
@ -146,26 +181,51 @@ public abstract class Filter implements Savable {
}
}
/**
* returns the default pass texture format
* @return
*/
protected Format getDefaultPassTextureFormat() {
return Format.RGBA8;
}
/**
* returns the default pass depth format
* @return
*/
protected Format getDefaultPassDepthFormat() {
return Format.Depth;
}
public Filter() {
/**
* contruct a Filter
*/
protected Filter() {
this("filter");
}
public void init(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
/**
*
* initialize this filter
* use InitFilter for overriding filter initialization
* @param manager the assetManager
* @param renderManager the renderManager
* @param vp the viewport
* @param w the width
* @param h the height
*/
protected final void init(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
// cleanup(renderManager.getRenderer());
defaultPass = new Pass();
defaultPass.init(renderManager.getRenderer(), w, h, getDefaultPassTextureFormat(), getDefaultPassDepthFormat());
initFilter(manager, renderManager, vp, w, h);
}
public void cleanup(Renderer r) {
/**
* cleanup this filter
* @param r
*/
protected final void cleanup(Renderer r) {
processor = null;
if (defaultPass != null) {
defaultPass.cleanup(r);
@ -180,36 +240,49 @@ public abstract class Filter implements Savable {
}
/**
* This method is called once xhen the filter is added to the FilterPostProcessor
* It should contain Maerial initializations and extra passes initialization
* @param manager
* Initialization of sub classes filters
* This method is called once when the filter is added to the FilterPostProcessor
* It should contain Material initializations and extra passes initialization
* @param manager the assetManager
* @param renderManager the renderManager
* @param vp the viewPort where this filter is rendered
* @param w the width of the filter
* @param h the height of the filter
*/
protected abstract void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h);
/**
* override this method if you have some cleanup to do
* @param r the renderer
*/
public abstract void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h);
protected void cleanUpFilter(Renderer r) {
}
public abstract void cleanUpFilter(Renderer r);
;
/**
* Returns the material used for this filter.
* Must return the material used for this filter.
* this method is called every frame.
*
* @return the material used for this filter.
*/
public abstract Material getMaterial();
protected abstract Material getMaterial();
/**
* Override this method if you want to make a pre pass, before the actual rendering of the frame
* @param renderManager
* @param viewPort
*/
public void postQueue(RenderManager renderManager, ViewPort viewPort) {
protected void postQueue(RenderManager renderManager, ViewPort viewPort) {
}
/**
* Use this method if you want to modify parameters according to tpf before the rendering of the frame.
* Override this method if you want to modify parameters according to tpf before the rendering of the frame.
* This is usefull for animated filters
* Also it can be the place to render pre passes
* @param tpf the time used to render the previous frame
*/
public void preFrame(float tpf) {
protected void preFrame(float tpf) {
}
/**
@ -217,7 +290,7 @@ public abstract class Filter implements Savable {
* @param renderManager
* @param viewPort
*/
public void postFrame(RenderManager renderManager, ViewPort viewPort, FrameBuffer prevFilterBuffer, FrameBuffer sceneBuffer) {
protected void postFrame(RenderManager renderManager, ViewPort viewPort, FrameBuffer prevFilterBuffer, FrameBuffer sceneBuffer) {
}
/**
@ -243,56 +316,84 @@ public abstract class Filter implements Savable {
enabled = ic.readBoolean("enabled", true);
}
/**
* returns the name of the filter
* @return
*/
public String getName() {
return name;
}
/**
* Sets the name of the filter
* @param name
*/
public void setName(String name) {
this.name = name;
}
public FrameBuffer getRenderFrameBuffer() {
/**
* returns the default pass frame buffer
* @return
*/
protected FrameBuffer getRenderFrameBuffer() {
return defaultPass.renderFrameBuffer;
}
public void setRenderFrameBuffer(FrameBuffer renderFrameBuffer) {
/**
* sets the default pas frame buffer
* @param renderFrameBuffer
*/
protected void setRenderFrameBuffer(FrameBuffer renderFrameBuffer) {
this.defaultPass.renderFrameBuffer = renderFrameBuffer;
}
public Texture2D getRenderedTexture() {
/**
* returns the rendered texture of this filter
* @return
*/
protected Texture2D getRenderedTexture() {
return defaultPass.renderedTexture;
}
public void setRenderedTexture(Texture2D renderedTexture) {
/**
* sets the rendered texture of this filter
* @param renderedTexture
*/
protected void setRenderedTexture(Texture2D renderedTexture) {
this.defaultPass.renderedTexture = renderedTexture;
}
/**
* Override this method and return true if your Filter need the depth texture
* Override this method and return true if your Filter needs the depth texture
*
* @return true if your Filter need the depth texture
*/
public boolean isRequiresDepthTexture() {
protected boolean isRequiresDepthTexture() {
return false;
}
/**
/**
* Override this method and return false if your Filter does not need the scene texture
*
* @return false if your Filter does not need the scene texture
*/
public boolean isRequiresSceneTexture() {
protected boolean isRequiresSceneTexture() {
return true;
}
public List<Pass> getPostRenderPasses() {
/**
* returns the list of the postRender passes
* @return
*/
protected List<Pass> getPostRenderPasses() {
return postRenderPasses;
}
public void setPostRenderPasses(List<Pass> postRenderPasses) {
this.postRenderPasses = postRenderPasses;
}
/**
* Enable or disable this filter
* @param enabled true to enable
*/
public void setEnabled(boolean enabled) {
if (processor != null) {
processor.setFilterState(this, enabled);
@ -301,10 +402,18 @@ public abstract class Filter implements Savable {
}
}
/**
* returns ttrue if the filter is enabled
* @return enabled
*/
public boolean isEnabled() {
return enabled;
}
/**
* sets a reference to the FilterPostProcessor ti which this filter is attached
* @param proc
*/
protected void setProcessor(FilterPostProcessor proc) {
processor = proc;
}

@ -55,6 +55,11 @@ import java.util.Collection;
import java.util.Iterator;
import java.util.List;
/**
* A FilterPostProcessor is a processor that can apply several {@link Filter}s to a rendered scene<br>
* It manages a list of filters that will be applied in the order in which they've been added to the list
* @author Rémy Bouquet aka Nehon
*/
public class FilterPostProcessor implements SceneProcessor, Savable {
private RenderManager renderManager;
@ -81,25 +86,26 @@ public class FilterPostProcessor implements SceneProcessor, Savable {
private int originalHeight;
private int lastFilterIndex = -1;
private boolean cameraInit = false;
// private boolean handleTranslucentBucket = false;
// private FrameBuffer transFrameBuffer;
// private Material transMaterial;
// private boolean isTransparencyRendered=false;
/**
* Create a FilterProcessor constructor
* @param assetManager the Asset Manager
* Create a FilterProcessor
* @param assetManager the assetManager
*/
public FilterPostProcessor(AssetManager assetManager) {
this.assetManager = assetManager;
}
/**
* Don't use this constructor use FilterPostProcessor(AssetManager assetManager)
* Don't use this constructor use {@link FilterPostProcessor(AssetManager assetManager)}<br>
* This constructor is used for serialization only
*/
public FilterPostProcessor() {
}
/**
* Adds a filter to the filters list<br>
* @param filter the filter to add
*/
public void addFilter(Filter filter) {
filters.add(filter);
filter.setProcessor(this);
@ -112,6 +118,10 @@ public class FilterPostProcessor implements SceneProcessor, Savable {
}
/**
* removes this filters from the filters list
* @param filter
*/
public void removeFilter(Filter filter) {
for (Iterator<Filter> it = filters.iterator(); it.hasNext();) {
if (it.next() == filter) {
@ -140,6 +150,11 @@ public class FilterPostProcessor implements SceneProcessor, Savable {
reshape(vp, cam.getWidth(), cam.getHeight());
}
/**
* init the given filter
* @param filter
* @param vp
*/
private void initFilter(Filter filter, ViewPort vp) {
filter.init(assetManager, renderManager, vp, width, height);
if (filter.isRequiresDepthTexture()) {
@ -152,6 +167,12 @@ public class FilterPostProcessor implements SceneProcessor, Savable {
}
}
/**
* renders a filter on a fullscreen quad
* @param r
* @param buff
* @param mat
*/
private void renderProcessing(Renderer r, FrameBuffer buff, Material mat) {
if (buff == outputBuffer) {
fsQuad.setWidth(width);
@ -199,7 +220,12 @@ public class FilterPostProcessor implements SceneProcessor, Savable {
}
Picture pic = new Picture("debug");
public void renderFilterChain(Renderer r, FrameBuffer sceneFb) {
/**
* iterate through the filter list and renders filters
* @param r
* @param sceneFb
*/
private void renderFilterChain(Renderer r, FrameBuffer sceneFb) {
Texture2D tex = filterTexture;
FrameBuffer buff = sceneFb;
boolean msDepth = depthTexture != null && depthTexture.getImage().getMultiSamples() > 1;
@ -268,7 +294,7 @@ public class FilterPostProcessor implements SceneProcessor, Savable {
}
renderFilterChain(renderer, sceneBuffer);
renderManager.setCamera(viewPort.getCamera(), false);
renderer.setFrameBuffer(outputBuffer);
}
@ -305,6 +331,11 @@ public class FilterPostProcessor implements SceneProcessor, Savable {
}
/**
* sets the filter to enabled or disabled
* @param filter
* @param enabled
*/
protected void setFilterState(Filter filter, boolean enabled) {
if (filters.contains(filter)) {
filter.enabled = enabled;
@ -312,6 +343,9 @@ public class FilterPostProcessor implements SceneProcessor, Savable {
}
}
/**
* compute the index of the last filter to render
*/
private void updateLastFilterIndex() {
lastFilterIndex = -1;
for (int i = filters.size() - 1; i >= 0 && lastFilterIndex == -1; i--) {
@ -423,32 +457,32 @@ public class FilterPostProcessor implements SceneProcessor, Savable {
this.assetManager = assetManager;
}
/**
* Writes the processor
* @param ex
* @throws IOException
*/
public void write(JmeExporter ex) throws IOException {
OutputCapsule oc = ex.getCapsule(this);
oc.write(numSamples, "numSamples", 0);
oc.writeSavableArrayList((ArrayList) filters, "filters", null);
}
/**
* Reads the processor
* @param im
* @throws IOException
*/
public void read(JmeImporter im) throws IOException {
InputCapsule ic = im.getCapsule(this);
numSamples = ic.readInt("numSamples", 0);
filters = ic.readSavableArrayList("filters", null);
}
/**
* For internal use only<br>
* returns the depth texture of the scene
* @return
*/
public Texture2D getDepthTexture() {
return depthTexture;
}
/**
* For internal use only<br>
* returns the rendered texture of the scene
* @return
*/
public Texture2D getFilterTexture() {
return filterTexture;
}

@ -37,9 +37,15 @@ import com.jme3.renderer.ViewPort;
import com.jme3.renderer.queue.RenderQueue;
import com.jme3.texture.FrameBuffer;
/**
* Scene processors are used to compute/render things before and after the classic render of the scene.
* They have to be added to a viewport and are rendered in the order they've been added
* @author Kirill Vainer aka Shadowislord aka Momoko_Fan
*/
public interface SceneProcessor {
/**
* For internal use only<br>
* Called in the render thread to initialize the scene processor.
*
* @param rm The render manager to which the SP was added to
@ -48,6 +54,7 @@ public interface SceneProcessor {
public void initialize(RenderManager rm, ViewPort vp);
/**
* For internal use only<br>
* Called when the resolution of the viewport has been changed.
* @param vp
*/
@ -60,6 +67,7 @@ public interface SceneProcessor {
public boolean isInitialized();
/**
* For internal use only<br>
* Called before a frame
*
* @param tpf Time per frame
@ -67,6 +75,7 @@ public interface SceneProcessor {
public void preFrame(float tpf);
/**
* For internal use only<br>
* Called after the scene graph has been queued, but before it is flushed.
*
* @param rq The render queue
@ -74,6 +83,7 @@ public interface SceneProcessor {
public void postQueue(RenderQueue rq);
/**
* For internal use only<br>
* Called after a frame has been rendered and the queue flushed.
*
* @param out The FB to which the scene was rendered.
@ -81,6 +91,7 @@ public interface SceneProcessor {
public void postFrame(FrameBuffer out);
/**
* For internal use only<br>
* Called when the SP is removed from the RM.
*/
public void cleanup();

@ -40,36 +40,37 @@ import com.jme3.material.Material;
import com.jme3.math.ColorRGBA;
import com.jme3.post.Filter;
import com.jme3.renderer.RenderManager;
import com.jme3.renderer.Renderer;
import com.jme3.renderer.ViewPort;
import com.jme3.texture.Image.Format;
import java.io.IOException;
import java.util.ArrayList;
/**
* <code>BloomFilter</code> is used to make objects in the scene have a
* "soap opera" glow effect.
*
* @author Nehon
* BloomFilter is used to make objects in the scene have a glow effect.<br>
* There are 2 mode : Scene and Objects.<br>
* Scene mode extracts the bright parts of the scene to make them glow<br>
* Object mode make objects glow according to their material's glowMap or their GlowColor<br>
* see {@link http://jmonkeyengine.org/wiki/doku.php/jme3:advanced:bloom_and_glow} for more details
*
* @author Rémy Bouquet aka Nehon
*/
public class BloomFilter extends Filter {
/**
* <code>GlowMode</code> specifies if bright objects or objects
* with glow map will be bloomed.
* GlowMode specifies if the glow will be applied to the whole scene,or to objects that have aglow color or a glow map
*/
public enum GlowMode {
/**
* Apply bloom filter to bright objects in the scene.
* Apply bloom filter to bright areas in the scene.
*/
Scene,
/**
* Apply bloom only to objects that have a glow map.
* Apply bloom only to objects that have a glow map or a glow color.
*/
Objects,
/**
* Apply bloom to both bright objects and objects with glow map.
* Apply bloom to both bright parts of the scene and objects with glow map.
*/
SceneAndObjects;
}
@ -93,14 +94,14 @@ public class BloomFilter extends Filter {
private ColorRGBA backupColor;
/**
* creates a Bloom filter
* Creates a Bloom filter
*/
public BloomFilter() {
super("BloomFilter");
}
/**
* Crete the bloom filter with the specific glow mode
* Creates the bloom filter with the specific glow mode
* @param glowMode
*/
public BloomFilter(GlowMode glowMode) {
@ -109,7 +110,7 @@ public class BloomFilter extends Filter {
}
@Override
public void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
protected void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
screenWidth = (int) (w / downSamplingFactor);
screenHeight = (int) (h / downSamplingFactor);
// System.out.println(screenWidth + " " + screenHeight);
@ -178,31 +179,15 @@ public class BloomFilter extends Filter {
material.setTexture("BloomTex", verticalalBlur.getRenderedTexture());
}
@Override
public void cleanUpFilter(Renderer r) {
if (preGlowPass != null) {
preGlowPass.cleanup(r);
}
if (extractPass != null) {
extractPass.cleanup(r);
}
if (horizontalBlur != null) {
horizontalBlur.cleanup(r);
}
if (verticalalBlur != null) {
verticalalBlur.cleanup(r);
}
}
@Override
public Material getMaterial() {
protected Material getMaterial() {
material.setFloat("BloomIntensity", bloomIntensity);
return material;
}
@Override
public void postQueue(RenderManager renderManager, ViewPort viewPort) {
protected void postQueue(RenderManager renderManager, ViewPort viewPort) {
if (glowMode != GlowMode.Scene) {
backupColor = viewPort.getBackgroundColor();
viewPort.setBackgroundColor(ColorRGBA.Black);
@ -216,30 +201,43 @@ public class BloomFilter extends Filter {
}
}
/**
* returns the bloom intensity
* @return
*/
public float getBloomIntensity() {
return bloomIntensity;
}
/**
* intensity of the bloom effect
* intensity of the bloom effect default is 2.0
* @param bloomIntensity
*/
public void setBloomIntensity(float bloomIntensity) {
this.bloomIntensity = bloomIntensity;
}
/**
* returns the blur scale
* @return
*/
public float getBlurScale() {
return blurScale;
}
/**
* The spread of the bloom
* sets The spread of the bloom default is 1.5f
* @param blurScale
*/
public void setBlurScale(float blurScale) {
this.blurScale = blurScale;
}
/**
* returns the exposure cutoff<br>
* for more details see {@link setExposureCutOff(float exposureCutOff)}
* @return
*/
public float getExposureCutOff() {
return exposureCutOff;
}
@ -252,12 +250,18 @@ public class BloomFilter extends Filter {
this.exposureCutOff = exposureCutOff;
}
/**
* returns the exposure power<br>
* form more details see {@link setExposurePower(float exposurePower)}
* @return
*/
public float getExposurePower() {
return exposurePower;
}
/**
* the power of the bloomed color
* defines how many time the bloom extracted color will be multiplied by itself. default id 5.0<br>
* a high value will reduce rough edges in the bloom and somhow the range of the bloom area *
* @param exposurePower
*/
public void setExposurePower(float exposurePower) {
@ -265,7 +269,8 @@ public class BloomFilter extends Filter {
}
/**
* returns the downSampling factor
* returns the downSampling factor<br>
* form more details see {@link setDownSamplingFactor(float downSamplingFactor)}
* @return
*/
public float getDownSamplingFactor() {
@ -273,7 +278,7 @@ public class BloomFilter extends Filter {
}
/**
* Sets the downSampling factor : the size of the computed texture will be divided by this factor.
* Sets the downSampling factor : the size of the computed texture will be divided by this factor. default is 1 for no downsampling
* A 2 value is a good way of widening the blur
* @param downSamplingFactor
*/

@ -55,19 +55,22 @@ public class CartoonEdgeFilter extends Filter {
private float depthThreshold = 0.1f;
private float normalSensitivity = 1.0f;
private float depthSensitivity = 10.0f;
private ColorRGBA edgeColor=new ColorRGBA(0, 0, 0, 1);
private ColorRGBA edgeColor = new ColorRGBA(0, 0, 0, 1);
/**
* Creates a CartoonEdgeFilter
*/
public CartoonEdgeFilter() {
super("CartoonEdgeFilter");
}
@Override
public boolean isRequiresDepthTexture() {
protected boolean isRequiresDepthTexture() {
return true;
}
@Override
public void postQueue(RenderManager renderManager, ViewPort viewPort) {
protected void postQueue(RenderManager renderManager, ViewPort viewPort) {
Renderer r = renderManager.getRenderer();
r.setFrameBuffer(normalPass.getRenderFrameBuffer());
renderManager.getRenderer().clearBuffers(true, true, true);
@ -78,13 +81,13 @@ public class CartoonEdgeFilter extends Filter {
}
@Override
public Material getMaterial() {
protected Material getMaterial() {
material.setTexture("NormalsTexture", normalPass.getRenderedTexture());
return material;
}
@Override
public void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
protected void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
normalPass = new Pass();
normalPass.init(renderManager.getRenderer(), w, h, Format.RGBA8, Format.Depth);
material = new Material(manager, "Common/MatDefs/Post/CartoonEdge.j3md");
@ -97,17 +100,20 @@ public class CartoonEdgeFilter extends Filter {
material.setColor("EdgeColor", edgeColor);
}
@Override
public void cleanUpFilter(Renderer r) {
if (normalPass != null) {
normalPass.cleanup(r);
}
}
/**
* Return the depth sensitivity<br>
* for more details see {@link setDepthSensitivity(float depthSensitivity)}
* @return
*/
public float getDepthSensitivity() {
return depthSensitivity;
}
/**
* sets the depth sensitivity<br>
* defines how much depth will influence edges, default is 10
* @param depthSensitivity
*/
public void setDepthSensitivity(float depthSensitivity) {
this.depthSensitivity = depthSensitivity;
if (material != null) {
@ -115,10 +121,20 @@ public class CartoonEdgeFilter extends Filter {
}
}
/**
* returns the depth threshold<br>
* for more details see {@link setDepthThreshold(float depthThreshold)}
* @return
*/
public float getDepthThreshold() {
return depthThreshold;
}
/**
* sets the depth threshold<br>
* Defines at what threshold of difference of depth an edge is outlined default is 0.1f
* @param depthThreshold
*/
public void setDepthThreshold(float depthThreshold) {
this.depthThreshold = depthThreshold;
if (material != null) {
@ -126,10 +142,20 @@ public class CartoonEdgeFilter extends Filter {
}
}
/**
* returns the edge intensity<br>
* for more details see {@link setEdgeIntensity(float edgeIntensity) }
* @return
*/
public float getEdgeIntensity() {
return edgeIntensity;
}
/**
* sets the edge intensity<br>
* Defineshow visilble will be the outlined edges
* @param edgeIntensity
*/
public void setEdgeIntensity(float edgeIntensity) {
this.edgeIntensity = edgeIntensity;
if (material != null) {
@ -137,10 +163,18 @@ public class CartoonEdgeFilter extends Filter {
}
}
/**
* returns the width of the edges
* @return
*/
public float getEdgeWidth() {
return edgeWidth;
}
/**
* sets the witdh of the edge in pixels default is 1
* @param edgeWidth
*/
public void setEdgeWidth(float edgeWidth) {
this.edgeWidth = edgeWidth;
if (material != null) {
@ -149,10 +183,19 @@ public class CartoonEdgeFilter extends Filter {
}
/**
* returns the normals sensitivity<br>
* form more details see {@link setNormalSensitivity(float normalSensitivity)}
* @return
*/
public float getNormalSensitivity() {
return normalSensitivity;
}
/**
* sets the normals sensitivity default is 1
* @param normalSensitivity
*/
public void setNormalSensitivity(float normalSensitivity) {
this.normalSensitivity = normalSensitivity;
if (material != null) {
@ -160,10 +203,20 @@ public class CartoonEdgeFilter extends Filter {
}
}
/**
* returns the normal threshold<br>
* for more details see {@link setNormalThreshold(float normalThreshold)}
*
* @return
*/
public float getNormalThreshold() {
return normalThreshold;
}
/**
* sets the normal threshold default is 0.5
* @param normalThreshold
*/
public void setNormalThreshold(float normalThreshold) {
this.normalThreshold = normalThreshold;
if (material != null) {
@ -185,10 +238,8 @@ public class CartoonEdgeFilter extends Filter {
*/
public void setEdgeColor(ColorRGBA edgeColor) {
this.edgeColor = edgeColor;
if(material!=null){
if (material != null) {
material.setColor("EdgeColor", edgeColor);
}
}
}

@ -40,44 +40,58 @@ import com.jme3.material.Material;
import com.jme3.math.ColorRGBA;
import com.jme3.post.Filter;
import com.jme3.renderer.RenderManager;
import com.jme3.renderer.Renderer;
import com.jme3.renderer.ViewPort;
import java.io.IOException;
/**
*
* @author nehon
* This filter simply multiply the whole scene by a color
* @author Rémy Bouquet aka Nehon
*/
public class ColorOverlayFilter extends Filter {
private ColorRGBA color = ColorRGBA.White;
/**
* creates a colorOverlayFilter with a white coor (transparent)
*/
public ColorOverlayFilter() {
super("Color Overlay");
}
/**
* creates a colorOverlayFilter with the given color
* @param color
*/
public ColorOverlayFilter(ColorRGBA color) {
this();
this.color = color;
}
@Override
public Material getMaterial() {
protected Material getMaterial() {
material.setColor("Color", color);
return material;
}
/**
* returns the color
* @return color
*/
public ColorRGBA getColor() {
return color;
}
/**
* sets the color
* @param color
*/
public void setColor(ColorRGBA color) {
this.color = color;
}
@Override
public void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
protected void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
material = new Material(manager, "Common/MatDefs/Post/Overlay.j3md");
}
@ -94,8 +108,4 @@ public class ColorOverlayFilter extends Filter {
InputCapsule ic = im.getCapsule(this);
color = (ColorRGBA) ic.readSavable("color", ColorRGBA.White);
}
@Override
public void cleanUpFilter(Renderer r) {
}
}

@ -36,7 +36,6 @@ import com.jme3.material.Material;
import com.jme3.math.ColorRGBA;
import com.jme3.post.Filter;
import com.jme3.renderer.RenderManager;
import com.jme3.renderer.Renderer;
import com.jme3.renderer.ViewPort;
/*
@ -64,10 +63,18 @@ public class CrossHatchFilter extends Filter {
private float lineThickness = 1.0f;
private float lineDistance = 4.0f;
/**
* Creates a crossHatch filter
*/
public CrossHatchFilter() {
super("CrossHatchFilter");
}
/**
* Creates a crossHatch filter
* @param lineColor the colors of the lines
* @param paperColor the paper color
*/
public CrossHatchFilter(ColorRGBA lineColor, ColorRGBA paperColor) {
this();
this.lineColor = lineColor;
@ -75,12 +82,12 @@ public class CrossHatchFilter extends Filter {
}
@Override
public boolean isRequiresDepthTexture() {
protected boolean isRequiresDepthTexture() {
return false;
}
@Override
public void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
protected void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
material = new Material(manager, "Common/MatDefs/Post/CrossHatch.j3md");
material.setColor("LineColor", lineColor);
material.setColor("PaperColor", paperColor);
@ -101,16 +108,13 @@ public class CrossHatchFilter extends Filter {
}
@Override
public Material getMaterial() {
protected Material getMaterial() {
return material;
}
@Override
public void cleanUpFilter(Renderer r) {
}
/*
/**
* Sets color used to draw lines
* @param lineColor
*/
public void setLineColor(ColorRGBA lineColor) {
this.lineColor = lineColor;
@ -119,8 +123,9 @@ public class CrossHatchFilter extends Filter {
}
}
/*
/**
* Sets color used as background
* @param paperColor
*/
public void setPaperColor(ColorRGBA paperColor) {
this.paperColor = paperColor;
@ -128,10 +133,11 @@ public class CrossHatchFilter extends Filter {
material.setColor("PaperColor", paperColor);
}
}
/*
/**
* Sets color influence of original image on lines drawn
* @param colorInfluenceLine
*/
public void setColorInfluenceLine(float colorInfluenceLine) {
this.colorInfluenceLine = colorInfluenceLine;
if (material != null) {
@ -139,8 +145,9 @@ public class CrossHatchFilter extends Filter {
}
}
/*
/**
* Sets color influence of original image on non-line areas
* @param colorInfluencePaper
*/
public void setColorInfluencePaper(float colorInfluencePaper) {
this.colorInfluencePaper = colorInfluencePaper;
@ -149,9 +156,10 @@ public class CrossHatchFilter extends Filter {
}
}
/*
/**
* Sets line/paper color ratio for areas with values < luminance5,
* really dark areas get no lines but a filled blob instead
* @param fillValue
*/
public void setFillValue(float fillValue) {
this.fillValue = fillValue;
@ -160,13 +168,14 @@ public class CrossHatchFilter extends Filter {
}
}
/*
/**
*
* Sets minimum luminance levels for lines drawn
* Luminance1: Top-left to down right 1
* Luminance2: Top-right to bottom left 1
* Luminance3: Top-left to down right 2
* Luminance4: Top-right to bottom left 2
* Luminance5: Blobs
* @param luminance1 Top-left to down right 1
* @param luminance2 Top-right to bottom left 1
* @param luminance3 Top-left to down right 2
* @param luminance4 Top-right to bottom left 2
* @param luminance5 Blobs
*/
public void setLuminanceLevels(float luminance1, float luminance2, float luminance3, float luminance4, float luminance5) {
this.luminance1 = luminance1;
@ -184,8 +193,9 @@ public class CrossHatchFilter extends Filter {
}
}
/*
/**
* Sets the thickness of lines drawn
* @param lineThickness
*/
public void setLineThickness(float lineThickness) {
this.lineThickness = lineThickness;
@ -194,10 +204,11 @@ public class CrossHatchFilter extends Filter {
}
}
/*
/**
* Sets minimum distance between lines drawn
* Primary lines are drawn at 2*lineDistance
* Secondary lines are drawn at lineDistance
* @param lineDistance
*/
public void setLineDistance(float lineDistance) {
this.lineDistance = lineDistance;
@ -206,84 +217,86 @@ public class CrossHatchFilter extends Filter {
}
}
/*
/**
* Returns line color
* @return
*/
public ColorRGBA getLineColor() {
return lineColor;
}
/*
/**
* Returns paper background color
* @return
*/
public ColorRGBA getPaperColor() {
return paperColor;
}
/*
/**
* Returns current influence of image colors on lines
*/
public float getColorInfluenceLine() {
return colorInfluenceLine;
}
/*
/**
* Returns current influence of image colors on paper background
*/
public float getColorInfluencePaper() {
return colorInfluencePaper;
}
/*
/**
* Returns line/paper color ratio for blobs
*/
public float getFillValue() {
return fillValue;
}
/*
/**
* Returns the thickness of the lines drawn
*/
public float getLineThickness() {
return lineThickness;
}
/*
/**
* Returns minimum distance between lines
*/
public float getLineDistance() {
return lineDistance;
}
/*
/**
* Returns treshold for lines 1
*/
public float getLuminance1() {
return luminance1;
}
/*
/**
* Returns treshold for lines 2
*/
public float getLuminance2() {
return luminance2;
}
/*
/**
* Returns treshold for lines 3
*/
public float getLuminance3() {
return luminance3;
}
/*
/**
* Returns treshold for lines 4
*/
public float getLuminance4() {
return luminance4;
}
/*
/**
* Returns treshold for blobs
*/
public float getLuminance5() {

@ -35,7 +35,6 @@ import com.jme3.asset.AssetManager;
import com.jme3.post.Filter;
import com.jme3.material.Material;
import com.jme3.renderer.RenderManager;
import com.jme3.renderer.Renderer;
import com.jme3.renderer.ViewPort;
/**
@ -55,28 +54,31 @@ public class DepthOfFieldFilter extends Filter {
private float xScale;
private float yScale;
/**
* Creates a DepthOfField filter
*/
public DepthOfFieldFilter() {
super("Depth Of Field");
}
@Override
public boolean isRequiresDepthTexture() {
protected boolean isRequiresDepthTexture() {
return true;
}
@Override
public Material getMaterial() {
protected Material getMaterial() {
return material;
}
@Override
public void initFilter(AssetManager assets, RenderManager renderManager,
protected void initFilter(AssetManager assets, RenderManager renderManager,
ViewPort vp, int w, int h) {
material = new Material(assets, "Common/MatDefs/Post/DepthOfField.j3md");
material.setFloat("FocusDistance", focusDistance);
material.setFloat("FocusRange", focusRange);
xScale = 1.0f / w;
yScale = 1.0f / h;
@ -85,10 +87,6 @@ public class DepthOfFieldFilter extends Filter {
material.setFloat("YScale", blurScale * yScale);
}
@Override
public void cleanUpFilter(Renderer r) {
}
/**
* Sets the distance at which objects are purely in focus.
*/
@ -101,6 +99,10 @@ public class DepthOfFieldFilter extends Filter {
}
/**
* returns the focus distance
* @return
*/
public float getFocusDistance() {
return focusDistance;
}
@ -118,6 +120,10 @@ public class DepthOfFieldFilter extends Filter {
}
/**
* returns the focus range
* @return
*/
public float getFocusRange() {
return focusRange;
}
@ -142,6 +148,10 @@ public class DepthOfFieldFilter extends Filter {
}
}
/**
* returns the blur scale
* @return
*/
public float getBlurScale() {
return blurScale;
}

@ -39,13 +39,13 @@ import com.jme3.export.OutputCapsule;
import com.jme3.material.Material;
import com.jme3.post.Filter;
import com.jme3.renderer.RenderManager;
import com.jme3.renderer.Renderer;
import com.jme3.renderer.ViewPort;
import java.io.IOException;
/**
*
* @author Nehon
* Fade Filter allows you to make an animated fade effect on a scene.
* @author Rémy Bouquet aka Nehon
* implemented from boxjar implementation
* see http://jmonkeyengine.org/groups/graphics/forum/topic/newbie-question-general-fade-inout-effect/#post-105559
*/
@ -56,29 +56,35 @@ public class FadeFilter extends Filter {
private float direction = 1;
private float duration = 1;
/**
* Creates a FadeFilter
*/
public FadeFilter() {
super("Fade In/Out");
}
/**
* Creates a FadeFilter with the given duration
* @param duration
*/
public FadeFilter(float duration) {
this();
this.duration = duration;
}
@Override
public Material getMaterial() {
protected Material getMaterial() {
material.setFloat("Value", value);
return material;
}
@Override
public void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
protected void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
material = new Material(manager, "Common/MatDefs/Post/Fade.j3md");
}
@Override
public void preFrame(float tpf) {
protected void preFrame(float tpf) {
if (playing) {
value += tpf * direction / duration;
@ -95,20 +101,34 @@ public class FadeFilter extends Filter {
}
}
/**
* returns the duration of the effect
* @return
*/
public float getDuration() {
return duration;
}
/**
* Sets the duration of the filter default is 1 second
* @param duration
*/
public void setDuration(float duration) {
this.duration = duration;
}
/**
* fades the scene in (black to scene)
*/
public void fadeIn() {
setEnabled(true);
direction = 1;
playing = true;
}
/**
* fades the scene out (scene to black)
*/
public void fadeOut() {
setEnabled(true);
direction = -1;
@ -130,15 +150,21 @@ public class FadeFilter extends Filter {
duration = ic.readFloat("duration", 1);
}
/**
* return the current value of the fading
* can be used to chack if fade is complete (eg value=1)
* @return
*/
public float getValue() {
return value;
}
/**
* sets the fade value
* can be used to force complete black or compete scene
* @param value
*/
public void setValue(float value) {
this.value = value;
}
@Override
public void cleanUpFilter(Renderer r) {
}
}

@ -40,13 +40,12 @@ import com.jme3.material.Material;
import com.jme3.math.ColorRGBA;
import com.jme3.post.Filter;
import com.jme3.renderer.RenderManager;
import com.jme3.renderer.Renderer;
import com.jme3.renderer.ViewPort;
import java.io.IOException;
/**
* A filter to render a fog effect
* @author Nehon
* @author Rémy Bouquet aka Nehon
*/
public class FogFilter extends Filter {
@ -54,6 +53,9 @@ public class FogFilter extends Filter {
private float fogDensity = 0.7f;
private float fogDistance = 1000;
/**
* Creates a FogFilter
*/
public FogFilter() {
super("FogFilter");
}
@ -72,12 +74,12 @@ public class FogFilter extends Filter {
}
@Override
public boolean isRequiresDepthTexture() {
protected boolean isRequiresDepthTexture() {
return true;
}
@Override
public void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
protected void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
material = new Material(manager, "Common/MatDefs/Post/Fog.j3md");
material.setColor("FogColor", fogColor);
material.setFloat("FogDensity", fogDensity);
@ -85,7 +87,7 @@ public class FogFilter extends Filter {
}
@Override
public Material getMaterial() {
protected Material getMaterial() {
return material;
}
@ -166,7 +168,5 @@ public class FogFilter extends Filter {
fogDistance = ic.readFloat("fogDistance", 1000);
}
@Override
public void cleanUpFilter(Renderer r) {
}
}

@ -41,13 +41,14 @@ import com.jme3.math.Vector3f;
import com.jme3.post.Filter;
import com.jme3.renderer.Camera;
import com.jme3.renderer.RenderManager;
import com.jme3.renderer.Renderer;
import com.jme3.renderer.ViewPort;
import java.io.IOException;
/**
* LightScattering filters creates rays comming from a light sources
* This is often reffered as god rays.
*
* @author nehon
* @author Rémy Bouquet aka Nehon
*/
public class LightScatteringFilter extends Filter {
@ -59,25 +60,32 @@ public class LightScatteringFilter extends Filter {
private float lightDensity = 1.4f;
private boolean adaptative = true;
Vector3f viewLightPos = new Vector3f();
private boolean display=true;
private boolean display = true;
private float innerLightDensity;
/**
* creates a lightScaterring filter
*/
public LightScatteringFilter() {
super("Light Scattering");
}
/**
* Creates a lightScatteringFilter
* @param lightPosition
*/
public LightScatteringFilter(Vector3f lightPosition) {
this();
this.lightPosition = lightPosition;
}
@Override
public boolean isRequiresDepthTexture() {
protected boolean isRequiresDepthTexture() {
return true;
}
@Override
public Material getMaterial() {
protected Material getMaterial() {
material.setVector3("LightPosition", screenLightPos);
material.setInt("NbSamples", nbSamples);
material.setFloat("BlurStart", blurStart);
@ -88,7 +96,7 @@ public class LightScatteringFilter extends Filter {
}
@Override
public void postQueue(RenderManager renderManager, ViewPort viewPort) {
protected void postQueue(RenderManager renderManager, ViewPort viewPort) {
getClipCoordinates(lightPosition, screenLightPos, viewPort.getCamera());
// screenLightPos.x = screenLightPos.x / viewPort.getCamera().getWidth();
// screenLightPos.y = screenLightPos.y / viewPort.getCamera().getHeight();
@ -101,12 +109,12 @@ public class LightScatteringFilter extends Filter {
//System.err.println("screenLightPos "+screenLightPos);
if (adaptative) {
innerLightDensity = Math.max(lightDensity - Math.max(screenLightPos.x, screenLightPos.y), 0.0f);
}else{
innerLightDensity=lightDensity;
} else {
innerLightDensity = lightDensity;
}
}
public Vector3f getClipCoordinates(Vector3f worldPosition, Vector3f store, Camera cam) {
private Vector3f getClipCoordinates(Vector3f worldPosition, Vector3f store, Camera cam) {
float w = cam.getViewProjectionMatrix().multProj(worldPosition, store);
store.divideLocal(w);
@ -119,46 +127,92 @@ public class LightScatteringFilter extends Filter {
}
@Override
public void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
protected void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
material = new Material(manager, "Common/MatDefs/Post/LightScattering.j3md");
}
/**
* returns the blur start of the scattering
* see {@link setBlurStart(float blurStart)}
* @return
*/
public float getBlurStart() {
return blurStart;
}
/**
* sets the blur start<br>
* at which distance from the light source the effect starts default is 0.02
* @param blurStart
*/
public void setBlurStart(float blurStart) {
this.blurStart = blurStart;
}
/**
* returns the blur width<br>
* see {@link setBlurWidth(float blurWidth)}
* @return
*/
public float getBlurWidth() {
return blurWidth;
}
/**
* sets the blur width default is 0.9
* @param blurWidth
*/
public void setBlurWidth(float blurWidth) {
this.blurWidth = blurWidth;
}
/**
* retiurns the light density<br>
* see {@link setLightDensity(float lightDensity)}
*
* @return
*/
public float getLightDensity() {
return lightDensity;
}
/**
* sets how much the effect is visible over the rendered scene default is 1.4
* @param lightDensity
*/
public void setLightDensity(float lightDensity) {
this.lightDensity = lightDensity;
}
/**
* returns the light position
* @return
*/
public Vector3f getLightPosition() {
return lightPosition;
}
/**
* sets the light position
* @param lightPosition
*/
public void setLightPosition(Vector3f lightPosition) {
this.lightPosition = lightPosition;
}
/**
* returns the nmber of samples for the radial blur
* @return
*/
public int getNbSamples() {
return nbSamples;
}
/**
* sets the number of samples for the radial blur default is 50
* the higher the value the higher the quality, but the slower the performances.
* @param nbSamples
*/
public void setNbSamples(int nbSamples) {
this.nbSamples = nbSamples;
}
@ -186,8 +240,4 @@ public class LightScatteringFilter extends Filter {
lightDensity = ic.readFloat("lightDensity", 1.4f);
adaptative = ic.readBoolean("adaptative", true);
}
@Override
public void cleanUpFilter(Renderer r) {
}
}

@ -35,7 +35,6 @@ import com.jme3.asset.AssetManager;
import com.jme3.material.Material;
import com.jme3.post.Filter;
import com.jme3.renderer.RenderManager;
import com.jme3.renderer.Renderer;
import com.jme3.renderer.ViewPort;
/**
@ -56,27 +55,34 @@ public class PosterizationFilter extends Filter {
private float gamma = 0.6f;
private float strength = 1.0f;
/**
* Creates a posterization Filter
*/
public PosterizationFilter() {
super("PosterizationFilter");
}
/**
* Creates a posterization Filter with the given number of colors
* @param numColors
*/
public PosterizationFilter(int numColors) {
this();
this.numColors = numColors;
}
/**
* Creates a posterization Filter with the given number of colors and gamma
* @param numColors
* @param gamma
*/
public PosterizationFilter(int numColors, float gamma) {
this(numColors);
this.gamma = gamma;
}
@Override
public boolean isRequiresDepthTexture() {
return false;
}
@Override
public void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
protected void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
material = new Material(manager, "Common/MatDefs/Post/Posterization.j3md");
material.setInt("NumColors", numColors);
material.setFloat("Gamma", gamma);
@ -84,16 +90,11 @@ public class PosterizationFilter extends Filter {
}
@Override
public Material getMaterial() {
protected Material getMaterial() {
return material;
}
@Override
public void cleanUpFilter(Renderer r) {
}
/*
/**
* Sets number of color levels used to draw the screen
*/
public void setNumColors(int numColors) {
@ -103,7 +104,7 @@ public class PosterizationFilter extends Filter {
}
}
/*
/**
* Sets gamma level used to enhange visual quality
*/
public void setGamma(float gamma) {
@ -113,7 +114,7 @@ public class PosterizationFilter extends Filter {
}
}
/*
/**
* Sets urrent strength value, i.e. influence on final image
*/
public void setStrength(float strength) {
@ -123,21 +124,21 @@ public class PosterizationFilter extends Filter {
}
}
/*
/**
* Returns number of color levels used
*/
public int getNumColors() {
return numColors;
}
/*
/**
* Returns current gamma value
*/
public float getGamma() {
return gamma;
}
/*
/**
* Returns current strength value, i.e. influence on final image
*/
public float getStrength() {

@ -39,14 +39,13 @@ import com.jme3.export.OutputCapsule;
import com.jme3.material.Material;
import com.jme3.post.Filter;
import com.jme3.renderer.RenderManager;
import com.jme3.renderer.Renderer;
import com.jme3.renderer.ViewPort;
import com.jme3.shader.VarType;
import java.io.IOException;
/**
*
* @author nehon
* Radially blurs the scene from the center of it
* @author Rémy Bouquet aka Nehon
*/
public class RadialBlurFilter extends Filter {
@ -54,10 +53,18 @@ public class RadialBlurFilter extends Filter {
private float sampleStrength = 2.2f;
private float[] samples = {-0.08f, -0.05f, -0.03f, -0.02f, -0.01f, 0.01f, 0.02f, 0.03f, 0.05f, 0.08f};
/**
* Creates a RadialBlurFilter
*/
public RadialBlurFilter() {
super("Radial blur");
}
/**
* Creates a RadialBlurFilter
* @param sampleDist the distance between samples
* @param sampleStrength the strenght of each sample
*/
public RadialBlurFilter(float sampleDist, float sampleStrength) {
this();
this.sampleDist = sampleDist;
@ -65,7 +72,7 @@ public class RadialBlurFilter extends Filter {
}
@Override
public Material getMaterial() {
protected Material getMaterial() {
material.setFloat("SampleDist", sampleDist);
material.setFloat("SampleStrength", sampleStrength);
@ -74,25 +81,60 @@ public class RadialBlurFilter extends Filter {
return material;
}
/**
* return the sample distance
* @return
*/
public float getSampleDistance() {
return sampleDist;
}
/**
* sets the samples distances default is 1
* @param sampleDist
*/
public void setSampleDistance(float sampleDist) {
this.sampleDist = sampleDist;
}
/**
*
* @return
* @deprecated use {@link getSampleDistance()}
*/
@Deprecated
public float getSampleDist() {
return sampleDist;
}
/**
*
* @param sampleDist
* @deprecated use {@link setSampleDistance(float sampleDist)}
*/
@Deprecated
public void setSampleDist(float sampleDist) {
this.sampleDist = sampleDist;
}
/**
* Returns the sample Strength
* @return
*/
public float getSampleStrength() {
return sampleStrength;
}
/**
* sets the sample streanght default is 2.2
* @param sampleStrength
*/
public void setSampleStrength(float sampleStrength) {
this.sampleStrength = sampleStrength;
}
@Override
public void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
protected void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
material = new Material(manager, "Common/MatDefs/Blur/RadialBlur.j3md");
}
@ -111,8 +153,4 @@ public class RadialBlurFilter extends Filter {
sampleDist = ic.readFloat("sampleDist", 1.0f);
sampleStrength = ic.readFloat("sampleStrength", 2.2f);
}
@Override
public void cleanUpFilter(Renderer r) {
}
}

@ -16,7 +16,8 @@ import com.jme3.texture.FrameBuffer;
import com.jme3.texture.Texture2D;
/**
*
* A filter to handle translucent objects when rendering a scene with filters that uses depth like WaterFilter and SSAOFilter
* just create a TranslucentBucketFilter and add it to the Filter list of a FilterPostPorcessor
* @author Nehon
*/
public final class TranslucentBucketFilter extends Filter {
@ -24,7 +25,7 @@ public final class TranslucentBucketFilter extends Filter {
private RenderManager renderManager;
@Override
public void initFilter(AssetManager manager, RenderManager rm, ViewPort vp, int w, int h) {
protected void initFilter(AssetManager manager, RenderManager rm, ViewPort vp, int w, int h) {
this.renderManager = rm;
material = new Material(manager, "Common/MatDefs/Post/Overlay.j3md");
material.setColor("Color", ColorRGBA.White);
@ -37,19 +38,20 @@ public final class TranslucentBucketFilter extends Filter {
}
renderManager.setHandleTranslucentBucket(false);
}
/**
/**
* Override this method and return false if your Filter does not need the scene texture
* @return
*/
public boolean isRequiresSceneTexture() {
@Override
protected boolean isRequiresSceneTexture() {
return false;
}
@Override
public void postFrame(RenderManager renderManager, ViewPort viewPort, FrameBuffer prevFilterBuffer, FrameBuffer sceneBuffer) {
protected void postFrame(RenderManager renderManager, ViewPort viewPort, FrameBuffer prevFilterBuffer, FrameBuffer sceneBuffer) {
renderManager.setCamera(viewPort.getCamera(), false);
if(prevFilterBuffer != sceneBuffer){
if (prevFilterBuffer != sceneBuffer) {
renderManager.getRenderer().copyFrameBuffer(prevFilterBuffer, sceneBuffer, false);
}
renderManager.getRenderer().setFrameBuffer(sceneBuffer);
@ -57,14 +59,14 @@ public final class TranslucentBucketFilter extends Filter {
}
@Override
public void cleanUpFilter(Renderer r) {
protected void cleanUpFilter(Renderer r) {
if (renderManager != null) {
renderManager.setHandleTranslucentBucket(true);
}
}
@Override
public Material getMaterial() {
protected Material getMaterial() {
return material;
}

@ -96,12 +96,12 @@ public class SSAOFilter extends Filter {
}
@Override
public boolean isRequiresDepthTexture() {
protected boolean isRequiresDepthTexture() {
return true;
}
@Override
public void postQueue(RenderManager renderManager, ViewPort viewPort) {
protected void postQueue(RenderManager renderManager, ViewPort viewPort) {
Renderer r = renderManager.getRenderer();
r.setFrameBuffer(normalPass.getRenderFrameBuffer());
renderManager.getRenderer().clearBuffers(true, true, true);
@ -112,12 +112,12 @@ public class SSAOFilter extends Filter {
}
@Override
public Material getMaterial() {
protected Material getMaterial() {
return material;
}
@Override
public void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
protected void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
int screenWidth = w;
int screenHeight = h;
postRenderPasses = new ArrayList<Pass>();
@ -270,7 +270,5 @@ public class SSAOFilter extends Filter {
bias = ic.readFloat("bias", 0.1f);
}
@Override
public void cleanUpFilter(Renderer r) {
}
}

@ -112,7 +112,6 @@ public class WaterFilter extends Filter {
private boolean underWater;
private float underWaterFogDistance = 120;
private float causticsIntensity = 0.5f;
private RenderManager renderManager;
private ViewPort viewPort;
@ -130,12 +129,12 @@ public class WaterFilter extends Filter {
}
@Override
public boolean isRequiresDepthTexture() {
protected boolean isRequiresDepthTexture() {
return true;
}
@Override
public void preFrame(float tpf) {
protected void preFrame(float tpf) {
time = time + (tpf * speed);
material.setFloat("Time", time);
Camera sceneCam = viewPort.getCamera();
@ -172,7 +171,7 @@ public class WaterFilter extends Filter {
float planeDistance = plane.pseudoDistance(vars.vect1);
vars.vect2.set(plane.getNormal()).multLocal(planeDistance * 2.0f);
vars.vect3.set(vars.vect1.subtractLocal(vars.vect2)).subtractLocal(loc).normalizeLocal().negateLocal();
reflectionCam.lookAt(targetLocation, vars.vect3);
assert vars.unlock();
@ -193,8 +192,8 @@ public class WaterFilter extends Filter {
}
renderManager.setCamera(sceneCam, false);
renderManager.getRenderer().setFrameBuffer(viewPort.getOutputFrameBuffer());
underWater = false;
} else {
underWater = true;
@ -202,21 +201,14 @@ public class WaterFilter extends Filter {
}
@Override
public void init(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
super.init(manager, renderManager, vp, w, h);
this.renderManager=renderManager;
this.viewPort=vp;
}
@Override
public Material getMaterial() {
protected Material getMaterial() {
return material;
}
@Override
public void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
protected void initFilter(AssetManager manager, RenderManager renderManager, ViewPort vp, int w, int h) {
this.renderManager = renderManager;
this.viewPort = vp;
reflectionPass = new Pass();
reflectionPass.init(renderManager.getRenderer(), reflectionMapSize, reflectionMapSize, Format.RGBA8, Format.Depth);
reflectionCam = new Camera(reflectionMapSize, reflectionMapSize);
@ -746,13 +738,6 @@ public class WaterFilter extends Filter {
this.reflectionMapSize = reflectionMapSize;
}
@Override
public void cleanUpFilter(Renderer r) {
if (reflectionPass != null) {
reflectionPass.cleanup(r);
}
}
/**
* returns true if the water uses foam
* @return

Loading…
Cancel
Save