所以我有这个.fxml:
<StackPane fx:controller="controller.MainController" xmlns:fx="http://javafx.com/fxml">
<Pane fx:id="aDrawPane" prefHeight="8000" prefWidth="10000" minWidth="10000" minHeight="8000">
</Pane>
<BorderPane fx:id="aBorderPane">
<top>
<VBox>
<ToolBar fx:id="aToolBar" orientation="HORIZONTAL">
<HBox fx:id="umlBox">
<Button text="Create" fx:id="createBtn"/>
<Button text="Package" fx:id="packageBtn"/>
<Button text="Edge" fx:id="edgeBtn"/>
<Button text="Draw" fx:id="drawBtn"/>
</HBox>
<HBox fx:id="utilBox">
<Button text="Select" fx:id="selectBtn"/>
<Button text="Move" fx:id="moveBtn"/>
</HBox>
<HBox fx:id="undoBox">
<Button text="Delete" fx:id="deleteBtn"/>
<Button text="Undo" fx:id="undoBtn"/>
<Button text="Redo" fx:id="redoBtn"/>
</HBox>
<HBox fx:id="recognizeBox">
<Button text="Recognize" fx:id="recognizeBtn"/>
</HBox>
</ToolBar>
</VBox>
</top>
<bottom>
<ToolBar>
<Pane HBox.hgrow="ALWAYS" />
<VBox alignment="CENTER">
<Slider fx:id="zoomSlider" min="10" max="200" value="100"/>
<Label text="Zoom"/>
</VBox>
<Pane HBox.hgrow="ALWAYS" />
</ToolBar>
</bottom>
</BorderPane>
<stylesheets>
<URL value="@main.css" />
</stylesheets>
</StackPane>
我的应用程序启动器类:
public class Launcher extends Application {
public void start(Stage stage) throws IOException {
BorderPane tabView = null;
FXMLLoader loader;
StackPane canvasView = null;
try {
loader = new FXMLLoader(getClass().getClassLoader().getResource("view.fxml"));
canvasView = (StackPane) loader.load();
} catch (IOException e) {
System.out.println(e.getMessage());
}
Scene scene = new Scene(canvasView, 1000, 800);
stage.setScene(scene);
stage.show();
}
}
使用此按钮,顶部工具栏中的按钮可见,并且与底部的滑块一样有效。
但是,如果我将代码更改为以下内容:
Group root = new Group();
root.getChildren().add(canvasView);
Scene scene = new Scene(root, 1000, 800);
顶部工具栏可见,但按钮不可见且不可点击,底部工具栏完全消失(第一个窗格“aDrawPane”按预期工作)。 当我想将view.fxml放在Tab中时,我遇到了这个问题。 为什么会发生这种情况?如何让工具栏和按钮再次可见?
答案 0 :(得分:0)
原因是一个集团没有调整其子女的大小,而是以他们喜欢的大小呈现它们。
FXML声明Pane应该是
<?php
/**
* Front to the WordPress application. This file doesn't do anything, but loads
* wp-blog-header.php which does and tells WordPress to load the theme.
*
* @package WordPress
*/
/**
* Tells WordPress to load the WordPress theme and output it.
*
* @var bool
*/
define('WP_USE_THEMES', true);
/** Loads the WordPress Environment and Template */
require( dirname( __FILE__ ) . '/wp-blog-header.php' );
这正是你得到的。