Class RenderArea
- java.lang.Object
-
- com.openinventor.inventor.Inventor
-
- com.openinventor.remoteviz.rendering.RenderArea
-
public class RenderArea extends Inventor
Defines the rendering area for Open Inventor rendering. Implement the classRenderAreaListenerto receiveRenderAreaevents.When using
ServiceSettings.INVENTOR_SERVICEorServiceSettings.INVENTOR_APPLICATIONservice mode, this class provides access to the scene manager and the touch manager to modify the rendering.A
RenderAreaobject may be created automatically by RemoteViz or created explicitly by the application. When a client requests a connection (see RemoteVizRenderArea.connectTo()), it specifies a render area id. If a render area with that id does not exist, RemoteViz will create one and ServiceListener.onPendingCreateRenderArea() will be called. If a render area with the requested id exists, RemoteViz will use that one andServiceListener.onPendingShareRenderArea()will be called. An application might want to explicitly create a render area, for example, to preload a default scene graph.A
RenderAreamay have zero, one or multiple connections.A
RenderAreaallows the application to send text or binary messages to the associated client. A JavaScript client will receive the message using a listener (see RemoteVizRenderArea.addServiceListener). Messages from a client are received using one of theRenderAreaListener.onReceivedMessage()methods.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class com.openinventor.inventor.Inventor
Inventor.ConstructorCommand
-
-
Field Summary
-
Fields inherited from class com.openinventor.inventor.Inventor
VERBOSE_LEVEL, ZeroHandle
-
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddListener(RenderAreaListener listener)Adds aRenderAreaListenerto manage the renderArea.voidcloseConnectionsAndDispose()Closes all connections of the renderArea and disposes it.ConnectiongetConnection(int index)Gets an existingConnectionto the renderArea.ConnectiongetConnection(java.lang.String id)Gets an existingConnectionto the renderArea.SoGLContextgetGLContext()Gets the OpenGL context associated with the renderArea.java.lang.StringgetGpu()Gets the Graphics Processing Unit (GPU) used to render images.intgetHeight()Gets the renderArea height.java.lang.StringgetId()Gets the renderArea id.intgetNumConnections()Gets the number of connections (seeConnection) that exist for this renderArea.intgetNumListeners()Gets the number ofRenderAreaListener.SoSceneManagergetSceneManager()Gets the Open Inventor scene manager associated with the renderArea.SoTouchManagergetTouchManager()Gets the Open Inventor touch manager associated with the renderArea.intgetWidth()Gets the renderArea width.booleanisDisposed()Gets the state of theRenderArea: alive or disposed.voidremoveAllListeners()Removes all RenderAreaListeners.voidremoveListener(RenderAreaListener listener)Removes aRenderAreaListener.voidresize(int width, int height)Resizes the renderArea at a specific size.booleansendMessage(java.lang.String message)Calls sendMessage(message, new java.util.ArrayList<>()).booleansendMessage(java.lang.String message, java.util.Collection<Connection> excludedConnections)Sends a text message to the renderArea connections.booleansendMessage(java.util.Collection<java.lang.Byte> buffer)Calls sendMessage(buffer, new java.util.ArrayList<>()).booleansendMessage(java.util.Collection<java.lang.Byte> buffer, java.util.Collection<Connection> excludedConnections)Sends a binary message to the renderArea connections.-
Methods inherited from class com.openinventor.inventor.Inventor
dispose, getNativeResourceHandle
-
-
-
-
Method Detail
-
sendMessage
public boolean sendMessage(java.lang.String message)
Calls sendMessage(message, new java.util.ArrayList<>()).
-
sendMessage
public boolean sendMessage(java.util.Collection<java.lang.Byte> buffer)
Calls sendMessage(buffer, new java.util.ArrayList<>()).
-
getGpu
public java.lang.String getGpu()
Gets the Graphics Processing Unit (GPU) used to render images. GPU can be defined in ServiceListener.onPendingCreateRenderArea.- Returns:
- gpu used to compute the render.
- See Also:
RenderAreaHardware.setGpu
-
getConnection
public Connection getConnection(int index)
Gets an existingConnectionto the renderArea.- Parameters:
index- : index identifying theConnection- Returns:
- the connection object if the index exists, otherwise returns null.
-
getNumListeners
public int getNumListeners()
Gets the number ofRenderAreaListener.- Returns:
- number of
RenderAreaListener.
-
getNumConnections
public int getNumConnections()
Gets the number of connections (seeConnection) that exist for this renderArea.- Returns:
- the number of connections
-
getHeight
public int getHeight()
Gets the renderArea height.- Returns:
- the renderArea height
-
isDisposed
public boolean isDisposed()
Gets the state of theRenderArea: alive or disposed. RemoteViz does not keep a reference to theRenderAreaobject after the object is disposed. If the application kept a reference to the object, this method can be used to query its state.The state "disposed" will be set just after triggering the listener
ServiceListener.onDisposingRenderArea.- Returns:
- true if the renderArea is disposed or false if the renderArea is alive.
-
getConnection
public Connection getConnection(java.lang.String id)
Gets an existingConnectionto the renderArea.- Parameters:
id- : ID identifying theConnection- Returns:
- the connection object if the id exists, otherwise returns null.
-
getId
public java.lang.String getId()
Gets the renderArea id.- Returns:
- the ID identifying the renderArea
-
closeConnectionsAndDispose
public void closeConnectionsAndDispose()
Closes all connections of the renderArea and disposes it. If connections are still open, this method will close them and dispose the renderArea. While executing this method, the listenersServiceListener.onDisposingRenderAreaandServiceListener.onDisposedRenderAreawill be triggered and a DISPOSED disconnect message will be sent to all clients of the renderArea. The listenerRenderAreaListener.onClosedConnectionwill not be triggered after closing connections.See
isDisposed().
-
sendMessage
public boolean sendMessage(java.lang.String message, java.util.Collection<Connection> excludedConnections)Sends a text message to the renderArea connections.- Parameters:
message- : the message to be sent to all connections of the renderAreaexcludedConnections- : an excluded connections array- Returns:
- true if the message has been successfully sent to all connections, otherwise returns false.
-
sendMessage
public boolean sendMessage(java.util.Collection<java.lang.Byte> buffer, java.util.Collection<Connection> excludedConnections)Sends a binary message to the renderArea connections.- Parameters:
buffer- : the binary buffer to be sent to all connections of the renderAreaexcludedConnections- : an excluded connections array- Returns:
- true if the message has been successfully sent to all connections, otherwise returns false.
-
getWidth
public int getWidth()
Gets the renderArea width.- Returns:
- the renderArea width
-
resize
public void resize(int width, int height)Resizes the renderArea at a specific size. After resizing, a notification will be sent to all the renderArea clients. The minimum size is (128, 128) and the maximum size is (3840, 2160). If the size is inferior or superior to the limit, it will be adjusted automatically.- Parameters:
width- : new width of the renderAreaheight- : new height of the renderArea- See Also:
RenderAreaListener.onResize
-
addListener
public void addListener(RenderAreaListener listener)
Adds aRenderAreaListenerto manage the renderArea.- Parameters:
listener- : object that listens to the renderArea events
-
removeAllListeners
public void removeAllListeners()
Removes all RenderAreaListeners.
-
getSceneManager
public SoSceneManager getSceneManager()
Gets the Open Inventor scene manager associated with the renderArea. This object is created automatically by RemoteViz.In the
ServiceSettings.INDEPENDENT_SERVICEmode, this method returns null.- Returns:
- the sceneManager
-
getTouchManager
public SoTouchManager getTouchManager()
Gets the Open Inventor touch manager associated with the renderArea. This object is created automatically by RemoteViz.In the
ServiceSettings.INDEPENDENT_SERVICEmode, this method returns null.- Returns:
- the touchManager
-
getGLContext
public SoGLContext getGLContext()
Gets the OpenGL context associated with the renderArea. This object is created automatically by RemoteViz.In the
ServiceSettings.INDEPENDENT_SERVICEmode, this method returns null.- Returns:
- the OpenGL context
-
removeListener
public void removeListener(RenderAreaListener listener)
Removes aRenderAreaListener.- Parameters:
listener- : object that listens to the renderArea events
-
-