diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/audio.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/audio.html index 9273b5497..2e6e17a35 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/audio.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/audio.html @@ -180,8 +180,12 @@ A sound engineer can create a custom com.​jme3.​audio.Environment You can find more info about OpenAL and its advanced features here: -

+
+ sound, + documentation, + environment +

view online version

\ No newline at end of file diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/bullet_multithreading.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/bullet_multithreading.html index c47709931..c44358f00 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/bullet_multithreading.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/bullet_multithreading.html @@ -36,8 +36,12 @@ stateManager.attach(bulletAppState);

The physics update happens in parallel to rendering, after the users changes have been made in the update() call. This way the loop logic is still maintained: the user can set and change values in physics and scenegraph objects before render() and physicsUpdate() are called in parallel. More physics spaces can simply be added by using multiple bulletAppStates. -

+
+ documentation, + physics, + threading +

view online version

\ No newline at end of file diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/headless_server.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/headless_server.html index a1b2efeb9..ba6e7a596 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/headless_server.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/headless_server.html @@ -83,7 +83,6 @@ Okay, so you can now start your game in a headless 'server mode', wher
- intermediate, server, spidermonkey, headless, diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/hinges_and_joints.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/hinges_and_joints.html index 6720b3fe7..cff6c257e 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/hinges_and_joints.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/hinges_and_joints.html @@ -219,6 +219,11 @@ When you disable the motor, the chained nodes are exposed to gravity again:

joint.enableMotor(false, 0, 0);
+
+ documentation, + physics, + joint +

view online version

