我从FXML加载了一个父级,将其添加到场景/舞台中的窗格中并显示,然后立即查找组件。lookup()对某些返回null,但对其他返回non-null。在什么情况下它会这样做?
下面是加载和查找代码:
rootUi = FXMLLoader.load(getClass().getResource("PracticeScreen.fxml"));
// added to Parent within stage and setVisible(true)
analysisGroup = (Pane)rootUi.lookup("#analysisGroup"); // null
stickiesPane = (Pane)rootUi.lookup("#stickiesPane"); // null
scoreScroll = (ScrollPane)rootUi.lookup("#scoreScrollPane"); // GOOD
tintLayer = rootUi.lookup("#tintLayer"); // GOOD
scoreImageView = (ImageView)rootUi.lookup("#scoreImage"); // null
StackPane scoreRenderStack = (StackPane)rootUi.lookup("#scoreRenderStack"); // null
StackPane scoreScrollStack = (StackPane)rootUi.lookup("#scoreScrollStack"); // null
scoreScrollPane返回OK,但它的所有子级返回NULL。
已加载FXML:
<?import javafx.geometry.Insets?>
<?import javafx.scene.control.Label?>
<?import javafx.scene.control.ScrollPane?>
<?import javafx.scene.control.ToggleButton?>
<?import javafx.scene.effect.DropShadow?>
<?import javafx.scene.effect.Glow?>
<?import javafx.scene.image.ImageView?>
<?import javafx.scene.layout.*?>
<?import javafx.scene.shape.Rectangle?>
<?import javafx.scene.text.Font?>
<BorderPane style="-fx-background-color: white;" xmlns="http://javafx.com/javafx/8.0.65" xmlns:fx="http://javafx.com/fxml/1">
<center>
<StackPane id="scoreScreenStack" style="-fx-background-color: blue;" BorderPane.alignment="CENTER">
<children>
<ScrollPane id="scoreScrollPane" fitToHeight="true" hbarPolicy="ALWAYS" vbarPolicy="NEVER">
<content>
<StackPane id="scoreScrollStack">
<children>
<StackPane id="scoreRenderStack" alignment="CENTER_LEFT" StackPane.alignment="CENTER_LEFT">
<children>
<ImageView id="scoreImage" pickOnBounds="true" preserveRatio="true" StackPane.alignment="CENTER_LEFT" />
<Pane id="analysisGroup" />
<Pane id="stickiesPane" minHeight="200.0" minWidth="200.0" />
<Rectangle id="playbackCursor" arcHeight="5.0" arcWidth="5.0" fill="DODGERBLUE" height="150.0" stroke="BLACK" strokeType="INSIDE" strokeWidth="0.0" visible="false" width="2.0">
<effect>
<DropShadow color="DODGERBLUE" />
</effect>
</Rectangle>
</children>
</StackPane>
</children>
</StackPane>
</content>
</ScrollPane>
<BorderPane pickOnBounds="false">
<top>
<StackPane BorderPane.alignment="CENTER">
<children>
<BorderPane>
<left>
<Label id="recordingIndicator" text="Listening..." textFill="#00a7ff" BorderPane.alignment="CENTER">
<font>
<Font size="18.0" />
</font>
<effect>
<Glow level="0.86" />
</effect>
<BorderPane.margin>
<Insets />
</BorderPane.margin>
<padding>
<Insets bottom="8.0" left="8.0" right="8.0" top="8.0" />
</padding>
</Label>
</left>
<right>
<HBox BorderPane.alignment="CENTER">
<children>
<ToggleButton id="finalPerformance" mnemonicParsing="false" text="Final Performance" />
</children>
<BorderPane.margin>
<Insets bottom="8.0" left="8.0" right="8.0" top="8.0" />
</BorderPane.margin>
</HBox>
</right>
</BorderPane>
</children>
</StackPane>
</top>
</BorderPane>
<Pane id="tintLayer" opacity="0.0" pickOnBounds="false" style="-fx-background-color: #00a7ff;" visible="false" />
</children>
</StackPane>
</center>
</BorderPane>
在将CSS应用到场景之前,查找不能保证正常工作。这通常发生在第一次布局过程中(即场景图第一次呈现到屏幕上),在某些情况下甚至可能发生在之后。通常不推荐使用查找作为获取场景图中定义的节点的机制。
引用FXML中定义的控件的推荐方法是使用controller类。将FXML中的所有id
属性更改为fx:id
属性,并向根元素添加一个controller类属性:
<BorderPane style="-fx-background-color: white;" xmlns="http://javafx.com/javafx/8.0.65" xmlns:fx="http://javafx.com/fxml/1"
fx:controller="com.my.company.PracticeScreenController">
<center>
<StackPane fx:id="scoreScreenStack" style="-fx-background-color: blue;" BorderPane.alignment="CENTER">
<children>
<ScrollPane fx:id="scoreScrollPane" fitToHeight="true" hbarPolicy="ALWAYS" vbarPolicy="NEVER">
<content>
<StackPane fx:id="scoreScrollStack">
<!-- etc -->
</StackPane>
</content>
</ScrollPane>
</children>
</StackPane>
</center>
</BorderPane>
现在定义一个具有相应@fxml
注释字段的控制器类。您可以访问initialize()
方法中的这些字段(注意,在调用构造函数时,它们尚未初始化):
package com.my.company ;
// imports...
public class PracticeScreenController {
@FXML
private StackPane scoreScreenStack ;
@FXML
private ScrollPane scoreScrollPane ;
@FXML
private ScrollPane scoreScrollStack ;
// etc...
public void initialize() {
// configure controls here, as needed...
}
}
如果迫切需要从加载FXML文件的地方(而不是在控制器中)检索对FXML文件中定义的节点的引用,则可以通过fxmlloader
的命名空间这样做。再次强调,这不是推荐的方法,您确实应该使用一个controller类来访问这些,但这确实提供了另一种解决方案。
使用上面的FXML中显示的相同fx:id
属性,您可以执行以下操作:
FXMLLoader loader = new FXMLLoader(getClass().getResource("PracticeScreen.fxml"));
rootUi = loader.load();
Map<String, Object> namespace = loader.getNamespace();
// added to Parent within stage and setVisible(true)
analysisGroup = (Pane)namespace.get("analysisGroup");
stickiesPane = (Pane)namespace.get("stickiesPane");
scoreScroll = (ScrollPane)namespace.get("scoreScrollPane");
tintLayer = (Pane)namespace.get("tintLayer");
scoreImageView = (ImageView)namespace.get("scoreImage");
StackPane scoreRenderStack = (StackPane)namespace.get("scoreRenderStack");
StackPane scoreScrollStack = (StackPane)namespace.get("scoreScrollStack");
本文向大家介绍如何指定样式仅适用于HTML中此元素的父元素和该元素的子元素?,包括了如何指定样式仅适用于HTML中此元素的父元素和该元素的子元素?的使用技巧和注意事项,需要的朋友参考一下 使用scoped 属性指定样式仅适用于父元素和元素的子元素- 示例
问题内容: 我有一个现有的网站,上面有很多用表格布置的旧页面和表格,我正尝试逐步过渡到CSS。我想使用Twitter Bootstrap样式表-特别是表单样式- 但仅在我明确要求它们的页面部分中使用。例如,我可能将整个表单围绕在div中,如下所示: 我希望所有其他形式保持与现在相同,因为我将无法同时更改所有形式。有没有简单的方法可以做到这一点?我可以遍历Bootstrap CSS中的每种样式,并添
我正在使用TestCafe选择器来选择元素。这是一个复杂的Custin Child嵌套场景。 下面是HTML以了解我上面提到的内容: 在图片中,我提到了和,它们是父元素(具有相同的DOM),有一个grand grand child,而另一棵树中相同父元素的grand grand child是。我需要,但需要链接,因为所有父节点都有相同的DOM。
问题内容: 我正在使用ngAnimate模块,但是所有我的,等等都受此影响,我想对某些选定的元素利用ngAnimate。为了提高性能以及某些元素的显示和隐藏速度非常快的错误。 谢谢。 问题答案: 只需将其添加到您的CSS中即可。最好是最后一条规则: 然后将其添加到要禁用的元素类中。例:
我有一个来自服务器的响应,我想把它放到列表中。但是当列表为空时,我需要隐藏这个div容器。例如,如果不在数组中-我想隐藏div。但是我想在ng之后使用bird重复,所以我不能使在上。我可以检查li是否为空,然后隐藏div吗? 普朗克例子 AngularJS ng-重复处理空列表大小写-这是不一样的。如果li是空的,我不想隐藏li,我想在li是空的时候隐藏父元素h1。
请帮我检查数据库属性。 然后,sizeBinding有第一个元素null(用于宽度)和绑定表达式实例(用于高度绑定)。我可以使用Mode=twoway设置绑定,但是我想知道为什么如果Mode没有设置为twoway就不会创建绑定实例。我认为这是因为表达式需要比路径更复杂。但是,我尝试了,但是返回null作为绑定。我尝试了GetBinding*方法,但它们的行为与完全相同。 我谷歌搜索的唯一一个问题就