jfxtras.labs.internal.scene.control.skin.window.DefaultWindowSkin Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jfxtras-labs Show documentation
Show all versions of jfxtras-labs Show documentation
Experimental components for JavaFX 2
/**
* DefaultWindowSkin.java
*
* Copyright (c) 2011-2015, JFXtras
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* * Neither the name of the organization nor the
* names of its contributors may be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package jfxtras.labs.internal.scene.control.skin.window;
import javafx.animation.Animation;
import javafx.animation.Animation.Status;
import javafx.animation.KeyFrame;
import javafx.animation.KeyValue;
import javafx.animation.Timeline;
import javafx.beans.value.ChangeListener;
import javafx.beans.value.ObservableValue;
import javafx.collections.ListChangeListener;
import javafx.collections.ListChangeListener.Change;
import javafx.event.EventHandler;
import javafx.geometry.Bounds;
import javafx.scene.Cursor;
import javafx.scene.Node;
import javafx.scene.control.SkinBase;
import javafx.scene.effect.DropShadow;
import javafx.scene.effect.Glow;
import javafx.scene.input.MouseEvent;
import javafx.scene.layout.HBox;
import javafx.scene.layout.Pane;
import javafx.scene.paint.Color;
import javafx.scene.text.Text;
import javafx.util.Duration;
import jfxtras.labs.scene.control.window.SelectableNode;
import jfxtras.labs.scene.control.window.Window;
import jfxtras.labs.scene.control.window.WindowIcon;
import jfxtras.labs.util.WindowUtil;
/**
*
* @author Michael Hoffer <[email protected]>
*/
public class DefaultWindowSkin extends SkinBase {
private double mouseX;
private double mouseY;
private double nodeX = 0;
private double nodeY = 0;
private boolean dragging = false;
private boolean zoomable = true;
private double minScale = 0.1;
private double maxScale = 10;
private double scaleIncrement = 0.001;
private ResizeMode resizeMode;
private boolean RESIZE_TOP;
private boolean RESIZE_LEFT;
private boolean RESIZE_BOTTOM;
private boolean RESIZE_RIGHT;
private TitleBar titleBar;
private Window control;
private Pane root = new Pane();
private double contentScale = 1.0;
private double oldHeight;
private Timeline minimizeTimeLine;
public DefaultWindowSkin(Window w) {
super(w);
this.control = w;
titleBar = new TitleBar(control);
titleBar.setTitle("");
init();
}
private void init() {
getChildren().add(root);
root.getChildren().add(titleBar);
for (WindowIcon i : control.getLeftIcons()) {
titleBar.addLeftIcon(i);
}
for (WindowIcon i : control.getRightIcons()) {
titleBar.addRightIcon(i);
}
control.getLeftIcons().addListener(
(ListChangeListener.Change extends WindowIcon> change) -> {
while (change.next()) {
if (change.wasPermutated()) {
for (int i = change.getFrom(); i < change.getTo(); ++i) {
//permutate
}
} else if (change.wasUpdated()) {
//update item
} else {
if (change.wasRemoved()) {
for (WindowIcon i : change.getRemoved()) {
titleBar.removeLeftIcon(i);
}
} else if (change.wasAdded()) {
for (WindowIcon i : change.getAddedSubList()) {
titleBar.addLeftIcon(i);
}
}
}
}
});
control.getRightIcons().addListener(
(ListChangeListener.Change extends WindowIcon> change) -> {
while (change.next()) {
if (change.wasPermutated()) {
for (int i = change.getFrom(); i < change.getTo(); ++i) {
//permutate
}
} else if (change.wasUpdated()) {
//update item
} else {
if (change.wasRemoved()) {
for (WindowIcon i : change.getRemoved()) {
titleBar.removeRightIcon(i);
}
} else if (change.wasAdded()) {
for (WindowIcon i : change.getAddedSubList()) {
titleBar.addRightIcon(i);
}
}
}
}
});
control.minimizedProperty().addListener(
(ObservableValue extends Boolean> ov, final Boolean oldValue, final Boolean newValue) -> {
if (oldValue == newValue) {
return;
}
boolean storeOldHeight = minimizeTimeLine == null && newValue;
if (minimizeTimeLine != null) {
minimizeTimeLine.stop();
minimizeTimeLine = null;
}
double newHeight;
if (newValue) {
newHeight = titleBar.getHeight();
} else {
newHeight = oldHeight;
}
if (storeOldHeight) {
oldHeight = control.getPrefHeight();
}
minimizeTimeLine = new Timeline(
new KeyFrame(Duration.ZERO,
new KeyValue(control.prefHeightProperty(), control.getPrefHeight())),
new KeyFrame(Duration.seconds(0.2),
new KeyValue(control.prefHeightProperty(), newHeight)));
minimizeTimeLine.statusProperty().addListener(
new ChangeListener() {
@Override
public void changed(ObservableValue extends Status> ov, Status oldStatus, Status newStatus) {
if (newStatus == Status.STOPPED) {
minimizeTimeLine = null;
if (newValue) {
control.getContentPane().setVisible(false);
}
}
}
});
minimizeTimeLine.play();
});
control.prefHeightProperty().addListener(new MinimizeHeightListener(control, titleBar));
initMouseEventHandlers();
titleBar.setTitle(control.getTitle());
control.titleProperty().addListener((ObservableValue extends String> ov, String oldValue, String newValue) -> {
titleBar.setTitle(newValue);
control.autosize();
});
root.getChildren().add(control.getContentPane());
control.getContentPane().setManaged(false);
control.contentPaneProperty().addListener((ObservableValue extends Pane> ov, Pane oldValue, Pane newValue) -> {
root.getChildren().remove(oldValue);
root.getChildren().add(newValue);
newValue.setManaged(false);
});
titleBar.setStyle(control.getStyle());
control.styleProperty().addListener((ObservableValue extends String> ov, String t, String t1) -> {
titleBar.setStyle(t1);
});
titleBar.getStyleClass().setAll(control.getTitleBarStyleClass());
titleBar.getLabel().getStyleClass().setAll(control.getTitleBarStyleClass());
control.titleBarStyleClassProperty().addListener((ObservableValue extends String> ov, String t, String t1) -> {
titleBar.getStyleClass().setAll(t1);
titleBar.getLabel().getStyleClass().setAll(t1);
});
titleBar.getStylesheets().setAll(control.getStylesheets());
control.getStylesheets().addListener((Change extends String> change) -> {
while (change.next()) {
if (change.wasPermutated()) {
for (int i = change.getFrom(); i < change.getTo(); ++i) {
//permutate
}
} else if (change.wasUpdated()) {
//update item
} else {
if (change.wasRemoved()) {
for (String i : change.getRemoved()) {
titleBar.getStylesheets().remove(i);
}
} else if (change.wasAdded()) {
for (String i : change.getAddedSubList()) {
titleBar.getStylesheets().add(i);
}
}
}
}
});
control.selectedProperty().addListener(
(ObservableValue extends Boolean> ov, Boolean oldValue, Boolean newValue) -> {
if (newValue) {
DropShadow shadow = new DropShadow(20, Color.WHITE);
Glow effect = new Glow(0.5);
// shadow.setInput(effect);
control.setEffect(effect);
} else {
control.setEffect(null);
}
});
}
private void initMouseEventHandlers() {
getSkinnable().onMousePressedProperty().set((EventHandler) (MouseEvent event) -> {
final Node n = control;
final double parentScaleX = n.getParent().
localToSceneTransformProperty().getValue().getMxx();
final double parentScaleY = n.getParent().
localToSceneTransformProperty().getValue().getMyy();
mouseX = event.getSceneX();
mouseY = event.getSceneY();
nodeX = n.getLayoutX() * parentScaleX;
nodeY = n.getLayoutY() * parentScaleY;
if (control.isMoveToFront()) {
control.toFront();
}
if (control.isSelected()) {
selectedWindowsToFront();
}
});
//Event Listener for MouseDragged
getSkinnable().onMouseDraggedProperty().set((EventHandler) (MouseEvent event) -> {
final Node n = control;
final double parentScaleX = n.getParent().
localToSceneTransformProperty().getValue().getMxx();
final double parentScaleY = n.getParent().
localToSceneTransformProperty().getValue().getMyy();
final double scaleX = n.localToSceneTransformProperty().
getValue().getMxx();
final double scaleY = n.localToSceneTransformProperty().
getValue().getMyy();
Bounds boundsInScene =
control.localToScene(control.getBoundsInLocal());
double sceneX = boundsInScene.getMinX();
double sceneY = boundsInScene.getMinY();
double offsetX = event.getSceneX() - mouseX;
double offsetY = event.getSceneY() - mouseY;
if (resizeMode == ResizeMode.NONE && control.isMovable()) {
nodeX += offsetX;
nodeY += offsetY;
double scaledX = nodeX * 1 / parentScaleX;
double scaledY = nodeY * 1 / parentScaleY;
double offsetForAllX = scaledX - n.getLayoutX();
double offsetForAllY = scaledY - n.getLayoutY();
n.setLayoutX(scaledX);
n.setLayoutY(scaledY);
dragging = true;
// move all selected windows
if (control.isSelected()) {
dragSelectedWindows(offsetForAllX, offsetForAllY);
}
} else {
double width = n.getBoundsInLocal().getMaxX()
- n.getBoundsInLocal().getMinX();
double height = n.getBoundsInLocal().getMaxY()
- n.getBoundsInLocal().getMinY();
if (RESIZE_TOP) {
// System.out.println("TOP");
double insetOffset = getSkinnable().getInsets().getTop() / 2;
double yDiff =
sceneY / parentScaleY
+ insetOffset
- event.getSceneY() / parentScaleY;
double newHeight = control.getPrefHeight() + yDiff;
if (newHeight > control.minHeight(0)) {
control.setLayoutY(control.getLayoutY() - yDiff);
control.setPrefHeight(newHeight);
}
}
if (RESIZE_LEFT) {
// System.out.println("LEFT");
double insetOffset = getSkinnable().getInsets().getLeft() / 2;
double xDiff = sceneX / parentScaleX
+ insetOffset
- event.getSceneX() / parentScaleX;
double newWidth = control.getPrefWidth() + xDiff;
if (newWidth > Math.max(control.minWidth(0),
control.getContentPane().minWidth(0))) {
control.setLayoutX(control.getLayoutX() - xDiff);
control.setPrefWidth(newWidth);
} else {
//
}
}
if (RESIZE_BOTTOM) {
// System.out.println("BOTTOM");
double insetOffset = getSkinnable().getInsets().getBottom() / 2;
double yDiff = event.getSceneY() / parentScaleY
- sceneY / parentScaleY - insetOffset;
double newHeight = yDiff;
newHeight = Math.max(
newHeight, control.minHeight(0));
if (newHeight < control.maxHeight(0)) {
control.setPrefHeight(newHeight);
}
}
if (RESIZE_RIGHT) {
double insetOffset = getSkinnable().getInsets().getRight() / 2;
double xDiff = event.getSceneX() / parentScaleX
- sceneX / parentScaleY - insetOffset;
double newWidth = xDiff;
newWidth = Math.max(
newWidth,
Math.max(control.getContentPane().minWidth(0),
control.minWidth(0)));
if (newWidth < control.maxWidth(0)) {
control.setPrefWidth(newWidth);
}
}
}
mouseX = event.getSceneX();
mouseY = event.getSceneY();
});
getSkinnable().onMouseClickedProperty().set((EventHandler) (MouseEvent event) -> {
dragging = false;
});
getSkinnable().onMouseMovedProperty().set((EventHandler) (MouseEvent t) -> {
if (control.isMinimized() || !control.isResizableWindow()) {
RESIZE_TOP = false;
RESIZE_LEFT = false;
RESIZE_BOTTOM = false;
RESIZE_RIGHT = false;
resizeMode = ResizeMode.NONE;
return;
}
final Node n = control;
final double parentScaleX = n.getParent().localToSceneTransformProperty().getValue().getMxx();
final double parentScaleY = n.getParent().localToSceneTransformProperty().getValue().getMyy();
final double scaleX = n.localToSceneTransformProperty().getValue().getMxx();
final double scaleY = n.localToSceneTransformProperty().getValue().getMyy();
final double border = control.getResizableBorderWidth() * scaleX;
double diffMinX = Math.abs(n.getLayoutBounds().getMinX() - t.getX() + getSkinnable().getInsets().getLeft());
double diffMinY = Math.abs(n.getLayoutBounds().getMinY() - t.getY() + getSkinnable().getInsets().getTop());
double diffMaxX = Math.abs(n.getLayoutBounds().getMaxX() - t.getX() - getSkinnable().getInsets().getRight());
double diffMaxY = Math.abs(n.getLayoutBounds().getMaxY() - t.getY() - getSkinnable().getInsets().getBottom());
boolean left = diffMinX * scaleX < Math.max(border, getSkinnable().getInsets().getLeft() / 2 * scaleX);
boolean top = diffMinY * scaleY < Math.max(border, getSkinnable().getInsets().getTop() / 2 * scaleY);
boolean right = diffMaxX * scaleX < Math.max(border, getSkinnable().getInsets().getRight() / 2 * scaleX);
boolean bottom = diffMaxY * scaleY < Math.max(border, getSkinnable().getInsets().getBottom() / 2 * scaleY);
RESIZE_TOP = false;
RESIZE_LEFT = false;
RESIZE_BOTTOM = false;
RESIZE_RIGHT = false;
if (left && !top && !bottom) {
n.setCursor(Cursor.W_RESIZE);
resizeMode = ResizeMode.LEFT;
RESIZE_LEFT = true;
} else if (left && top && !bottom) {
n.setCursor(Cursor.NW_RESIZE);
resizeMode = ResizeMode.TOP_LEFT;
RESIZE_LEFT = true;
RESIZE_TOP = true;
} else if (left && !top && bottom) {
n.setCursor(Cursor.SW_RESIZE);
resizeMode = ResizeMode.BOTTOM_LEFT;
RESIZE_LEFT = true;
RESIZE_BOTTOM = true;
} else if (right && !top && !bottom) {
n.setCursor(Cursor.E_RESIZE);
resizeMode = ResizeMode.RIGHT;
RESIZE_RIGHT = true;
} else if (right && top && !bottom) {
n.setCursor(Cursor.NE_RESIZE);
resizeMode = ResizeMode.TOP_RIGHT;
RESIZE_RIGHT = true;
RESIZE_TOP = true;
} else if (right && !top && bottom) {
n.setCursor(Cursor.SE_RESIZE);
resizeMode = ResizeMode.BOTTOM_RIGHT;
RESIZE_RIGHT = true;
RESIZE_BOTTOM = true;
} else if (top && !left && !right) {
n.setCursor(Cursor.N_RESIZE);
resizeMode = ResizeMode.TOP;
RESIZE_TOP = true;
} else if (bottom && !left && !right) {
n.setCursor(Cursor.S_RESIZE);
resizeMode = ResizeMode.BOTTOM;
RESIZE_BOTTOM = true;
} else {
n.setCursor(Cursor.DEFAULT);
resizeMode = ResizeMode.NONE;
}
control.autosize();
});
// setOnScroll(new EventHandler() {
// @Override
// public void handle(ScrollEvent event) {
//
// if (!isZoomable()) {
// return;
// }
//
// double scaleValue =
// control.getScaleY() + event.getDeltaY() * getScaleIncrement();
//
// scaleValue = Math.max(scaleValue, getMinScale());
// scaleValue = Math.min(scaleValue, getMaxScale());
//
// control.setScaleX(scaleValue);
// control.setScaleY(scaleValue);
//
// event.consume();
// }
// });
}
// TODO move from skin to behavior class (a lot of other stuff here too)
private void selectedWindowsToFront() {
for (SelectableNode sN : WindowUtil.
getDefaultClipboard().getSelectedItems()) {
if (sN == control
|| !(sN instanceof Window)) {
continue;
}
Window selectedWindow = (Window) sN;
if (control.getParent().
equals(selectedWindow.getParent())
&& selectedWindow.isMoveToFront()) {
selectedWindow.toFront();
}
} // end for sN
}
// TODO move from skin to behavior class (a lot of other stuff here too)
private void dragSelectedWindows(double offsetForAllX, double offsetForAllY) {
for (SelectableNode sN : WindowUtil.
getDefaultClipboard().getSelectedItems()) {
if (sN == control
|| !(sN instanceof Window)) {
continue;
}
Window selectedWindow = (Window) sN;
if (control.getParent().
equals(selectedWindow.getParent())) {
selectedWindow.setLayoutX(
selectedWindow.getLayoutX()
+ offsetForAllX);
selectedWindow.setLayoutY(
selectedWindow.getLayoutY()
+ offsetForAllY);
}
} // end for sN
}
/**
* @return the zoomable
*/
public boolean isZoomable() {
return zoomable;
}
/**
* @param zoomable the zoomable to set
*/
public void setZoomable(boolean zoomable) {
this.zoomable = zoomable;
}
/**
* @return the dragging
*/
protected boolean isDragging() {
return dragging;
}
public void removeNode(Node n) {
getChildren().remove(n);
}
/**
* @return the minScale
*/
public double getMinScale() {
return minScale;
}
/**
* @param minScale the minScale to set
*/
public void setMinScale(double minScale) {
this.minScale = minScale;
}
/**
* @return the maxScale
*/
public double getMaxScale() {
return maxScale;
}
/**
* @param maxScale the maxScale to set
*/
public void setMaxScale(double maxScale) {
this.maxScale = maxScale;
}
/**
* @return the scaleIncrement
*/
public double getScaleIncrement() {
return scaleIncrement;
}
/**
* @param scaleIncrement the scaleIncrement to set
*/
public void setScaleIncrement(double scaleIncrement) {
this.scaleIncrement = scaleIncrement;
}
@Override
protected void layoutChildren(double x, double y, double w, double h) {
super.layoutChildren(x, y, w, h);
root.relocate(0, 0);
root.resize(root.getWidth()
+ getSkinnable().getInsets().getLeft() + getSkinnable().getInsets().getRight(),
root.getHeight()
+ getSkinnable().getInsets().getTop() + getSkinnable().getInsets().getBottom());
titleBar.relocate(0, 0);
double titleBarWidth = titleBar.prefWidth(0);
double windowWidth = root.getWidth();
// if (titleBarWidth > windowWidth) {
// titleBar.setPrefWidth(titleBarWidth);
// }
double newTitleBarWidth =
Math.max(
titleBarWidth,
windowWidth);
titleBar.resize(newTitleBarWidth, titleBar.prefHeight(0));
double leftAndRight = getSkinnable().getInsets().getLeft() + getSkinnable().getInsets().getRight();
double topAndBottom = getSkinnable().getInsets().getTop() + getSkinnable().getInsets().getBottom();
control.getContentPane().relocate(
getSkinnable().getInsets().getLeft(),
titleBar.prefHeight(0));
double contentWidth = root.getWidth() - leftAndRight;
double contentHeight = root.getHeight() - getSkinnable().getInsets().getBottom() - titleBar.prefHeight(0);
control.getContentPane().resize(
contentWidth,
contentHeight);
titleBar.layoutChildren();
}
@Override
protected double computeMinWidth(double width, double topInset, double rightInset, double bottomInset, double leftInset) {
double result = root.minWidth(width);
double minWidth = Math.max(titleBar.prefWidth(width),
control.getContentPane().minWidth(width)+ getSkinnable().getInsets().getRight());
result = Math.max(result,minWidth);
return result;
}
@Override
protected double computePrefWidth(double width, double topInset, double rightInset, double bottomInset, double leftInset) {
return computeMinWidth(width, topInset, rightInset, bottomInset, leftInset);
}
@Override
protected double computeMinHeight(double height, double topInset, double rightInset, double bottomInset, double leftInset) {
double result = root.minHeight(height);
double minHeight = titleBar.prefHeight(height);
if (!control.isMinimized() && control.getContentPane().isVisible()) {
minHeight += control.getContentPane().minHeight(height)
+ getSkinnable().getInsets().getBottom();
}
result = Math.max(result, minHeight);
return result;
}
static class MinimizeHeightListener implements ChangeListener {
private final Window control;
private final TitleBar titleBar;
public MinimizeHeightListener(Window control, TitleBar titleBar) {
this.control = control;
this.titleBar = titleBar;
}
@Override
public void changed(ObservableValue extends Number> ov, Number t, Number t1) {
if (control.isMinimized()
&& control.getPrefHeight()
< titleBar.minHeight(0) + control.getContentPane().minHeight(0)) {
control.getContentPane().setVisible(false);
// System.out.println("v: false");
} else if (!control.isMinimized()
&& control.getPrefHeight()
>= titleBar.minHeight(0) + control.getContentPane().minHeight(0)) {
control.getContentPane().setVisible(true);
// System.out.println("v: true");
}
}
}
}
class TitleBar extends HBox {
public static final String DEFAULT_STYLE_CLASS = "window-titlebar";
private final Pane leftIconPane;
private final Pane rightIconPane;
private final Text label = new Text();
private final double iconSpacing = 3;
Window control;
// estimated size of "...",
// is there a way to find out text dimension without rendering it
private final double offset = 40;
private double originalTitleWidth;
public TitleBar(Window w) {
this.control = w;
setManaged(false);
getStylesheets().setAll(w.getStylesheets());
getStyleClass().setAll(DEFAULT_STYLE_CLASS);
setSpacing(8);
// label.setTextAlignment(TextAlignment.CENTER);
// label.getStyleClass().setAll(DEFAULT_STYLE_CLASS);
leftIconPane = new IconPane();
rightIconPane = new IconPane();
getChildren().add(leftIconPane);
// getChildren().add(VFXLayoutUtil.createHBoxFiller());
getChildren().add(label);
// getChildren().add(VFXLayoutUtil.createHBoxFiller());
getChildren().add(rightIconPane);
control.boundsInParentProperty().addListener(
(ObservableValue extends Bounds> ov, Bounds t, Bounds t1) -> {
if (control.getTitle() == null
|| getLabel().getText() == null
|| getLabel().getText().isEmpty()) {
return;
}
double maxIconWidth = Math.max(
leftIconPane.getWidth(), rightIconPane.getWidth());
if (!control.getTitle().equals(getLabel().getText())) {
if (originalTitleWidth
+ maxIconWidth * 2 + offset < getWidth()) {
getLabel().setText(control.getTitle());
}
} else if (!"...".equals(getLabel().getText())) {
if (originalTitleWidth
+ maxIconWidth * 2 + offset >= getWidth()) {
getLabel().setText("...");
}
}
});
}
public void setTitle(String title) {
getLabel().setText(title);
originalTitleWidth = getLabel().getBoundsInParent().getWidth();
double maxIconWidth = Math.max(
leftIconPane.getWidth(), rightIconPane.getWidth());
if (originalTitleWidth
+ maxIconWidth * 2 + offset >= getWidth()) {
getLabel().setText("...");
}
}
public String getTitle() {
return getLabel().getText();
}
public void addLeftIcon(Node n) {
leftIconPane.getChildren().add(n);
}
public void addRightIcon(Node n) {
rightIconPane.getChildren().add(n);
}
public void removeLeftIcon(Node n) {
leftIconPane.getChildren().remove(n);
}
public void removeRightIcon(Node n) {
rightIconPane.getChildren().remove(n);
}
@Override
protected double computeMinWidth(double h) {
double result = super.computeMinWidth(h);
double iconWidth =
Math.max(
leftIconPane.prefWidth(h),
rightIconPane.prefWidth(h)) * 2;
result = Math.max(result,
iconWidth
// + getLabel().prefWidth(h)
+ getInsets().getLeft()
+ getInsets().getRight());
return result + iconSpacing * 2 + offset;
}
@Override
protected double computePrefWidth(double h) {
return computeMinWidth(h);
}
@Override
protected void layoutChildren() {
super.layoutChildren();
leftIconPane.resizeRelocate(getInsets().getLeft(), getInsets().getTop(),
leftIconPane.prefWidth(USE_PREF_SIZE),
getHeight() - getInsets().getTop() - getInsets().getBottom());
rightIconPane.resize(rightIconPane.prefWidth(USE_PREF_SIZE),
getHeight() - getInsets().getTop() - getInsets().getBottom());
rightIconPane.relocate(getWidth() - rightIconPane.getWidth() - getInsets().getRight(),
getInsets().getTop());
}
/**
* @return the label
*/
public final Text getLabel() {
return label;
}
private static class IconPane extends Pane {
private final double spacing = 2;
public IconPane() {
setManaged(false);
//
setPrefWidth(USE_COMPUTED_SIZE);
setMinWidth(USE_COMPUTED_SIZE);
}
@Override
protected void layoutChildren() {
int count = 0;
double width = getHeight();
double height = getHeight();
for (Node n : getManagedChildren()) {
double x = (width + spacing) * count;
n.resizeRelocate(x, 0, width, height);
count++;
}
}
@Override
protected double computeMinWidth(double h) {
return getHeight() * getChildren().size()
+ spacing * (getChildren().size() - 1);
}
@Override
protected double computeMaxWidth(double h) {
return computeMinWidth(h);
}
@Override
protected double computePrefWidth(double h) {
return computeMinWidth(h);
}
}
}
// TODO do we still need this enum?
enum ResizeMode {
NONE,
TOP,
LEFT,
BOTTOM,
RIGHT,
TOP_LEFT,
TOP_RIGHT,
BOTTOM_LEFT,
BOTTOM_RIGHT
}