\ No newline at end of file diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/hud.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/hud.html index 02600def1..e941ac52f 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/hud.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/hud.html @@ -195,7 +195,8 @@ For HUDs, you basically follow the same instructions as for creating a normal gui, display, - documentation + documentation, + hud diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/loading_screen.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/loading_screen.html index 78107e094..e4b3bf7e2 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/loading_screen.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/loading_screen.html @@ -56,8 +56,8 @@ nifty_loading.xml   <screen id="loadlevel" controller = "jme3test.TestLoadingScreen"> <layer id="loadinglayer" childLayout="center" backgroundColor="#000000"> - <panel id = "loadingpanel" childLayout="vertical" align="center" valign="center" height="32px" width="400px"> - <control name="loadingbar" align="center" valign="center" width="400px" height="32px" /> + <panel id = "loadingpanel" childLayout="vertical" align="center" valign="center" height="32px" width="70%"> + <control name="loadingbar" align="center" valign="center" width="100%" height="100%" /> <control id="loadingtext" name="label" align="center" text=" "/> </panel> diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/monkey_zone.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/monkey_zone.html index fb29d228b..be9ef73a8 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/monkey_zone.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/monkey_zone.html @@ -319,6 +319,13 @@ MonkeyZone is hosted at GoogleCode, where you can check out the jMonkeyPlatform-
  • Run the server first (com.jme3.monkeyzone.ServerMain), and then a client (com.jme3.monkeyzone.ClientMain).
  • +
    + network, + basegame, + physics, + inputs, + spidermonkey +

    view online version

    \ No newline at end of file diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/networking.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/networking.html index 969cf77cd..a5a93da2a 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/networking.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/networking.html @@ -436,7 +436,8 @@ Learn more about documentation, - network + network, + spidermonkey diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui.html index 781fc02a9..98048262d 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui.html @@ -254,9 +254,10 @@ Next, learn how to lay out your graphical user interface. Typically, you start w
    - documentation, gui, - input + documentation, + nifty, + hud
    diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_java_interaction.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_java_interaction.html index 01f663783..fb2dd2a11 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_java_interaction.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_java_interaction.html @@ -307,8 +307,9 @@ You're done with the basic Nifty gui, documentation, input, - controller, - controllers + control, + hud, + nifty diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_java_layout.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_java_layout.html index 39b2749f2..527e9d89a 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_java_layout.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_java_layout.html @@ -628,6 +628,12 @@ Integrate the GUI into the g
  • Nifty GUI Projection (optional)
  • +
    + gui, + documentation, + nifty, + hud +

    view online version

    \ No newline at end of file diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_overlay.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_overlay.html index 0daf44d6d..b8deaf613 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_overlay.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_overlay.html @@ -79,8 +79,10 @@ Now that you have layed out and integrated the gui, documentation, - gui + nifty, + hud diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_projection.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_projection.html index 745808907..5e9145120 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_projection.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_projection.html @@ -97,8 +97,10 @@ Now that you have layed out and integrated the documentation, gui, + documentation, + nifty, + hud, texture diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_xml_layout.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_xml_layout.html index 54e3f2b94..39dcf5198 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_xml_layout.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/nifty_gui_xml_layout.html @@ -370,9 +370,10 @@ Integrate the GUI into the g
    - documentation, gui, - nifty + documentation, + nifty, + hud
    diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/open_game_finder.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/open_game_finder.html index 606d7f0e4..446e711f8 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/open_game_finder.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/open_game_finder.html @@ -187,6 +187,9 @@ A: Save the image files in the path jMonkeyProjects/OGF-Client-1.0-bin/OGF A: TBD +
    + network +

    view online version

    \ No newline at end of file diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/physics.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/physics.html index 7e8a8967e..71101321f 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/physics.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/physics.html @@ -523,9 +523,14 @@ removeCollideWithGroup(COLLISION_GROUP_01)Collision Groups are integer
      -
    • For large static meshes like shooter levels or terrain its best to divide the mesh into multiple physics objects to allow the less CPU intense broadphase to filter out most collision items.
      +
    • For large static meshes like shooter levels or terrain it is best to divide the scene model into multiple physics objects, with each its own CollisionShape. A huge city level should not be one huge mesh (model) of pavement and streets and buildings. Instead, you make individual models for buildings, for pieces of pavement, for pieces of streets, etc. Position them next to one another to form the whole city, and give each piece its own optimal CollisionShape. E.g. streets can use a fast PlaneCollisionShape if you keep them separate for buildings. Breaking the level into manageable pieces helps the engine improve performance: The less CPU-intensive can now filter out parts of the scene that are behind you or out of reach, and it only calculates the details of collisions for parts that are actually close to the action.
    +

    view online version

    \ No newline at end of file diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/physics_listeners.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/physics_listeners.html index 0a1e38589..03c6384e8 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/physics_listeners.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/physics_listeners.html @@ -165,6 +165,13 @@ getObjectB() The two participants in the collision. You cannot kno Note that after the collision method has been called the object is not valid anymore so you should copy any data you want to keep into local variables.

    +

    view online version

    \ No newline at end of file diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/ragdoll.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/ragdoll.html index 2be49dc8d..ed86f661e 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/ragdoll.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/ragdoll.html @@ -203,6 +203,14 @@ Read the documentation, + physics, + character, + NPC, + forces, + collisions +

    view online version

    \ No newline at end of file diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/update_loop.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/update_loop.html index 2c9cc500b..d58135914 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/update_loop.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/update_loop.html @@ -61,7 +61,7 @@ There are two strategies how advanced developers can spread out their init and u
    basegame, - controller, + control, input, init, keyinput, diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/vehicles.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/vehicles.html index 2a2df156d..721b9205e 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/vehicles.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/vehicles.html @@ -326,6 +326,12 @@ This example shows a very simple but functional vehicle. For a game you would im

    For a more advanced example, look at .

    +
    diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/walking_character.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/walking_character.html index 8c4bc9e54..3cab684bf 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/walking_character.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/advanced/walking_character.html @@ -334,6 +334,15 @@ This method resets the walk animation. if (channel == attackChannel) channel.setAnim("stand"); } public void onAnimChange(AnimControl control, AnimChannel channel, String animName) { } +

    view online version

    \ No newline at end of file diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_animation.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_animation.html index c165106e3..a8e588f79 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_animation.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_animation.html @@ -315,7 +315,6 @@ See also:

    beginner, - beginner,, intro, animation, documentation, diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_asset.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_asset.html index be4014f93..59cef6a06 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_asset.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_asset.html @@ -485,7 +485,6 @@ Let's add some action to the scene and continue with the beginner, - beginner,, intro, documentation, lightnode, @@ -493,6 +492,7 @@ Let's add some action to the scene and continue with the model, node, gui, + hud, texture
    diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_audio.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_audio.html index 6f8d7610f..348270cd1 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_audio.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_audio.html @@ -375,7 +375,6 @@ See also: diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_collision.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_collision.html index 613c5fda9..63bab7ede 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_collision.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_collision.html @@ -526,10 +526,8 @@ Related info:
    beginner, - beginner,, collision, - controller, - controllers, + control, intro, documentation, model, diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_input_system.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_input_system.html index 9cf0a2ca3..d0e0652cd 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_input_system.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_input_system.html @@ -362,7 +362,6 @@ Now you can already write a little interactive game! But wouldn't it be coo input, intro, beginner, - beginner,, documentation, keyinput, click diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_main_event_loop.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_main_event_loop.html index c70f8bd95..d64a8b8a6 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_main_event_loop.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_main_event_loop.html @@ -184,13 +184,11 @@ See also: Advanced jME3 developers additionally use documentation, - beginner,, state, states, intro, beginner, - controller, - controllers, + control, loop
    diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_material.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_material.html index a38aa0bc3..42cf185e5 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_material.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_material.html @@ -430,7 +430,6 @@ See also
    documentation, - beginner,, beginner, intro, model, diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_node.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_node.html index 5088678e1..6a7ca97eb 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_node.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_node.html @@ -373,11 +373,9 @@ You have learned that your 3D scene is a scene graph made up of Spatials: Visibl

    Since standard shapes like spheres and boxes get old fast, continue with the next chapter where you learn to load assets, such as 3-D models. -

    beginner, - beginner,, rootNode, node, intro, diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_physics.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_physics.html index 11bf3a0e8..9e41faefc 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_physics.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_physics.html @@ -640,7 +640,7 @@ You have learned how to activate the jBullet PhysicsSpace in an application by a documentation, input, model, - controller + control
    diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_picking.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_picking.html index 76f62a4e5..cca89a904 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_picking.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_picking.html @@ -527,7 +527,6 @@ See also:
    beginner, - beginner,, documentation, intro, node, diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_simpleapplication.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_simpleapplication.html index c2c5cf86c..a49cab246 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_simpleapplication.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_simpleapplication.html @@ -281,11 +281,12 @@ See also:
    diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_terrain.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_terrain.html index 053531b3f..23178932e 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_terrain.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/beginner/hello_terrain.html @@ -561,7 +561,6 @@ See also:
    beginner, - beginner,, heightmap, documentation, terrain, diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/intermediate/appsettings.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/intermediate/appsettings.html index 50d4f8e77..f27567989 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/intermediate/appsettings.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/intermediate/appsettings.html @@ -30,7 +30,7 @@ Set the boolean in the AppSettings contructor to true if you want to keep the de

    -

    Use app.setShowSettings(false); in the main() method to hide the default settings window (default splash screen) at startup. +

    Use app.setShowSettings(true); to present the user with a splashscreen and display settings dialog when starting the game, or app.setShowSettings(false); to hide the custom splashscreen. Set this boolean before calling app.start() on the SimpleApplication.

    @@ -40,15 +40,11 @@ Set the boolean in the AppSettings contructor to true if you want to keep the de
    - + - - - +
    Settings PropertyDscriptionDefaultSettings Property (Video)DescriptionDefault
    setRenderer(AppSettings.LWJGL_OPENGL2)
    setRenderer(AppSettings.LWJGL_OPENGL3)
    Switch Video RendererOpenGL 2
    setAudioRenderer(AppSettings.LWJGL_OPENAL)
    -setAudioRenderer(AppSettings.LWJGL_JOAL)
    Switch Audio RendererOpenAL
    setBitsPerPixel(8)Set color depth.
    @@ -78,20 +74,46 @@ Depending on your graphic card, you may be able to set multisampling to higher v
    setVSync(true)Set vertical syncing to true to time the frame buffer to coincide with the refresh interval of the screen: Prevents page tearing, but slower; recommened for release.
    Set to false to deactivate vertical syncing (faster, but possible page tearing artifacts); can be deactivated during development.
    false
    +
    - + - + - + + +
    useInput(false)Respond to user input by mouse and keyboard. Can be deactivated for use cases where you only display a 3D scene on the canvas without any interaction.trueSettings Property (Input)DescriptionDefault
    useJoysticks(true)Activate optional joystick supportfalsesetUseInput(false)Respond to user input by mouse and keyboard. Can be deactivated for use cases where you only display a 3D scene on the canvas without any interaction.true
    setSettingsDialogImage("/path/in/assets.png")A custom image to display when the settings dialog is shown."/com/jme3/app/Monkey.png"setUseJoysticks(true)Activate optional joystick supportfalse
    +
    + + + + + + + + + +
    Settings Property (Audio)DescriptionDefault
    setAudioRenderer(AppSettings.LWJGL_OPENAL)
    +setAudioRenderer(AppSettings.LWJGL_JOAL)
    Switch Audio RendererOpenAL
    setStereo3D(true)Enable 3D stereo. This feature requires hardware support from the GPU driver. See .false
    +
    + + + + + + + +
    Settings Property (Branding)DescriptionDefault
    setTitle("My Game")This string will be visible in the titlebar, unless the window is fullscreen."jMonkey Engine 3.0"
    setIcons(new BufferedImage[]{
    +ImageIO.read(new File("")), …});
    This specifies the little application icon in the titlebar of the application. You should specify the icon in various sizes (256,128,32,16) to look good on each OS. Note: This is not the application icon on the desktop.null
    setSettingsDialogImage("/path/to/splash.png")A custom splashscreen image in the assets directory which is displayed when the settings dialog is shown."/com/jme3/app/Monkey.png"
    - +

    Saving and Loading Settings

    @@ -102,13 +124,35 @@ Set to false to deactivate vertical syncing (faster, but possible page tearing a An AppSettings object also supports the following methods:

      -
    • Use settings.save(outstream) to save your settings via standard java.io serialization.
      +
    • Use settings.save("unique_key") to save your settings via standard java.io serialization.
    • -
    • Use settings.load(instream) to load your settings.
      +
    • Use settings.load("unique_key") to load your settings.
    • Use settings2.copyFrom(settings) to copy a settings object.
    +

    + +Usage: +

    + +

    +Provide the unique name of your jME3 application as the String argument. For example com.foo.MyCoolGame3. +

    +
        try { settings.save("com.foo.MyCoolGame3"); } 
    +    catch (BackingStoreException ex) { /** could not save settings */ }
    +
      +
    • On Windows, the preferences are saved under the following registry key:
      +HKEY_CURRENT_USER\Software\JavaSoft\Prefs\com\foo\MyCoolGame3
      +
    • +
    • On Linux, the preferences are saved in an XML file under:
      +$HOME/.java/.userPrefs/com/foo/MyCoolGame3
      +
    • +
    • On Mac OS X, the preferences are saved as XML file under:
      +$HOME/Library/Preferences/com.foo.MyCoolGame3.plist
      +
    • +
    +

    view online version

    \ No newline at end of file diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/intermediate/headlessserver.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/intermediate/headlessserver.html index 5d3c3a24c..ebe6ec753 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/intermediate/headlessserver.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/intermediate/headlessserver.html @@ -147,7 +147,7 @@ var NS='jme3:intermediate';var JSINFO = {"id":"jme3:intermediate:headlessserver" - + @@ -302,7 +302,7 @@ You've followed a link to a topic that doesn't exist yet. If permissio
    -
      +
     
    @@ -353,7 +353,7 @@ You've followed a link to a topic that doesn't exist yet. If permissio - +
    diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/intermediate/simpleapplication.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/intermediate/simpleapplication.html index d2657ebd2..72a766ede 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/intermediate/simpleapplication.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/intermediate/simpleapplication.html @@ -172,12 +172,7 @@ The com.jme3.app.SimpleApplication class extends the generic com.jme3.app.Applic

    -

    By default, a SimpleApplication also displays statistics (such as frames per second) on the screen, using the com.jme3.app.StatsView class. You hide the statistics HUD from the screen by calling setDisplayFps(false); setDisplayStatView(false); inside the simpleInitApp() method. The displays contain valuable information during the development and debugging phase. At the latest, you remove these displays for the release. -

    -

    - -

    -Additional to the functionality that Application brings, SimpleApplication offers: +Additional to the functionality that Application brings, SimpleApplication offers the following methods and fields that can be used, for example, inside the simpleInitApp() method:

    @@ -197,35 +192,44 @@ getGuiNode()
    Attach flat GUIThe default first-person fly-by camera control. This default camera control lets you navigate the 3D scene using the preconfigured WASD and arrow keys and the mouse.
    -
    +
    - + + + + - + - +
    SimpleApplication MethodPurpose
    loadStatsView()Call this method to print live statistic information to the screen, such as current frames-per-second and triangles/vertices counts. You use this info typically only during development or debugging.loadStatsView();Call this method to print live statistic information to the screen, such as current frames-per-second and triangles/vertices counts. You use this info typically only during development or debugging.
    loadFPSText();Call this method to print the current framerate (frames per second) to the screen.
    loadFPSText()Call this method to print the current framerate (frames per second) to the screen.setDisplayFps(false);A default SimpleApplication displays the framerate (frames per second) on the screen. You can choose to deactivate the FPS display using this command.
    setShowSettings(true)Whether the user should be presented with a splashscreen and display settings dialog when starting the game. Set this boolean before calling start() on the SimpleApplication.setDisplayStatView(false);A default SimpleApplication displays mesh statistics on the screen using the com.jme3.app.StatsView class. The information is valuable during the development and debugging phase, but for the release, you should hide the statistics HUD.
    -
    +
    - + - + - +
    SimpleApplication InterfacePurpose
    simpleInitApp()Override this method to initialize the game scene. Here you load and create objects, attach Spatials to the rootNode, and bring everything in its starts position. See also Application States for best practies.public void simpleInitApp()Override this method to initialize the game scene. Here you load and create objects, attach Spatials to the rootNode, and bring everything in its starts position. See also Application States for best practices.
    simpleUpdate(float tpf)Override this method to have access to the update loop. Use this loop to poll the current game state and respond to changes, or to let the game mechanics generate encounters and initiate state changes. Use tpd (time per frame) as a factor to time events. For more info on how to hook into the update loop, see Application States and Custom Controls. public void simpleUpdate(float tpf)Override this method to have access to the update loop. Use this loop to poll the current game state and respond to changes, or to let the game mechanics generate encounters and initiate state changes. Use tpf (time per frame) as a factor to time events. For more info on how to hook into the update loop, see Application States and Custom Controls.
    simpleRender()Optional: Override this method to implement advanced modifications of the frameBuffer and scene graph.public void simpleRender(RenderManager rm)Optional: Override this method to implement advanced modifications of the frameBuffer and scene graph.
    - + +

    + +

    Use app.setShowSettings(true); to present the user with a splashscreen and display settings dialog when starting the game, or app.setShowSettings(false); to hide the custom splashscreen. Set this boolean before calling app.start() on the SimpleApplication. +

    +

    +

    Default Input Mappings

    @@ -250,7 +254,7 @@ The following default navigational input actions are mapped by the default KEY_MPrints memory usage stats the out stream.
    - +

    As long as useInput() is true, the default Flyby Cam is active. Then the following so-called "WASD" inputs are additionally available: @@ -300,7 +304,7 @@ As long as useInput() is true, the default Flyby Cam is active. Then the followi Rotate dragHold left mouse button and move -

    +
    display, basegame, documentation, diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/terminology.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/terminology.html index e3d24de20..b4713ff5c 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/terminology.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/jme3/terminology.html @@ -3,8 +3,8 @@

    -Before you start, make certain you are familiar with the following concepts and terminology. +Before you start, make certain you are familiar with the following concepts and terminology.

    @@ -24,7 +24,6 @@ Before you start, make certain you are familiar with the following concepts and

    OpenAL is the Open Audio Library, a platform-independent 3D audio API. -

    @@ -33,6 +32,7 @@ Before you start, make certain you are familiar with the following concepts and

    + The jME Context makes settings, renderer, timer, input and event listeners, display system, accessible to a JME game.

      @@ -59,10 +59,13 @@ The jME Context makes settings, renderer, timer, input and even

      + Coordinates represent a location in a coordinate system, relative to the origin (0,0,0). m. In 3D space, you need to specify three coordinate values to locate a point: x,y,z. As opposed to a vector (which looks similar), a coordinate does not have a "direction". - +

      +

      +

      @@ -71,9 +74,9 @@ As opposed to a vector (which looks similar), a coordinate does not have a "

      + The origin is the central point in the 3D world. It's at the coordinates (0,0,0). Code sample: Vector3f origin = new Vector3f( Vector3f.ZERO ); -

      @@ -82,9 +85,9 @@ Code sample: Vector3f origin = new Vector3f( Vector3f.ZERO );

      + A vector has a length and a direction. It is used like an arrow pointing at a point in 3D space. A vector starts at the origin (0,0,0), and ends at the target coordinate (x,y,z). Backwards directions are expressed with negative values. Code sample: Vector3f v = new Vector3f( 17 , -4 , 0 ); -

      @@ -93,6 +96,7 @@ Code sample: Vector3f v = new Vector3f( 17 , -4 , 0 );

      + A unit vector is a basic vector with a length of 1 world unit. Since its length is fixed (and it thus can only point at one location anyway), the only interesting thing about this vector is its direction.

        @@ -106,16 +110,23 @@ A unit vector is a basic vector with a length of 1 world unit. Since it
      +

      +Negate the vegator to change its direction, e.g. (-1, 0, 0) = left. +

      +

      Normalized Vectors

      + A normalized vector is a custom unit vector. A normalized vector is not the same as a (surface) normal vector. When you normalize a vector, it still has the same direction, but you lose the information where the vector originally pointed. -For instance, you normalize vectors before calculating angles. +

      +

      +Example: You normalize vectors before calculating angles.

      @@ -124,9 +135,9 @@ For instance, you normalize vectors before calculating angles.

      + A surface normal is a vector that is perpendicular to a plane. You calculate the Surface Normal by calculating the cross product. -

      @@ -135,12 +146,15 @@ You calculate the Surface Normal by calculating the cross product.

      + The cross product is a calculation that you use to find a perpendicular vector (an orthogonal, a "right angle" at 90°). In 3D space, speaking of an orthogonal only makes sense with respect to a plane. You need two vectors to uniquely define a plane. The cross product of the two vectors, v1 × v2, is a new vector that is perpendicular to this plane. A vector perpendicular to a plane is a called Surface Normal. -Example: The x unit vector and the y unit vector together define the x/y plane. The vector perpendicular to them is the z axis. JME can calculate that this equation is true:
      +

      -( Vector3f.UNIT_X.cross( Vector3f.UNIT_Y ) ).equals( Vector3f.UNIT_Z ) == true +

      +Example: The x unit vector and the y unit vector together define the x/y plane. The vector perpendicular to them is the z axis. JME can calculate that this equation is true:
      +( Vector3f.UNIT_X.cross( Vector3f.UNIT_Y ) ).equals( Vector3f.UNIT_Z ) == true

      @@ -149,12 +163,24 @@ Example: The x unit vector and the y unit vector together define the x/y plane.

      + +

      + +

      Most visible objects in a 3D scene are made up of polygon meshes – characters, terrains, buildings, etc. A mesh is a grid-like structure that represents a complex shape. The advantage of a mesh is that it is mathematically simple enough to render in real time, and detailed enough to be recognizable. +

      + +

      Every shape is reduced to a number of connected polygons, usually triangles; even round surfaces such as spheres are reduced to a grid of triangles. The polygons' corner points are called vertices. Every vertex is positioned at a coordinate, all vertices together describe the outline of the shape. -You create 3D meshes in tools called mesh editors, e.g in Blender. -Learn more about 3D maths here. +

      +

      +You create 3D meshes in tools called mesh editors, e.g in Blender. The jMonkeyEngine can load finished meshes (=models) and arrange them to scenes, but it cannot edit the mesh itself. +

      + +

      +Learn more about 3D maths here.

      @@ -163,8 +189,8 @@ You create 3D meshes in tools called mesh editors, e.g in Blender.

      -What we call "color" is merely part of an object's light reflection. The onlooker's brain uses shading and reflecting properties to infer an object's shape and material. Factors like these make all the difference between chalk vs milk, skin vs paper, water vs plastic, etc! () +What we call "color" is merely part of an object's light reflection. The onlooker's brain uses shading and reflecting properties to infer an object's shape and material. Factors like these make all the difference between chalk vs milk, skin vs paper, water vs plastic, etc! ()

      @@ -252,7 +278,6 @@ Set the Specular color to ColorRGBA.Black to switch off shininess.

    -

    @@ -261,9 +286,9 @@ Set the Specular color to ColorRGBA.Black to switch off shininess.

    + Textures are part of Materials. In the simplest case, an object could have just one texture, the Color Map, loaded from one image file. When you think back of old computer games you'll remember this looks quite plain. The more information you (the game designer) provide additionally to the Color Map, the higher the degree of detail and realism. Whether you want photo-realistic rendering or "toon" rendering (Cel Shading), everything depends on the quality of your materials and texture maps. Modern 3D graphics use several layers of information to describe one material, each layer is a Texture Map. -

    @@ -380,10 +405,16 @@ A seamless texture is an image file that has been designed so that it can be use

    + -Creating a texture for a cube is easy – but what about a character with a face and extremities? For more complex objects, you design the texture in the same ways as a sewing pattern: One image file contains the outline of the front, back, and side of the object, next to one another. Specific areas of the flat texture (UV coordinates) map onto certain areas of your 3D model (XYZ coordinates), hence the name UV map. -Getting the seams and mappings right is crucial: You will have to use a graphic tool like Blender to create UV Maps. It's worth the while to learn this, UV mapped models look a lot more professional. +

    +

    +Creating a texture for a cube is easy – but what about a character with a face and extremities? For more complex objects, you design the texture in the same ways as a sewing pattern: One image file contains the outline of the front, back, and side of the object, next to one another. Specific areas of the flat texture (UV coordinates) map onto certain areas of your 3D model (XYZ coordinates), hence the name UV map. Using UV Maps, models can have a different texture on each side. +

    + +

    +Getting the seams and mappings right is crucial: You must use a graphic tool like Blender to create UV Maps and store the coordinates. It's worth the while to learn this, UV mapped models look a lot more professional.

    @@ -392,10 +423,13 @@ Getting the seams and mappings right is crucial: You will have to use a graphic

    + +

    + +

    Environment Maps are used to create the impression of reflections and refractions. You create a Cube Map to represent your environment, similar to a skybox. (Sphere Maps are possible, but often look too distorted.) You give the Cube Map a set of images showing a "360° view" of the completed scene. The renderer uses this as base to texture the reflective surface. Of course these reflections are static and not "real", e.g. the player will not see his avatar's face reflected, etc… But they cause the desired "glass/mirror/water" effect, and are fast enough to render in real usecases, it's better than nothing. -

    @@ -404,8 +438,8 @@ Of course these reflections are static and not "real", e.g. the player

    -You provide the texture in two or three resolutions to be stored in one file (MIP = "multum in parvo" = "many in one"). Depending on how close (or far) the camera is, the engine automatically renders a more (or less) detailed texture for the object. Thus objects look smooth from close up, but don't waste resources with unspottable details when far away. Good for everything, but requires more time to create and more space to store textures. +You provide the texture in two or three resolutions to be stored in one file (MIP = "multum in parvo" = "many in one"). Depending on how close (or far) the camera is, the engine automatically renders a more (or less) detailed texture for the object. Thus objects look smooth from close up, but don't waste resources with unspottable details when far away. Good for everything, but requires more time to create and more space to store textures.

    @@ -414,10 +448,16 @@ You provide the texture in two or three resolutions to be stored in one file (MI

    + A procedural texture is generated from repeating one small image, plus some pseudo-random, gradient variations (Perlin noise). Procedural textures look more natural than static rectangular textures, for instance, they look less distorted on spheres. On big meshes, their repetitiveness is much less noticable than tiled seamless textures. Procedural textures are ideal for irregular large-area textures like grass, soil, rock, rust, and walls. See also: +

    + +

    -See also: , +

    +

    +See also: ,

    @@ -426,9 +466,9 @@ See also:

    + In 3D games, Skeletal Animation is used for animated characters, but in principle the skeleton approach can be extended to any 3D mesh (for example, an opening crate's hinge can be considered a joint). Unless you animate a 3D cartoon, realism of animated characters is generally a problem: Movement can look alien-like mechanical or broken, the character appears hollow, or as if floating. Professional game designers invest a lot of effort to make characters animate in a natural way (including motion capturing). -

    @@ -437,8 +477,15 @@ Unless you animate a 3D cartoon, realism of animated characters is generally a p

    + +

    + +

    An animated character has an armature: An internal skeleton (Bones) and an external surface (Skin). The Skin is the visible outside of the character and it includes clothing. The Bones are not visible and are used to interpolate (calculate) the morphing steps of the skin. +

    + +

    JME3, the game engine, only loads and plays your recorded animations. You must use a tool (such as Blender) to set up (rig, skin, and animate) a character.

      @@ -494,7 +541,6 @@ E.g. when the thigh bone moves, the leg is fully affected, the hips joints less

      In the JME3 application, you register animated models to the Animation Controller. The controller object gives you access to the available animation sequences. The controller has several channels, each channels can run one animation sequence at a time. To run several sequences, you create several channels, and run them in parallel. -

    @@ -514,8 +560,8 @@ Non-player (computer-controlled) characters (NPCs) are only fun in a game if the The domain of artificial intelligence deals, among other things, with:

      -
    • Knowledge – An agent only "knows" what it can "see and hear", this implies that information can be hidden from it (to keep the game fair). You can let some agents share knowledge and let others find out by themselves.
      -Example: All guards with two-way radios know the player's position within 60 sec, while other guards don't know anything yet.
      +
    • Knowledge – Knowledge is about the data to which the agent has access to base its decisions on. Realistic agents only "know" what they "see and hear", this implies that information can be hidden from them (to keep the game fair). You can let some agents share information and others need to find out by themselves.
      +Example: After tripping the wire, all guards with two-way radios start moving towards the player's position within 60 sec, while minor guards don't suspect anything yet.
    • Goal Planning – Planning is about how the agent takes action. Each game agent has the priority to achieve a specific goal, to reach a future state. You split the agent's goal into subgoals, then the agent chooses from available tactics and strategies, and prioritizes them. The agent keeps testing whether the current state is closer to the (sub)goal. If unsuccessful, the agent changes the tactics/strategy and tries again.
      Example: An agent searches the best path to reach the player base in a changing environment; an agent chases the player with the goal of eliminating him; an agent hides from the player with the goal of murdering a VIP.
      diff --git a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/sdk/model_loader_and_viewer.html b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/sdk/model_loader_and_viewer.html index d67584520..3e1551eee 100644 --- a/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/sdk/model_loader_and_viewer.html +++ b/sdk/jme3-core/javahelp/com/jme3/gde/core/docs/sdk/model_loader_and_viewer.html @@ -8,7 +8,7 @@ JMonkeyPlatform imports models from your project and stores them in the assets f

      -Presently, is the preferred modelling tool for jME3 as it is also Open-Source Software and an exporter for OgreXML files exists. Note that the OgreXML exporter is not yet compatible with Blender 2.5alpha! +Presently, is the preferred modelling tool for jME3 as it is also Open-Source Software and an exporter for OgreXML files exists. Note that the OgreXML exporter is not compatible with Blender 2.49 or before!