aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/graphui/classes/com/jogamp/graph/ui/Scene.java15
-rw-r--r--src/graphui/classes/com/jogamp/graph/ui/Shape.java14
2 files changed, 28 insertions, 1 deletions
diff --git a/src/graphui/classes/com/jogamp/graph/ui/Scene.java b/src/graphui/classes/com/jogamp/graph/ui/Scene.java
index 388b7c1e1..25733a21d 100644
--- a/src/graphui/classes/com/jogamp/graph/ui/Scene.java
+++ b/src/graphui/classes/com/jogamp/graph/ui/Scene.java
@@ -560,7 +560,7 @@ public final class Scene implements Container, GLEventListener {
final Ray ray = new Ray();
shape[0] = null;
- forSortedAll(Shape.ZAscendingComparator, pmv, (final Shape s, final PMVMatrix4f pmv2) -> {
+ forSortedAll(Shape.ZDescendingComparator, pmv, (final Shape s, final PMVMatrix4f pmv2) -> {
final boolean ok = s.isInteractive() && pmv.mapWinToRay(glWinX, glWinY, winZ0, winZ1, viewport, ray);
if( ok ) {
final AABBox sbox = s.getBounds();
@@ -916,11 +916,24 @@ public final class Scene implements Container, GLEventListener {
}
public void releaseActiveShape() {
+ if( null != activeShape && !FloatUtil.isZero(lastActiveZOffset) ) {
+ activeShape.move(0, 0, -lastActiveZOffset);
+ lastActiveZOffset = 0f;
+ }
activeShape = null;
}
private void setActiveShape(final Shape shape) {
+ if( activeShape != shape ) {
+ releaseActiveShape();
+ lastActiveZOffset = zOffsetScale * getZEpsilon(16);
+ if( null != shape && !FloatUtil.isZero(lastActiveZOffset) ) {
+ shape.move(0, 0, +lastActiveZOffset);
+ }
+ }
activeShape = shape;
}
+ private float lastActiveZOffset = 0f;
+ private static final float zOffsetScale = 10f;
private final class SBCGestureListener implements GestureHandler.GestureListener {
@Override
diff --git a/src/graphui/classes/com/jogamp/graph/ui/Shape.java b/src/graphui/classes/com/jogamp/graph/ui/Shape.java
index 70ceb9f95..db7d7d9c2 100644
--- a/src/graphui/classes/com/jogamp/graph/ui/Shape.java
+++ b/src/graphui/classes/com/jogamp/graph/ui/Shape.java
@@ -1559,6 +1559,20 @@ public abstract class Shape {
}
} };
+ public static Comparator<Shape> ZDescendingComparator = new Comparator<Shape>() {
+ @Override
+ public int compare(final Shape s1, final Shape s2) {
+ final float s1Z = s1.getScaledMinZ()+s1.getPosition().z();
+ final float s2Z = s2.getScaledMinZ()+s2.getPosition().z();
+ if( FloatUtil.isEqual2(s1Z, s2Z) ) {
+ return 0;
+ } else if( s1Z < s2Z ){
+ return 1;
+ } else {
+ return -1;
+ }
+ } };
+
//
//
//