JavaFX TextField : Automatically transform text to uppercase

13.1k views Asked by At

I have a JavaFX TextField control on my FXMl that looks like this...

<TextField fx:id="input_search" onKeyPressed="#keyListener" prefHeight="25.0" prefWidth="197.0" />

I want to automatically change all characters to uppercase when the user is typing.

The code in my controller :

public void keyListener(KeyEvent event){
    //maybe transform the pressed key to uppercase here...
}
2

There are 2 answers

3
ItachiUchiha On BEST ANSWER

There are a few ways to achieve this:

Override replaceText()

TextField textField = new TextField() {
    @Override public void replaceText(int start, int end, String text) {
        super.replaceText(start, end, text.toUpperCase());
    }
};

Use TextFormatter

textField.setTextFormatter(new TextFormatter<>((change) -> {
    change.setText(change.getText().toUpperCase());
    return change;
}));

This part of the answer triggers textProperty twice and shouldn't be used. It is only here to show the original post.

Instead of using the onKeyPressed on your TextField, use the textProperty() of your TextField. Just add the following code inside the initialize() of the controller.

input_search.textProperty().addListener((ov, oldValue, newValue) -> {
     input_search.setText(newValue.toUpperCase());
});
1
Uwe On

Starting with JavaFX 8u40, you can set a TextFormatter object on a text field. This allows you to apply a filter/converter on the user input. Here's an example.

Listening to changes in the text property comes with the drawback of triggering two change events, one for the initial input (in your case the lower-case characters) and another one for the corrected input (the upper-case characters). If there are are other listeners on the text property, they will need to deal with both events and decide which event is relevant for them. The TextFormatter approach does not have this drawback.