De PropertySheet:
/**
* Sets a new editor factory used by the PropertySheet to determine which
* {@link PropertyEditor} to use for a given {@link Item}.
* @param factory
*/
public final void setPropertyEditorFactory(Callback<Item, PropertyEditor<?>> factory) {
propertyEditorFactory.set(factory == null? new DefaultPropertyEditorFactory(): factory);
}
Si vous créez un rappel à un PropertyEditor vous pouvez ajouter des écouteurs à l'éditeur.
Par exemple:
SimpleObjectProperty<Callback<PropertySheet.Item, PropertyEditor<?>>> propertyEditorFactory = new SimpleObjectProperty<>(this, "propertyEditor", new DefaultPropertyEditorFactory());
projectSheet.setPropertyEditorFactory(getItemPropertyEditorCallback(propertyEditorFactory));
private Callback<PropertySheet.Item, PropertyEditor<?>> getItemPropertyEditorCallback(SimpleObjectProperty<Callback<PropertySheet.Item, PropertyEditor<?>>> propertyEditorFactory) {
return param -> {
PropertyEditor<?> editor = propertyEditorFactory.get().call(param);
//Add listeners to editor
editor.getEditor().focusedProperty().addListener((observable, oldValue, newValue) -> System.out.println(newValue));
return editor;
};
}
Merci. J'ai testé le code d'exemple, mais ne fonctionne pas pour moi. Je ne comprends pas le PropertyItemBase, il ne peut pas être un PropertySheet.Item, non? Parce qu'il n'y a pas une méthode setEditor() dans ses méthodes. Alors c'est quoi? @bonfatti – user6839234
Je voulais supprimer la partie itemBase du code avant de coller mon commentaire, désolé à ce sujet. PropertyItemBase est une implémentation de PropertySheet.Item contenant une instance de l'éditeur, plus getter et setter. Je vais modifier ma réponse pour supprimer l'itemBase. – bonfatti
Merci beaucoup! – user6839234