JavaFX Как установить фоновое изображение сцены - PullRequest
36 голосов
/ 16 марта 2012

Как установить фоновое изображение сцены?

Ответы [ 4 ]

35 голосов
/ 16 марта 2012

Один из подходов может быть таким:

1) Создайте файл CSS с именем «style.css» и определите в нем селектор идентификатора:

#pane{
    -fx-background-image: url("background_image.jpg");
    -fx-background-repeat: stretch;   
    -fx-background-size: 900 506;
    -fx-background-position: center center;
    -fx-effect: dropshadow(three-pass-box, black, 30, 0.5, 0, 0); 
}

2) Установите идентификатор самого верхнего элемента управления (или любого элемента управления) в сцене со значением, определенным в CSS, и загрузите этот файл CSS в сцену:

  public class Test extends Application {

    public static void main(String[] args) {
        launch(args);
    }

    @Override
    public void start(Stage primaryStage) {
        StackPane root = new StackPane();
        root.setId("pane");
        Scene scene = new Scene(root, 300, 250);
        scene.getStylesheets().addAll(this.getClass().getResource("style.css").toExternalForm());
        primaryStage.setScene(scene);
        primaryStage.show();
    }
}

Вы также можете присвоить id элементу управления в файле FXML:

<StackPane id="pane" prefHeight="200" prefWidth="320" xmlns:fx="http://javafx.com/fxml" fx:controller="demo.Sample">
    <children>
    </children>
</StackPane>

Для получения дополнительной информации о JavaFX CSS Styling, обратитесь к этому руководству .

30 голосов
/ 14 марта 2015

Я знаю, что это старый вопрос

Но если вы хотите сделать это программным путем или способом Java

для фоновых изображений; Вы можете использовать BackgroundImage class

BackgroundImage myBI= new BackgroundImage(new Image("my url",32,32,false,true),
        BackgroundRepeat.REPEAT, BackgroundRepeat.NO_REPEAT, BackgroundPosition.DEFAULT,
          BackgroundSize.DEFAULT);
//then you set to your node
myContainer.setBackground(new Background(myBI));

Для рисования или заливки фона; Вы можете использовать BackgroundFill class

BackgroundFill myBF = new BackgroundFill(Color.BLUEVIOLET, new CornerRadii(1),
         new Insets(0.0,0.0,0.0,0.0));// or null for the padding
//then you set to your node or container or layout
myContainer.setBackground(new Background(myBF));

Поддерживает вашу Java в живых && Ваш CSS мертвым ..

11 голосов
/ 16 марта 2012

Вы можете изменить стиль непосредственно для сцены, используя .root class:

.root {
    -fx-background-image: url("https://www.google.com/images/srpr/logo3w.png");
}

Добавьте это в CSS и загрузите как «Uluk Biy», описанный в его ответе.

0 голосов
/ 23 мая 2019

В дополнение к ответу @Elltz мы можем использовать и заливку, и изображение для фона:

someNode.setBackground(
            new Background(
                    Collections.singletonList(new BackgroundFill(
                            Color.WHITE, 
                            new CornerRadii(500), 
                            new Insets(10))),
                    Collections.singletonList(new BackgroundImage(
                            new Image("image/logo.png", 100, 100, false, true),
                            BackgroundRepeat.NO_REPEAT,
                            BackgroundRepeat.NO_REPEAT,
                            BackgroundPosition.CENTER,
                            BackgroundSize.DEFAULT))));
...