Class SelectionTool
java.lang.Object
java.awt.event.MouseAdapter
com.marginallyclever.ro3.apps.viewport.viewporttool.SelectionTool
- All Implemented Interfaces:
ViewportTool
,MouseListener
,MouseMotionListener
,MouseWheelListener
,EventListener
A selection tool allows the user to click on the 3D view and change the current Registry.selection
.
-
Field Summary
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
This method is called when the tool is activated.void
Force cancel the tool.void
This method is called when the tool is deactivated.void
dispose
(com.jogamp.opengl.GL3 gl3) This is called when the OpenGL context is destroyed.void
getComponents
(List<JPanel> list) Build a Swing Component that represents this Tool.javax.vecmath.Point3d
Returns the point on the tool clicked by the user.void
handleMouseEvent
(MouseEvent event) Handles mouse input events for the tool.void
init
(com.jogamp.opengl.GL3 gl3) This is called when the OpenGL context is created.boolean
isInUse()
Returns true if the tool is active (was clicked correctly and could be dragged)void
render
(com.jogamp.opengl.GL3 gl, ShaderProgram shaderProgram) Renders any tool-specific visuals to the 3D scene.void
Sets the frame of reference for the tool.void
setViewport
(Viewport viewport) void
update
(double deltaTime) Updates the tool's internal state, if necessary.Methods inherited from class java.awt.event.MouseAdapter
mouseClicked, mouseDragged, mouseEntered, mouseExited, mouseMoved, mousePressed, mouseReleased, mouseWheelMoved
Methods inherited from class java.lang.Object
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface com.marginallyclever.ro3.apps.viewport.viewporttool.ViewportTool
mouseDragged, mouseMoved, mousePressed, mouseReleased
-
Field Details
-
PICK_POINT_NAME
- See Also:
-
-
Constructor Details
-
SelectionTool
public SelectionTool()
-
-
Method Details
-
activate
This method is called when the tool is activated. It receives the SelectedItems object containing the selected entities and their initial world poses.- Specified by:
activate
in interfaceViewportTool
- Parameters:
list
- The selected items to be manipulated by the tool.
-
deactivate
public void deactivate()This method is called when the tool is deactivated. It allows the tool to perform any necessary cleanup actions before another tool takes over.- Specified by:
deactivate
in interfaceViewportTool
-
handleMouseEvent
Handles mouse input events for the tool.- Specified by:
handleMouseEvent
in interfaceViewportTool
- Parameters:
event
- The MouseEvent object representing the input event.
-
update
public void update(double deltaTime) Updates the tool's internal state, if necessary.- Specified by:
update
in interfaceViewportTool
- Parameters:
deltaTime
- Time elapsed since the last update.
-
render
Renders any tool-specific visuals to the 3D scene.- Specified by:
render
in interfaceViewportTool
- Parameters:
gl
- The OpenGL context.
-
setViewport
- Specified by:
setViewport
in interfaceViewportTool
-
isInUse
public boolean isInUse()Returns true if the tool is active (was clicked correctly and could be dragged)- Specified by:
isInUse
in interfaceViewportTool
- Returns:
- true if the tool is active (was clicked correctly and could be dragged)
-
cancelUse
public void cancelUse()Force cancel the tool. useful if two viewporttools are activated at once.- Specified by:
cancelUse
in interfaceViewportTool
-
getStartPoint
public javax.vecmath.Point3d getStartPoint()Returns the point on the tool clicked by the user. This is used to determine which tool is closer to the user.- Specified by:
getStartPoint
in interfaceViewportTool
- Returns:
- the point on the tool clicked by the user.
-
setFrameOfReference
Sets the frame of reference for the tool.- Specified by:
setFrameOfReference
in interfaceViewportTool
- Parameters:
index
- 0 for world, 1 for local, 2 for camera.
-
init
public void init(com.jogamp.opengl.GL3 gl3) Description copied from interface:ViewportTool
This is called when the OpenGL context is created. It should create any resources.- Specified by:
init
in interfaceViewportTool
- Parameters:
gl3
- the OpenGL context.
-
dispose
public void dispose(com.jogamp.opengl.GL3 gl3) Description copied from interface:ViewportTool
This is called when the OpenGL context is destroyed. It should release any resources.- Specified by:
dispose
in interfaceViewportTool
- Parameters:
gl3
- the OpenGL context.
-
getComponents
Description copied from interface:ViewportTool
Build a Swing Component that represents this Tool.- Specified by:
getComponents
in interfaceViewportTool
- Parameters:
list
- the list to add components to.
-