Рина Сергеева
Рина Сергеева3 мая 2018 г. 3:04

Обработка событий клавиатуры с помощью 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
                }
            }
        }
    }
}

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

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

Комментарии

Только авторизованные пользователи могут публиковать комментарии.
Пожалуйста, авторизуйтесь или зарегистрируйтесь
ОК

Qt - Тест 001. Сигналы и слоты

  • Результат:47баллов,
  • Очки рейтинга-6
A
  • Alena
  • 19 января 2025 г. 11:41

C++ - Тест 005. Структуры и Классы

  • Результат:58баллов,
  • Очки рейтинга-2
OI
  • Ora Iro
  • 24 декабря 2024 г. 6:38

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

  • Результат:40баллов,
  • Очки рейтинга-8
Последние комментарии
ИМ
Игорь Максимов22 ноября 2024 г. 11:51
Django - Урок 017. Кастомизированная страница авторизации на Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Evgenii Legotckoi
Evgenii Legotckoi31 октября 2024 г. 14:37
Django - Урок 064. Как написать расширение для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
A
ALO1ZE19 октября 2024 г. 8:19
Читалка fb3-файлов на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Игорь Максимов5 октября 2024 г. 7:51
Django - Урок 064. Как написать расширение для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas55 июля 2024 г. 11:02
QML - Урок 016. База данных SQLite и работа с ней в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Сейчас обсуждают на форуме
n
nkly3 января 2025 г. 2:52
Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
M
Marsel16 августа 2023 г. 14:26
OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.
Evgenii Legotckoi
Evgenii Legotckoi24 июня 2024 г. 15:11
добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
t
tonypeachey115 ноября 2024 г. 6:04
google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
NSProject
NSProject4 июня 2022 г. 3:49
Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…

Следите за нами в социальных сетях