Package com.jme3.app
Class VRAppState
java.lang.Object
com.jme3.app.state.AbstractAppState
com.jme3.app.VRAppState
- All Implemented Interfaces:
- AppState
A JMonkey app state dedicated to Virtual Reality.
 An application that want to use VR devices (HTC vive, ...) has to use this app state.
As this app state and the main
 
As this app state and the main
application have to share application settings,
 the common way to use this app state is:- To create application settingsand set the VR related settings (seeVRConstants).
- To instantiate this app state with the created settings.
- To instantiate the main applicationand to attach it to the created settings (withsetSettings(AppSettings)).
- To start the main application.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionbooleanIs the application has not to start within VR mode (default isfalse).static final StringFields inherited from class com.jme3.app.state.AbstractAppStateinitialized
- 
Constructor SummaryConstructorsConstructorDescriptionVRAppState(VREnvironment environment) Create a new default VR app state that relies on the givenVR environment.VRAppState(AppSettings settings, VREnvironment environment) Create a new VR app state with given settings.
- 
Method SummaryModifier and TypeMethodDescriptionvoidcleanup()Called byAppStateManagerwhen transitioning thisAppStatefrom terminating to detached.Get theApplicationto which this app state is attached.Get the observer final position within the scene.Get the observer final rotation within the scene.Get the VR headset left viewport.Get the scene observer.Get the VR headset right viewport.Get thesettingsattached to this app state.Get thestate managerto which this app state is attached.Return theVR environmenton which this app state relies.Get the GUI manager attached to this app state.Get the VR underlying hardware.Get the VR dedicated input.Get the VR mouse manager attached to this app state.Get the VR view manager.voidinitialize(AppStateManager stateManager, Application app) Called byAppStateManagerwhen transitioning thisAppStatefrom initializing to running.
 This will happen on the next iteration through the update loop afterAppStateManager.attach(com.jme3.app.state.AppState)was called.booleanCheck if the rendering is instanced (see Geometry instancing).voidMove filters from the main scene into the eye's.voidCalled after all rendering commands are flushed.protected voidprocessSettings(AppSettings settings) Process the attached settings and apply changes to this app state.voidrender(RenderManager rm) Render the state.voidSet the background color for both left and right view ports.voidsetFrustrumNearFar(float near, float far) Set the frustum values for the application.voidsetMirrorWindowSize(int width, int height) Set the mirror window size in pixel.voidsetObserver(Spatial observer) Set the scene observer.voidsetResolutionMultiplier(float val) Set the resolution multiplier.voidsetSettings(AppSettings settings) Set thesettingsattached to this app state.voidsimpleRender(RenderManager renderManager) Rendering callback of the app state.voidsimpleUpdate(float tpf) Simple update of the app state, this method should contain any spatial updates.voidstateAttached(AppStateManager stateManager) Called byAppStateManager.attach(com.jme3.app.state.AppState)when transitioning thisAppStatefrom detached to initializing.voidstateDetached(AppStateManager stateManager) Called byAppStateManager.detach(com.jme3.app.state.AppState)when transitioning thisAppStatefrom running to terminating.voidupdate(float tpf) Called to update theAppState.Methods inherited from class com.jme3.app.state.AbstractAppStategetId, isEnabled, isInitialized, setEnabled, setId
- 
Field Details- 
ID- See Also:
 
- 
DISABLE_VRpublic boolean DISABLE_VRIs the application has not to start within VR mode (default isfalse).
 
- 
- 
Constructor Details- 
VRAppStateCreate a new default VR app state that relies on the givenVR environment.- Parameters:
- environment- the- VR environmentthat this app state is using.
 
- 
VRAppStateCreate a new VR app state with given settings. The app state relies on the givenVR environment.- Parameters:
- settings- the settings to use.
- environment- the- VR environmentthat this app state is using.
 
 
- 
- 
Method Details- 
simpleUpdatepublic void simpleUpdate(float tpf) Simple update of the app state, this method should contain any spatial updates. This method is called by theupdate()method and should not be called manually.- Parameters:
- tpf- the application time.
 
- 
simpleRenderRendering callback of the app state. This method is called by theupdate()method and should not be called manually.- Parameters:
- renderManager- the- render manager.
 
- 
setFrustrumNearFarpublic void setFrustrumNearFar(float near, float far) Set the frustum values for the application.- Parameters:
- near- the frustum near value.
- far- the frustum far value.
 
- 
setMirrorWindowSizepublic void setMirrorWindowSize(int width, int height) Set the mirror window size in pixel.- Parameters:
- width- the width of the mirror window in pixel.
- height- the height of the mirror window in pixel.
 
- 
setResolutionMultiplierpublic void setResolutionMultiplier(float val) Set the resolution multiplier.- Parameters:
- val- the resolution multiplier.
 
- 
moveScreenProcessingToVRpublic void moveScreenProcessingToVR()Move filters from the main scene into the eye's. This removes filters from the main scene.
- 
getFinalObserverRotationGet the observer final rotation within the scene.- Returns:
- the observer final rotation within the scene.
- See Also:
 
- 
getFinalObserverPositionGet the observer final position within the scene.- Returns:
- the observer position.
- See Also:
 
