© EVILEG 2015-2018
Рекомендует хостинг
TIMEWEB

Обработка событий клавиатуры с помощью KeyListener в TextField

KeyListener, TextField

Иногда появляется необходимость совершить определенные действия по нажатию клавиш в поле TextField . Далее разберемся как можно обрабатывать события, которые поступают с клавиатуры.

Для начала создаем JTextField

JTextField textField = new JTextField();

помешаем его на панель или фрейм

panel.add(textField);

Теперь нужно добавить слушатель, который будет вызываться каждый раз при вводе данных в TextField. Роль слушателя выполняет интерфейс KeyListener из пакета java.awt.event.

Интерфейс KeyListener имеет 3 метода:

- void keyPressed (KeyEvent e);

Вызывается при нажатии пользователем на любую клавишу.

- void keyReleased (KeyEvent e);

Вызывается после того, как пользователь нажмет и отпустит любую клавишу.

- void keyTyped ( KeyEvent e);

Срабатывает каждый раз, когда пользователь вводит символы Unicode. Таблица символов Unicode

Добавить интерфейс слушателя можно двумя способами:

1) реализовать этот интерфейс и все его методы;

numberOfRouteTextField.addKeyListener(new KeyListener() {

    public void keyPressed(KeyEvent event) {
    ... ... ... 
    }
    public void keyReleased(KeyEvent event) {
    ... ... ... 
    }
    public void keyTyped(KeyEvent event) {
    ... ... ... 
    }
});

2) расширить  абстрактный класс KeyAdapter, переопределяя только необходимые методы.

numberOfRouteTextField.addKeyListener(new NumberKeyListener());

class NumberKeyListener extends KeyAdapter {
    public void keyReleased(KeyEvent e) {
    ... ... ...  
    }
}

Кроме того, мы можем сделать так, чтобы событие срабатывало при нажатии какой-то конкретной клавиши. Каждый символ, цифра, буква и клавиши управления на клавиатуре имеют свой код (код ключа).  Добавляем проверку в любой из переопределенных методов. Например, тело метода будет выполняться только после нажатия пользователем клавиши Enter:

public void keyReleased(KeyEvent event) {
    if(event.getKeyCode() == KeyEvent.VK_ENTER ) {
    // тело метода
    }
}

Далее пример небольшой реализации. Что я хочу получить ?

У меня имеется поле TextField c именем numberOfRouteTextField. Пользователь вводит количество путей. Затем, сразу после после ввода числа, появляется таблица с числом строк равным введенному числу.

import javax.swing.*;
import javax.swing.table.DefaultTableModel;
import java.awt.*;
import java.awt.event.*;
import java.util.ArrayList;

public class Routes {

    private JTextField numberOfRouteTextField;
    private DefaultTableModel tableModel;
    private Frame frame;
    private ArrayList<String[]> dataOfTableAboutRoutes;

    public static void main(String args[]) {

        Routes routes = new Routes();
        routes.CreateGui();
    }

    private void CreateGui() {

        frame = new JFrame("Построение таблицы маршрутов");
        JLabel numberOfRoutesLabel;
        JPanel widgetPanel = new JPanel();                      // создаем панель, где будут располагаться все элементы
        GridBagLayout gblWidgetPanel = new GridBagLayout();     // определяем менеджер компоновки
        GridBagConstraints constraints = new GridBagConstraints();
        widgetPanel.setLayout(gblWidgetPanel);

        numberOfRoutesLabel = new JLabel("Количество маршрутов:");
        constraints.gridwidth = 1;   // сколько ячеек занимает объект
        constraints.gridy = 0;       //  какая по-счету ячейка по вертикали
        gblWidgetPanel.setConstraints(numberOfRoutesLabel, constraints);
        widgetPanel.add(numberOfRoutesLabel);

        numberOfRouteTextField = new JTextField(10);
        constraints.gridy = 1;
        numberOfRouteTextField.addKeyListener(new NumberKeyListener()); // добавляем слушателя к TextField
        gblWidgetPanel.setConstraints(numberOfRouteTextField, constraints);
        widgetPanel.add(numberOfRouteTextField);           // размещаем на панели

        dataOfTableAboutRoutes = new ArrayList<>();   // здесь будет хранится все содержимое таблицы по строкам
        tableModel = new DefaultTableModel();
        JTable writingRoutesTable = new JTable(tableModel);
        constraints.gridy = 2;          // сколько ячеек занимает таблица
        gblWidgetPanel.setConstraints(writingRoutesTable, constraints);
        widgetPanel.add(writingRoutesTable);

        frame.add(BorderLayout.WEST,widgetPanel);
        frame.setSize(300, 300);
        frame.setVisible(true);
    }

    class NumberKeyListener extends KeyAdapter {   // расширяем абстрактный класс KeyAdapter

