Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/387.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
JavaFX-屏蔽窗格可降低3D对象的可见性_Java_Javafx_3d_Masking_Meter - Fatal编程技术网

JavaFX-屏蔽窗格可降低3D对象的可见性

JavaFX-屏蔽窗格可降低3D对象的可见性,java,javafx,3d,masking,meter,Java,Javafx,3d,Masking,Meter,我正在尝试创建一个可视化组件,该组件显示带有测量线的光盘,以显示源中的当前值 一切正常,但当我遮罩容器(窗格)以减少可见区域时,图像显示变暗 面具前: 遮罩后: 遮罩不起作用,子场景起作用: 代码如下: Main.java package sample; import javafx.application.Application; import javafx.fxml.FXMLLoader; import javafx.scene.Parent; import javafx.scene

我正在尝试创建一个可视化组件,该组件显示带有测量线的光盘,以显示源中的当前值

一切正常,但当我遮罩容器(窗格)以减少可见区域时,图像显示变暗

面具前:

遮罩后:

遮罩不起作用,子场景起作用:

代码如下:

Main.java

package sample;

import javafx.application.Application;
import javafx.fxml.FXMLLoader;
import javafx.scene.Parent;
import javafx.scene.Scene;
import javafx.stage.Stage;

public class Main extends Application {

    @Override
    public void start(Stage primaryStage) throws Exception{
        FXMLLoader loader = new FXMLLoader(
            getClass().getResource("sample.fxml"));
        Parent root = loader.load();
        primaryStage.setTitle("Clock Test");
        primaryStage.setScene(new Scene(root, 800, 200));
        primaryStage.show();

        Controller controller = loader.getController();
        controller.initClock();
    }

    public static void main(String[] args) {
        launch(args);
    }
}
Controller.java[更新]

package sample;

import javafx.fxml.FXML;
import javafx.scene.Group;
import javafx.scene.PerspectiveCamera;
import javafx.scene.PointLight;
import javafx.scene.SubScene;
import javafx.scene.image.Image;
import javafx.scene.layout.Pane;
import javafx.scene.paint.Color;
import javafx.scene.paint.PhongMaterial;
import javafx.scene.shape.Cylinder;
import javafx.scene.shape.Rectangle;

public class Controller {

    @FXML private Pane clock;

    public void initClock() {

        PerspectiveCamera camera = new PerspectiveCamera();
        camera.setTranslateX(-150);
        camera.setTranslateY(-32.5);
        camera.setTranslateZ(-600);

        Group group = new Group();

        SubScene subScene = new SubScene(group, 300, 65);
        subScene.setCamera(camera);

        Rectangle rectangle = new Rectangle();
        rectangle.setArcWidth(1);
        rectangle.setArcHeight(1);
        rectangle.setX(0);
        rectangle.setY(0);
        rectangle.setWidth(300);
        rectangle.setHeight(65);

        Cylinder cylinder = new Cylinder(600, 65);
        PhongMaterial material = new PhongMaterial();

        Image diffuseMap
                = new Image(getClass()
                .getResource("/images/clock.png")
                .toExternalForm());

        material.setDiffuseColor(new Color(1, 1, 1, 1));
        material.setDiffuseMap(diffuseMap);
        cylinder.setMaterial(material);

        PointLight light = new PointLight();
        light.setColor(Color.WHITE);
        light.setTranslateX(0);
        light.setTranslateY(50);
        light.setTranslateZ(-800);

        group.getChildren().addAll(cylinder, light);

        clock.getChildren().add(subScene);
    }
}
sample.fxml

<?xml version="1.0" encoding="UTF-8"?>
<?import javafx.scene.layout.ColumnConstraints?>
<?import javafx.scene.layout.GridPane?>
<?import javafx.scene.layout.Pane?>
<?import javafx.scene.layout.RowConstraints?>
<GridPane alignment="center" hgap="10" vgap="10" xmlns:fx="http://javafx.com/fxml/1" xmlns="http://javafx.com/javafx/8.0.172-ea" fx:controller="sample.Controller">
  <children>
     <Pane fx:id="clock" prefHeight="65.0" prefWidth="200.0" GridPane.columnIndex="1" GridPane.rowIndex="1" />
  </children>
  <columnConstraints>
     <ColumnConstraints minWidth="10.0" prefWidth="100.0" />
     <ColumnConstraints minWidth="300.0" maxWidth="300.0" prefWidth="300.0" />
     <ColumnConstraints minWidth="10.0" prefWidth="100.0" />
  </columnConstraints>
  <rowConstraints>
     <RowConstraints minHeight="10.0" prefHeight="30.0" />
     <RowConstraints />
     <RowConstraints minHeight="10.0" prefHeight="30.0" />
  </rowConstraints>
</GridPane>

这个相关问题的答案可能会对您有所帮助。最后,它使用了一个亚场景。谢谢@mipa。这个相关问题的答案可能会对您有所帮助。最后,它使用了一个亚场景。谢谢@mipa。
git clone https://your_username@bitbucket.org/diegoluisr/meter3d.git