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=31cbb13351e968ebb88718d24f160ed104721df8;hp=2603c1106913dce83fbbb8947b06e54e6a03f8eb;hb=0590faa0f0434ebb29955a711299f8ad5ac226d6;hpb=3ae8edf67328f8d74d92d737835e7ea17ecb934a 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 2603c11..31cbb13 100644 --- a/src/main/java/eu/svjatoslav/sixth/e3d/gui/RenderingContext.java +++ b/src/main/java/eu/svjatoslav/sixth/e3d/gui/RenderingContext.java @@ -31,14 +31,41 @@ public class RenderingContext { public int frameNumber = 0; /** - * Mouse click. During rendering we can detect which item user clicked on. + * UI component that mouse is currently hovering over. */ - public MouseEvent mouseEvent; + private MouseInteractionController currentMouseOverComponent; + + public void prepareForNewFrameRendering(){ + mouseEvent = null; + objectUnderMouse = null; + } + + /** + * Mouse click event that needs to be processed. + */ + private MouseEvent mouseEvent; + + public void setMouseEvent(MouseEvent mouseEvent) { + this.mouseEvent = mouseEvent; + } + + public MouseEvent getMouseEvent() { + return mouseEvent; + } /** * Item that user clicked on. */ - public MouseInteractionController objectUnderMouse; + private MouseInteractionController objectUnderMouse; + + /** + * 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 RenderingContext(final int width, final int height) { this.width = width; @@ -60,4 +87,31 @@ public class RenderingContext { graphics.setRenderingHint(RenderingHints.KEY_TEXT_ANTIALIASING, RenderingHints.VALUE_TEXT_ANTIALIAS_ON); } + /** + * @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; + } + return false; + } + }