From e6dd7711c7dad5e000445208eb5845801f4ccffc Mon Sep 17 00:00:00 2001 From: Eduardo Pedroni Date: Sun, 6 Apr 2014 21:58:53 +0100 Subject: About to make big changes to the way fitness works, committing just in case --- src/jcgp/gui/dragresize/HorizontalDragResize.java | 90 +++++++++++++++++++++++ src/jcgp/gui/dragresize/VerticalDragResize.java | 90 +++++++++++++++++++++++ 2 files changed, 180 insertions(+) create mode 100644 src/jcgp/gui/dragresize/HorizontalDragResize.java create mode 100644 src/jcgp/gui/dragresize/VerticalDragResize.java (limited to 'src/jcgp/gui/dragresize') diff --git a/src/jcgp/gui/dragresize/HorizontalDragResize.java b/src/jcgp/gui/dragresize/HorizontalDragResize.java new file mode 100644 index 0000000..d580878 --- /dev/null +++ b/src/jcgp/gui/dragresize/HorizontalDragResize.java @@ -0,0 +1,90 @@ +package jcgp.gui.dragresize; + +import javafx.event.EventHandler; +import javafx.scene.Cursor; +import javafx.scene.input.MouseEvent; +import javafx.scene.layout.Region; +import jcgp.gui.GUI; + +/** + * + * http://andrewtill.blogspot.co.uk/2012/12/dragging-to-resize-javafx-region.html + * + * @author eddy + * + */ +public class HorizontalDragResize { + + private boolean dragging = false; + private final Region region; + + private HorizontalDragResize(Region region) { + this.region = region; + } + + public static void makeDragResizable(final Region region) { + final HorizontalDragResize dr = new HorizontalDragResize(region); + + region.setOnMousePressed(new EventHandler() { + @Override + public void handle(MouseEvent event) { + dr.mousePressed(event); + } + }); + region.setOnMouseDragged(new EventHandler() { + @Override + public void handle(MouseEvent event) { + dr.mouseDragged(event); + } + }); + region.setOnMouseMoved(new EventHandler() { + @Override + public void handle(MouseEvent event) { + dr.mouseMoved(event); + } + }); + region.setOnMouseReleased(new EventHandler() { + @Override + public void handle(MouseEvent event) { + dr.mouseReleased(); + } + }); + + } + + private void mousePressed(MouseEvent event) { + if(isInDraggableZone(event)) { + dragging = true; + } + } + + private void mouseDragged(MouseEvent event) { + if(dragging) { + double newWidth = region.getWidth() - event.getX(); + if (newWidth >= region.getMinWidth()) { + region.setPrefWidth(newWidth); + } else { + region.setPrefWidth(region.getMinWidth()); + } + } + } + + private void mouseMoved(MouseEvent event) { + if(isInDraggableZone(event) || dragging) { + region.setCursor(Cursor.H_RESIZE); + } + else { + region.setCursor(Cursor.DEFAULT); + } + } + + private void mouseReleased() { + dragging = false; + region.setCursor(Cursor.DEFAULT); + } + + private boolean isInDraggableZone(MouseEvent event) { + return event.getX() < (GUI.RESIZE_MARGIN); + } + +} diff --git a/src/jcgp/gui/dragresize/VerticalDragResize.java b/src/jcgp/gui/dragresize/VerticalDragResize.java new file mode 100644 index 0000000..32a7526 --- /dev/null +++ b/src/jcgp/gui/dragresize/VerticalDragResize.java @@ -0,0 +1,90 @@ +package jcgp.gui.dragresize; + +import javafx.event.EventHandler; +import javafx.scene.Cursor; +import javafx.scene.input.MouseEvent; +import javafx.scene.layout.Region; +import jcgp.gui.GUI; + +/** + * + * http://andrewtill.blogspot.co.uk/2012/12/dragging-to-resize-javafx-region.html + * + * @author eddy + * + */ +public class VerticalDragResize { + + private boolean dragging = false; + private final Region region; + + private VerticalDragResize(Region region) { + this.region = region; + } + + public static void makeDragResizable(final Region region) { + final VerticalDragResize dr = new VerticalDragResize(region); + + region.setOnMousePressed(new EventHandler() { + @Override + public void handle(MouseEvent event) { + dr.mousePressed(event); + } + }); + region.setOnMouseDragged(new EventHandler() { + @Override + public void handle(MouseEvent event) { + dr.mouseDragged(event); + } + }); + region.setOnMouseMoved(new EventHandler() { + @Override + public void handle(MouseEvent event) { + dr.mouseMoved(event); + } + }); + region.setOnMouseReleased(new EventHandler() { + @Override + public void handle(MouseEvent event) { + dr.mouseReleased(); + } + }); + + } + + private void mousePressed(MouseEvent event) { + if(isInDraggableZone(event)) { + dragging = true; + } + } + + private void mouseDragged(MouseEvent event) { + if(dragging) { + double newHeight = region.getHeight() - event.getY(); + if (newHeight >= region.getMinHeight()) { + region.setPrefHeight(newHeight); + } else { + region.setPrefHeight(region.getMinHeight()); + } + } + } + + private void mouseMoved(MouseEvent event) { + if(isInDraggableZone(event) || dragging) { + region.setCursor(Cursor.V_RESIZE); + } + else { + region.setCursor(Cursor.DEFAULT); + } + } + + private void mouseReleased() { + dragging = false; + region.setCursor(Cursor.DEFAULT); + } + + private boolean isInDraggableZone(MouseEvent event) { + return event.getY() < (GUI.RESIZE_MARGIN); + } + +} -- cgit v1.2.3