X-Git-Url: http://www2.svjatoslav.eu/gitweb/?p=sixth-3d.git;a=blobdiff_plain;f=src%2Fmain%2Fjava%2Feu%2Fsvjatoslav%2Fsixth%2Fe3d%2Fgui%2FRenderingContext.java;h=b6417e5aa7a66b1377bea912b6b64209baf8ccb3;hp=3641bc9e12f53ee74c0e10b3a606602346a7f569;hb=a377e3094d304bbc815b36edc2eb303ec023ea48;hpb=8aa50f568d2edcfe974ceed4192158951e7f3215 diff --git a/src/main/java/eu/svjatoslav/sixth/e3d/gui/RenderingContext.java b/src/main/java/eu/svjatoslav/sixth/e3d/gui/RenderingContext.java index 3641bc9..b6417e5 100644 --- a/src/main/java/eu/svjatoslav/sixth/e3d/gui/RenderingContext.java +++ b/src/main/java/eu/svjatoslav/sixth/e3d/gui/RenderingContext.java @@ -28,11 +28,11 @@ public class RenderingContext { /** * UI component that mouse is currently hovering over. */ - private MouseInteractionController currentMouseOverComponent; + private MouseInteractionController objectPreviouslyUnderMouseCursor; public void prepareForNewFrameRendering(){ mouseEvent = null; - objectUnderMouse = null; + currentObjectUnderMouseCursor = null; } /** @@ -51,15 +51,15 @@ public class RenderingContext { /** * Item that user clicked on. */ - private MouseInteractionController objectUnderMouse; + private MouseInteractionController currentObjectUnderMouseCursor; /** * Called when given object was detected under mouse cursor, while processing {@link #mouseEvent}. * Because objects are rendered back to front. The last method caller will set the top-most object, if * there are multiple objects under mouse cursor. */ - public void setObjectUnderMouse(MouseInteractionController objectUnderMouse) { - this.objectUnderMouse = objectUnderMouse; + public void setCurrentObjectUnderMouseCursor(MouseInteractionController currentObjectUnderMouseCursor) { + this.currentObjectUnderMouseCursor = currentObjectUnderMouseCursor; } public RenderingContext(final int width, final int height) { @@ -85,28 +85,24 @@ public class RenderingContext { /** * @return true if view repaint is needed. */ - public boolean handleDetectedComponentMouseEvents() { - if (objectUnderMouse != null) { - if (mouseEvent.button == 0) { - // mouse over - if (currentMouseOverComponent == null) { - currentMouseOverComponent = objectUnderMouse; - return currentMouseOverComponent.mouseEntered(); - } else if (currentMouseOverComponent != objectUnderMouse) { - boolean viewRepaintNeeded = currentMouseOverComponent.mouseExited(); - currentMouseOverComponent = objectUnderMouse; - return viewRepaintNeeded | currentMouseOverComponent.mouseEntered(); - } - } else { - // mouse click - return objectUnderMouse.mouseClicked(); - } - } else if (currentMouseOverComponent != null) { - boolean viewRepaintNeeded = currentMouseOverComponent.mouseExited(); - currentMouseOverComponent = null; - return viewRepaintNeeded; + public boolean handlePossibleComponentMouseEvent() { + if (mouseEvent == null) return false; + + boolean viewRepaintNeeded = false; + + if (objectPreviouslyUnderMouseCursor != currentObjectUnderMouseCursor) { + // Mouse cursor has just entered or left component. + viewRepaintNeeded = objectPreviouslyUnderMouseCursor != null && objectPreviouslyUnderMouseCursor.mouseExited(); + viewRepaintNeeded |= currentObjectUnderMouseCursor != null && currentObjectUnderMouseCursor.mouseEntered(); + objectPreviouslyUnderMouseCursor = currentObjectUnderMouseCursor; } - return false; + + if (mouseEvent.button != 0 && currentObjectUnderMouseCursor != null) { + // Mouse button was clicked on some component. + viewRepaintNeeded |= currentObjectUnderMouseCursor.mouseClicked(mouseEvent.button); + } + + return viewRepaintNeeded; } }