- 
getLeftViewPortGet the VR headset left viewport.- Returns:
- the VR headset left viewport.
- See Also:
 
- 
getRightViewPortGet the VR headset right viewport.- Returns:
- the VR headset right viewport.
- See Also:
 
- 
setBackgroundColorsSet the background color for both left and right view ports.- Parameters:
- clr- the background color.
 
- 
getApplicationGet theApplicationto which this app state is attached.- Returns:
- the Applicationto which this app state is attached.
- See Also:
 
- 
getStateManagerGet thestate managerto which this app state is attached.- Returns:
- the state managerto which this app state is attached.
- See Also:
 
- 
getObserverGet the scene observer. If no observer has been set, this method returns the application camera.- Returns:
- the scene observer.
- See Also:
 
- 
setObserverSet the scene observer. The VR headset will be linked to it. If no observer is set, the VR headset is linked to the application camera.- Parameters:
- observer- the scene observer.
 
- 
isInstanceRenderingpublic boolean isInstanceRendering()Check if the rendering is instanced (see Geometry instancing).- Returns:
- trueif the rendering is instanced and- falseotherwise.
 
- 
getVREnvironmentReturn theVR environmenton which this app state relies.- Returns:
- the VR environmenton which this app state relies.
 
- 
getVRHardwareGet the VR underlying hardware.- Returns:
- the VR underlying hardware.
 
- 
getVRinputGet the VR dedicated input.- Returns:
- the VR dedicated input.
 
- 
getVRViewManagerGet the VR view manager.- Returns:
- the VR view manager.
 
- 
getVRGUIManagerGet the GUI manager attached to this app state.- Returns:
- the GUI manager attached to this app state.
 
- 
getVRMouseManagerGet the VR mouse manager attached to this app state.- Returns:
- the VR mouse manager attached to this application.
 
- 
getSettingsGet thesettingsattached to this app state.- Returns:
- the settingsattached to this app state.
- See Also:
 
- 
setSettingsSet thesettingsattached to this app state.- Parameters:
- settings- the- settingsattached to this app state.
- See Also:
 
- 
updatepublic void update(float tpf) Description copied from interface:AppStateCalled to update theAppState. This method will be called every render pass if theAppStateis both attached and enabled.- Specified by:
- updatein interface- AppState
- Overrides:
- updatein class- AbstractAppState
- Parameters:
- tpf- Time since the last call to update(), in seconds.
 
- 
renderDescription copied from interface:AppStateRender the state. This method will be called every render pass if theAppStateis both attached and enabled.- Specified by:
- renderin interface- AppState
- Overrides:
- renderin class- AbstractAppState
- Parameters:
- rm- RenderManager
 
- 
postRenderpublic void postRender()Description copied from interface:AppStateCalled after all rendering commands are flushed. This method will be called every render pass if theAppStateis both attached and enabled.- Specified by:
- postRenderin interface- AppState
- Overrides:
- postRenderin class- AbstractAppState
 
- 
initializeDescription copied from interface:AppStateCalled byAppStateManagerwhen transitioning thisAppStatefrom initializing to running.
 This will happen on the next iteration through the update loop afterAppStateManager.attach(com.jme3.app.state.AppState)was called.AppStateManagerwill call this only from the update loop inside the rendering thread. This means is it safe to modify the scene graph from this method.- Specified by:
- initializein interface- AppState
- Overrides:
- initializein class- AbstractAppState
- Parameters:
- stateManager- The state manager
- app- The application
 
- 
stateAttachedDescription copied from interface:AppStateCalled byAppStateManager.attach(com.jme3.app.state.AppState)when transitioning thisAppStatefrom detached to initializing.There is no assumption about the thread from which this function is called, therefore it is unsafe to modify the scene graph from this method. Please use AppState.initialize(com.jme3.app.state.AppStateManager, com.jme3.app.Application)instead.- Specified by:
- stateAttachedin interface- AppState
- Overrides:
- stateAttachedin class- AbstractAppState
- Parameters:
- stateManager- State manager to which the state was attached to.
 
- 
cleanuppublic void cleanup()Description copied from interface:AppStateCalled byAppStateManagerwhen transitioning thisAppStatefrom terminating to detached. This method is called the following render pass after theAppStatehas been detached and is always called once and only once for each timeinitialize()is called. Either when theAppStateis detached or when the application terminates (if it terminates normally).- Specified by:
- cleanupin interface- AppState
- Overrides:
- cleanupin class- AbstractAppState
 
- 
stateDetachedDescription copied from interface:AppStateCalled byAppStateManager.detach(com.jme3.app.state.AppState)when transitioning thisAppStatefrom running to terminating.There is no assumption about the thread from which this function is called, therefore it is unsafe to modify the scene graph from this method. Please use AppState.cleanup()instead.- Specified by:
- stateDetachedin interface- AppState
- Overrides:
- stateDetachedin class- AbstractAppState
- Parameters:
- stateManager- The state manager from which the state was detached from.
 
- 
processSettingsProcess the attached settings and apply changes to this app state.- Parameters:
- settings- the app settings to process.
 
 
-