Как реализовать прозрачную панель с непрозрачными дочерними элементами?
Как я могу реализовать прозрачную панель с непрозрачными дочерними элементами в JavaFX 2? Эффект, которого я хочу достичь, применяется, например, к меню в Blender:
Панель меню / окно прозрачны, но текстовые элементы не прозрачны, что приводит к хорошему эффекту.
1 ответ
Решение
Установите цвет фона панели с альфа-компонентом. Для этого вы можете использовать таблицу стилей или встроенный стиль.
Например, если ваша панель была названа стеклом, то следующее даст ей округленный, полупрозрачный голубой фон:
glass.setStyle("-fx-background-color: rgba(0, 100, 100, 0.5); -fx-background-radius: 10;");
Вы также можете достичь аналогичных эффектов, используя смеси, стековые панели или группы элементов с непрозрачностью, установленной для элементов на задней панели стека или группы.
Вот исполняемый пример, использующий фоновый метод css.
import javafx.application.Application;
import javafx.geometry.Pos;
import javafx.scene.Scene;
import javafx.scene.control.*;
import javafx.scene.image.*;
import javafx.scene.layout.*;
import javafx.stage.Stage;
public class TranslucentPane extends Application {
@Override public void start(final Stage stage) throws Exception {
final ImageView imageView = new ImageView(
new Image("https://upload.wikimedia.org/wikipedia/commons/b/b7/Idylls_of_the_King_3.jpg")
);
imageView.setFitHeight(300);
imageView.setFitWidth(228);
final Label label = new Label("The Once\nand\nFuture King");
label.setStyle("-fx-text-fill: goldenrod; -fx-font: italic 20 \"serif\"; -fx-padding: 0 0 20 0; -fx-text-alignment: center");
StackPane glass = new StackPane();
StackPane.setAlignment(label, Pos.BOTTOM_CENTER);
glass.getChildren().addAll(label);
glass.setStyle("-fx-background-color: rgba(0, 100, 100, 0.5); -fx-background-radius: 10;");
glass.setMaxWidth(imageView.getFitWidth() - 40);
glass.setMaxHeight(imageView.getFitHeight() - 40);
final StackPane layout = new StackPane();
layout.getChildren().addAll(imageView, glass);
layout.setStyle("-fx-background-color: silver; -fx-padding: 10;");
stage.setScene(new Scene(layout));
stage.show();
}
public static void main(String[] args) { launch(args); }
}
Пример программы вывода: