gpt4 book ai didi

menu - 在 JavaFX 中制作垂直菜单栏

转载 作者:行者123 更新时间:2023-12-04 23:24:47 24 4
gpt4 key购买 nike

自从我与电脑打交道以来,我只见过水平方向的菜单栏。此类菜单栏的菜单项将向下弹出。在 JavaFX 中,很容易创建带有水平菜单栏的菜单。

是否可以在 JavaFX 中创建垂直菜单栏?此外,我希望菜单项向左或向右弹出,而不是向下弹出。

我可以实现这样一个我想要的菜单吗?有人请帮忙。

最佳答案

您可以为此利用 MenuButton:

@Override
public void start(Stage primaryStage) {
MenuButton m = new MenuButton("Eats");
m.setPrefWidth(100);
m.setPopupSide(Side.RIGHT);
m.getItems().addAll(new MenuItem("Burger"), new MenuItem("Hot Dog"));

MenuButton m2 = new MenuButton("Drinks");
m2.setPrefWidth(100);
m2.setPopupSide(Side.RIGHT);
m2.getItems().addAll(new MenuItem("Juice"), new MenuItem("Milk"));

VBox root = new VBox();
root.getChildren().addAll(m, m2);

Scene scene = new Scene(root, 300, 250);
scene.getStylesheets().add(getClass().getResource("style.css").toExternalForm());
primaryStage.setScene(scene);
primaryStage.show();
}

style.css 在哪里

.menu-button {
-fx-skin: "com.sun.javafx.scene.control.skin.MenuButtonSkin";
-fx-background-color: red, green, green, lightgreen;
-fx-background-insets: 0 0 -1 0, 0, 1, 2;
-fx-background-radius: 0;
-fx-padding: 0.0em; /* 0 */
-fx-text-fill: -fx-text-base-color;
}

/* TODO workaround for RT-19062 */
.menu-button .label { -fx-text-fill: -fx-text-base-color; }

.menu-button:focused {
-fx-color: beige;
-fx-background-color: -fx-focus-color, -fx-outer-border, -fx-inner-border, -fx-body-color;
-fx-background-insets: -1.4, 0, 1, 2;
-fx-background-radius: 0;
}

.menu-button:hover {
-fx-color: darkgreen;
}

.menu-button:armed {
-fx-color: greenyellow;
}

这些选择器部分取自并覆盖 caspian.css。根据您的需要更改颜色偏好,您也可以通过 css 删除按钮的箭头。

这种方法的缺点是难以制作嵌套的菜单项。

关于menu - 在 JavaFX 中制作垂直菜单栏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22658695/

24 4 0