        public void keyReleased(KeyEvent event) {  // переопределяем необходимые методы

            // данный метод будет срабатывать после того, как пользователь введет любой символ с клавиатуры
            // в нашем случае неплохо было бы сделать проверку на вводимые данные, чтобы это были только целые числа

            if (event.getKeyCode() != KeyEvent.VK_BACK_SPACE) {

                // если пользователь нажал BackSpace с желанием стереть содержимое, то тело функции не будет выполняться

                String[] columnNames = new String[]{"Номер маршрута", "Начало", "Конец"}; // задаем заголовки таблицы
                int numberOfRoutes = Integer.parseInt(numberOfRouteTextField.getText());  // получаем число из TextField

                for (int i = 0; i < dataOfTableAboutRoutes.size(); i++) {
                    tableModel.removeRow(0);
                    // после удаления элементы смещаются,поэтому мы каждый раз удаляем первый элемент
                }
                dataOfTableAboutRoutes.clear();  // очищаем содержимое таблицы

                for (int i = 1; i <= numberOfRoutes; i++) {
                    String[] temp = {"маршрут " + i, "",""};
                    dataOfTableAboutRoutes.add(temp); // заносим в таблицу число строк, равное заданному числу
                }
                tableModel.setColumnIdentifiers(columnNames); // устанавливаем в таблицу заголовки
                for (String[] dataOfTable : dataOfTableAboutRoutes) {
                    tableModel.addRow(dataOfTable);    // помещаем в таблицу содержимое из ArrayList
                }
            }
        }
    }
}

Так выглядит работа программы

Комментарии

Комментарии

Только авторизованные пользователи могут оставлять комментарии.
Пожалуйста, Авторизуйтесь или Зарегистрируйтесь
19 октября 2018 г. 8:05
Василий Ильченко

C++ - Тест 001. Первая программа и типы данных

  • Результат:66баллов,
  • Очки рейтинга-1
18 октября 2018 г. 16:14
druidx

C++ - Тест 002. Константы

  • Результат:25баллов,
  • Очки рейтинга-10
18 октября 2018 г. 15:58
druidx

C++ - Тест 001. Первая программа и типы данных

  • Результат:80баллов,
  • Очки рейтинга4
Последние комментарии
19 октября 2018 г. 7:59
Евгений Легоцкой

Python 3 - Урок 001. Введение

Добрый день! Вот это линуксовая директива #!/usr/bin/python3 Указывает, где находится python пакет в системе. А вы видимо под windows разрабатываете. Попробуйте просто у...
19 октября 2018 г. 7:54
Abdurashid Parpieff

Python 3 - Урок 001. Введение

Python 3.7.0 (v3.7.0:1bf9cc5093, Jun 27 2018, 04:06:47) [MSC v.1914 32 bit (Intel)] on win32 Type "copyright", "credits" or "license()" for more information. >>> #!/usr/bi...
18 октября 2018 г. 8:31
Евгений Легоцкой

Qt/C++ - Урок 006. QSqlQueryModel - Таблицы в Qt с помощью SQL-запросов

Как-то даже странно, а вы что ли в отдельный поток убрали базу данных? То есть изначально инстанс создаётся в одном потоке, а все QSqlQuery в другом потоке? Они должны находиться в одном поток...
17 октября 2018 г. 8:43
pasagir

Qt/C++ - Урок 006. QSqlQueryModel - Таблицы в Qt с помощью SQL-запросов

Не получается bool DataBase::insertDataIntoDB(QVariantList data){ QSqlQuery query(db); QString str; qDebug()<<"InsertInsertInsertInsertInsert"<<QThread::curre...
17 октября 2018 г. 7:09
Евгений Легоцкой

Qt/C++ - Урок 006. QSqlQueryModel - Таблицы в Qt с помощью SQL-запросов

Попробуйте передать инстанс базы данных в конструктор QSqlQuery QSqlQuery q(db);
Сейчас обсуждают на форуме
19 октября 2018 г. 11:52
Евгений Легоцкой

Уведомления о лайках и дислайках

Вообще планируется система ачивок. А рейтинг есть в зачаточном состоянии. Но для системы ачивок нужно собраться с духом и выделить приличную кучку времени. Помимо того, что сами ачивки п...
18 октября 2018 г. 12:15
Михаиллл

Настройка Qt Creator для Android

все галочки включены.
18 октября 2018 г. 8:16
Allyans .

Работа с WinAPI в QT(изменение title bar)

Хорошо, я попробуй по вашей статье.
15 октября 2018 г. 12:45
Allyans .

QGraphicsItem change color

Хорошо)
11 октября 2018 г. 10:13
Arrow

Работа с WebView в QML

Нашел в чем проблема. Пишу на случай если кому-то попадется такое же счастье с WebView как и мне. Проблема как оказалась с Debug версией, так как в Release и Profile все работает (...
Присоединяйтесь к нам в социальных сетях