我有一个自定义的 TimePicker 节点,它大部分工作正常,但我需要能够添加一个监听器来检查它何时获得或失去焦点。问题是它没有检测到我何时专注于它。
public class TimePicker extends HBox {
private NumberField nbxH; // NumberField is a custom class that extends Textbox. `focusedProperty().addListener` works as expected for this node.
private Label lblColon;
private NumberField nbxM;
private Button btnAmPm;
public TimePicker() {
// for testing
this.focusedProperty().addListener((observable, oldValue, newValue) -> {
printDebug("--TIME PICKER FOCUSED PROPERTY-------------------------"
+ "\n" + observable
+ "\n" + oldValue
+ "\n" + newValue
);
});
nbxH = new NumberField();
/* nbxH setup */
lblColon = new Label(":");
nbxM = new NumberField();
/* nbxM setup */
btnAmPm = new Button("AM");
/* btnAmPm setup */
}
/* other methods */
}
在类里面,我可以检查每个 child 是否专注。我想添加一个监听器来检查是否有任何 child 集中注意力或是否没有 child 集中注意力。换句话说,如果任何子级获得焦点,则 isFocused
为 true
,如果没有一个子级获得焦点,则 isFocused
为 false
;我可以设置一个监听器来检查是否发生变化。问题是,isFocused
被设置为最终的并且不能被覆盖。
我明白了。为每个子元素添加一个监听器,检查是否有任何元素获得焦点并将父元素的焦点设置为结果。当我意识到 setFocused
是一个选项时,这变得非常明显。
nbxM.focusedProperty().addListener((observable, oldValue, newValue) -> {
this.setFocused(nbxH.isFocused() | nbxM.isFocused() | btnAmPm.isFocused());
});
我是一名优秀的程序员,十分优秀!