JavaFX TextField : Automatically transform text to uppercase
Asked Answered
M

2

7

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...
}
Mancuso answered 17/6, 2015 at 7:20 Comment(0)
B
17

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());
});
Bayle answered 17/6, 2015 at 7:34 Comment(3)
Note, that this will call the listener twice. First you get your untransformed string the user typed in, then you get the uppercased string you set inside the listener.Jupiter
@Jupiter Thanks for pointing it out. I have added alternatives.Bayle
Actually I believe the original (with the listener) causes a NPE when you Ctrl-Z from the text field.Surface
P
6

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.

Pediform answered 6/4, 2016 at 7:0 Comment(1)
Thanks, I've learned something new. But there seems to be another drawback. A TextField with a TextFormatter set seems to consume the ESC KeyEvent. I don't have time to research it now but the reason might be that with TextFormatter set, ESC is used to cancel current edit: https://mcmap.net/q/1475558/-javafx-textfield-canceledit-not-working-as-expectedElkin

© 2022 - 2024 — McMap. All rights reserved.