effects_overview.adoc 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  1. = jME3 Special Effects Overview
  2. :revnumber: 2.1
  3. :revdate: 2020/07/22
  4. :keywords: documentation, effect, light, water
  5. :uri-jmonkeyengine: https://github.com/jMonkeyEngine/jmonkeyengine/tree/master/
  6. :img-jmonkeyengine: https://github.com/jMonkeyEngine/jmonkeyengine/raw/master/
  7. :uri-forum: https://hub.jmonkeyengine.org/
  8. jME3 supports several types of special effects: Post-Processor Filters, SceneProcessors, and Particle Emitters (also known as particle systems). This list contains screenshots and links to sample code that demonstrates how to add the effect to a scene.
  9. == Sample Code
  10. * There is one `com.jme3.effect.ParticleEmitter` class for all Particle Systems.
  11. * There is one `com.jme3.post.FilterPostProcessor` class and several `com.jme3.post.filters.` (all Filters have `Filter` in their names).
  12. * There are several `SceneProcessor` classes in various packages, including e.g. `com.jme3.shadow.` and `com.jme3.water.` (SceneProcessor have `Processor` or `Renderer` in their names).
  13. === Particle Emitter
  14. [source,java]
  15. ----
  16. public class MyGame extends SimpleApplication {
  17. public void simpleInitApp() {
  18. ParticleEmitter pm = new ParticleEmitter("my particle effect", Type.Triangle, 60);
  19. Material pmMat = new Material(assetManager, "Common/MatDefs/Misc/Particle.j3md");
  20. pmMat.setTexture("Texture", assetManager.loadTexture("Effects/spark.png"));
  21. pm.setMaterial(pmMat);
  22. pm.setImagesX(1);
  23. pm.setImagesY(1);
  24. rootNode.attachChild(pm); // attach one or more emitters to any node
  25. }
  26. }
  27. ----
  28. === Scene Processor
  29. [source,java]
  30. ----
  31. public class MyGame extends SimpleApplication {
  32. private BasicShadowRenderer bsr;
  33. public void simpleInitApp() {
  34. bsr = new BasicShadowRenderer(assetManager, 1024);
  35. bsr.setDirection(new Vector3f(.3f, -0.5f, -0.5f));
  36. viewPort.addProcessor(bsr); // add one or more sceneprocessor to viewport
  37. }
  38. ...
  39. }
  40. ----
  41. === Post-Processor Filter
  42. [source,java]
  43. ----
  44. public class MyGame extends SimpleApplication {
  45. private FilterPostProcessor fpp; // one FilterPostProcessor per app
  46. private SomeFilter sf; // one or more Filters per app
  47. public void simpleInitApp() {
  48. fpp = new FilterPostProcessor(assetManager);
  49. viewPort.addProcessor(fpp); // add one FilterPostProcessor to viewPort
  50. sf = new SomeFilter();
  51. fpp.addFilter(sf); // add one or more Filters to FilterPostProcessor
  52. }
  53. ...
  54. }
  55. ----
  56. == Water
  57. [.float-group]
  58. --
  59. [.right.text-left]
  60. image:jme3/advanced/water-post.png[water-post.png,width="150",height="100"] +
  61. image:jme3/advanced/water.png[water.png,width="150",height="100",align="right"]
  62. The jMonkeyEngine xref:jme3/advanced/water.adoc["`SeaMonkey WaterFilter`"] simulates ocean waves, foam, including cool underwater caustics. +
  63. Use the SimpleWaterProcessor (SceneProcessor) for small, limited bodies of water, such as puddles, drinking troughs, pools, fountains.
  64. See also:
  65. * link:{uri-forum}t/monkeys-at-the-beach/15000[Rendering Water as Post-Process Effect] announcement with video.
  66. * link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/water/TestSceneWater.java[TestSceneWater.java] – SimpleWaterProcessor. (SceneProcessor)
  67. * link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/water/TestSimpleWater.java[TestSimpleWater.java] – SimpleWaterProcessor. (SceneProcessor)
  68. --
  69. [.float-group]
  70. --
  71. [.right]
  72. image:jme3/advanced/water-reflection-muddy.png[water-reflection-muddy.png,width="150",height="100"] +
  73. image:jme3/advanced/underwater2.jpg[underwater2.jpg,width="150",height="100",align="right"]
  74. * link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/water/TestPostWater.java[TestPostWater.java] – WaterFilter.
  75. * link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/water/TestPostWaterLake.java[TestPostWaterLake.java] – WaterFilter.
  76. --
  77. == Environment Effects
  78. === Depth of Field Blur
  79. [.right]
  80. image:jme3/advanced/dof-blur.png[dof-blur.png,width="150",height="100"] +
  81. image:jme3/advanced/light-scattering-filter.png[light-scattering-filter.png,width="150",height="100",align="right"]
  82. * link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/post/TestDepthOfField.java[TestDepthOfField.java] – DepthOfFieldFilter.
  83. === Fog
  84. * link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/post/TestFog.java[TestFog.java] – FogFilter.
  85. === Light Scattering
  86. * link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/post/TestLightScattering.java[TestLightScattering.java] – LightScatteringFilter.
  87. === Vegetation
  88. * Contribution: xref:jme3/contributions/vegetationsystem/grass.adoc[Grass System]
  89. * Contribution: {uri-forum}t/generating-vegetation-paged-geometry-style/18928[Trees (WIP)]
  90. == Light and Shadows
  91. === Bloom and Glow
  92. [.right]
  93. image:effect/tanlglow1.png[tanlglow1.png,width="150",height="100"] +
  94. image:jme3/advanced/shadow-sponza-ssao.png[shadow-sponza-ssao.png,width="150",height="100",align="right"]
  95. * link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/post/TestBloom.java[TestBloom.java]
  96. * More details: xref:jme3/advanced/bloom_and_glow.adoc[Bloom and Glow] – BloomFilter.
  97. === Light
  98. * link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/light/TestSimpleLighting.java[TestSimpleLighting.java] – DirectionalLight, PointLight.
  99. * link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/light/TestLightRadius.java[TestLightRadius.java] – DirectionalLight, PointLight.
  100. * link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/light/TestManyLights.java[TestManyLights.java] – .j3o scene.
  101. * More details: xref:jme3/advanced/light_and_shadow.adoc[Light and Shadow]
  102. === Shadow
  103. [.right]
  104. image:jme3/advanced/shadow.png[shadow.png,width="150",height="100"] +
  105. image:jme3/advanced/light-sources.png[light-sources.png,width="150",height="100",align="right"]
  106. //* link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/light/TestShadow.java[TestShadow.java] – BasicShadowRenderer. (SceneProcessor)
  107. //* link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/light/TestPssmShadow.java[TestPssmShadow.java] – PssmShadowRenderer (SceneProcessor), also known as Parallel-Split Shadow Mapping (PSSM).
  108. * link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/post/TestSSAO.java[TestSSAO.java] +
  109. link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/post/TestSSAO2.java[TestSSAO2.java] – SSAOFilter, also known as Screen-Space Ambient Occlusion shadows (SSOA).
  110. *  link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/post/TestTransparentSSAO.java[TestTransparentSSAO.java] – SSAOFilter, also known as Screen-Space Ambient Occlusion shadows (SSOA), plus transparancy.
  111. * More details: xref:jme3/advanced/light_and_shadow.adoc[Light and Shadow]
  112. == Special: Glass, Metal, Dissolve, Toon
  113. === Toon Effect
  114. [.right]
  115. image::jme3/advanced/toon-dino.png[toon-dino.png,width="150",height="100"]
  116. * link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/post/TestCartoonEdge.java[TestCartoonEdge.java] – CartoonEdgeFilter.
  117. * link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/post/TestTransparentCartoonEdge.java[TestTransparentCartoonEdge.java] – CartoonEdgeFilter.
  118. === Fade in / Fade out
  119. * xref:jme3/advanced/fade.adoc[Fade] – FadeFilter
  120. === User Contributed
  121. [.float-group]
  122. --
  123. [.right]
  124. image:jme3/advanced/shaderblow_light1.jpg[shaderblow_light1.jpg,width="78",height="150"] +
  125. image:jme3/advanced/shaderblow_glass.jpg[shaderblow_glass.jpg,width="80",height="150",align="right"] +
  126. image:jme3/advanced/shaderblow_matcap.jpg[shaderblow_matcap.jpg,width="150",height="150",align="right"] +
  127. image:jme3/advanced/shaderblow_light2.jpg[shaderblow_light2.jpg,width="66",height="150",align="right"]
  128. xref:sdk:plugin/shaderblow.adoc[ShaderBlow - GLSL Shader Library]
  129. * LightBlow Shader – blend material texture maps.
  130. * FakeParticleBlow Shader – jet, fire effect.
  131. * ToonBlow Shader – Toon Shading, toon edges.
  132. * Dissolve Shader – Scifi teleportation/dissolve effect.
  133. * MatCap Shader – Gold, metals, glass, toons…!
  134. * Glass Shader – Glass.
  135. * Force Shield Shader – Scifi impact-on-force-field effect.
  136. * SimpleSprite Shader – Animated textures.
  137. * SimpleSpriteParticle Shader – Sprite library.
  138. * MovingTexture Shader – Animated cloud/mist texture.
  139. * SoftParticles Shader – Fire, clouds, smoke etc.
  140. * Displace Shader – Deformation effect: Ripple, wave, pulse, swell!
  141. Thanks for your awesome contributions! Keep them coming!
  142. --
  143. == Particle Emitters: Explosions, Fire, Smoke
  144. [.right]
  145. image:jme3/advanced/explosion-5.png[explosion-5.png,width="150",height="100"] +
  146. image:jme3/advanced/particle.png[particle.png,width="150",height="100",align="right"]
  147. xref:jme3/advanced/particle_emitters.adoc[Particle emitter effects] are highly configurable and can have any texture. They can simulate smoke, dust, leaves, meteors, snowflakes, mosquitos, fire, explosions, clusters, embers, sparks…
  148. * link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/effect/TestExplosionEffect.java[TestExplosionEffect.java] – debris, flame, flash, shockwave, smoke, sparks.
  149. * link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/effect/TestPointSprite.java[TestPointSprite.java] – cluster of points.
  150. * link:{uri-jmonkeyengine}jme3-examples/src/main/java/jme3test/effect/TestMovingParticle.java[TestMovingParticle.java] – dust, smoke.
  151. '''
  152. === Creating your own Filters
  153. Here is an extract taken from @nehon in the forum thread (link:{uri-forum}t/how-exactly-do-filters-work/26871[http://hub.jmonkeyengine.org/forum/topic/how-exactly-do-filters-work/])
  154. The methods are called in this order (pretty much the same flow as processors):
  155. - initFilter() is called once when the FilterPostPorcessor is initialized or when the filter is added to the processor and this one as already been initialized.
  156. for each frame the methods are called in that sequence :
  157. - preFrame() occurs before anything happens
  158. - postQueue() occcurs once the queues have been populated (there is one queue per bucket and 2 additional queues for the shadows, casters and recievers). Note that geometries in the queues are the one in the view frustum.
  159. - postFrame occurs once the main frame has been rendered (the back buffer)
  160. Those methods are optional in a filter, they are only there if you want to hook in the rendering process.
  161. The material variable is here for convenience. You have a getMaterial method that returns the material that’s gonna be used to render the full screen quad. It just happened that in every implementation I had a material attribute in all my sub-classes, so I just put it back in the abstract class. Most of the time getMaterial returns this attribute.
  162. Forced-technique can be any technique really, they are more related with the material system than to the filters but anyway. When you use a forced technique the renderer tries to select it on the material of each geometry, if the technique does not exists for the material the geometry is not rendered.
  163. You assume well about the SSAO filer, the normal of the scene are rendered to a texture in a pre pass.
  164. Passes : these are filters in filters in a way. First they are a convenient way to initialize a FrameBuffer and the associated textures it needs, then you can use them for what ever you want.
  165. For example, a Pass can be (as in the SSAO filter) an extra render of the scene with a forced technique, and you have to handle the render yourself in the postQueue method.
  166. It can be a post pass to do after the main filter has been rendered to screen (for example an additional blur pass used in SSAO again). You have a list of passes called postRenderPass in the Filter abstract class. If you add a pass to this list, it’ll be automatically rendered by the FilterPostProcessor during the filter chain.
  167. The bloom Filter does an intensive use of passes.
  168. Filters in a nutshell.
  169. '''
  170. See also:
  171. * xref:jme3/advanced/particle_emitters.adoc[Particle Emitters]
  172. * xref:jme3/advanced/bloom_and_glow.adoc[Bloom and Glow]
  173. * link:http://www.smashingmagazine.com/2008/08/07/50-photoshop-tutorials-for-sky-and-space-effects/[Photoshop Tutorial for Sky and space effects (article)]