com.sun.javafx.scene.SubSceneHelper Maven / Gradle / Ivy
The newest version!
/*
* Copyright (c) 2013, 2022, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
package com.sun.javafx.scene;
import com.sun.javafx.geom.BaseBounds;
import com.sun.javafx.geom.PickRay;
import com.sun.javafx.geom.transform.BaseTransform;
import com.sun.javafx.scene.input.PickResultChooser;
import com.sun.javafx.sg.prism.NGNode;
import com.sun.javafx.util.Utils;
import javafx.scene.Camera;
import javafx.scene.Node;
import javafx.scene.SubScene;
/**
* Used to access internal methods of SubScene.
*/
public class SubSceneHelper extends NodeHelper {
private static final SubSceneHelper theInstance;
private static SubSceneAccessor subSceneAccessor;
static {
theInstance = new SubSceneHelper();
Utils.forceInit(SubScene.class);
}
private static SubSceneHelper getInstance() {
return theInstance;
}
public static void initHelper(SubScene subScene) {
setHelper(subScene, getInstance());
}
public static void superProcessCSS(Node node) {
((SubSceneHelper) getHelper(node)).superProcessCSSImpl(node);
}
@Override
protected NGNode createPeerImpl(Node node) {
return subSceneAccessor.doCreatePeer(node);
}
@Override
protected void updatePeerImpl(Node node) {
super.updatePeerImpl(node);
subSceneAccessor.doUpdatePeer(node);
}
@Override
protected BaseBounds computeGeomBoundsImpl(Node node, BaseBounds bounds,
BaseTransform tx) {
return subSceneAccessor.doComputeGeomBounds(node, bounds, tx);
}
@Override
protected boolean computeContainsImpl(Node node, double localX, double localY) {
return subSceneAccessor.doComputeContains(node, localX, localY);
}
void superProcessCSSImpl(Node node) {
super.processCSSImpl(node);
}
@Override
protected void processCSSImpl(Node node) {
subSceneAccessor.doProcessCSS(node);
}
@Override
protected void pickNodeLocalImpl(Node node, PickRay localPickRay,
PickResultChooser result) {
subSceneAccessor.doPickNodeLocal(node, localPickRay, result);
}
public static boolean isDepthBuffer(SubScene subScene) {
return subSceneAccessor.isDepthBuffer(subScene);
}
public static Camera getEffectiveCamera(SubScene subScene) {
return subSceneAccessor.getEffectiveCamera(subScene);
}
public static void setSubSceneAccessor(final SubSceneAccessor newAccessor) {
if (subSceneAccessor != null) {
throw new IllegalStateException();
}
subSceneAccessor = newAccessor;
}
public interface SubSceneAccessor {
NGNode doCreatePeer(Node node);
void doUpdatePeer(Node node);
BaseBounds doComputeGeomBounds(Node node, BaseBounds bounds, BaseTransform tx);
boolean doComputeContains(Node node, double localX, double localY);
void doProcessCSS(Node node);
void doPickNodeLocal(Node node, PickRay localPickRay,
PickResultChooser result);
boolean isDepthBuffer(SubScene subScene);
Camera getEffectiveCamera(SubScene subScene);
}
}