Рина Сергеева
Рина СергееваМамыр 3, 2018, 3:04 Т.Ж.

TextField ішіндегі KeyListener көмегімен пернетақта оқиғаларын өңдеу

Иногда появляется необходимость совершить определенные действия по нажатию клавиш в поле 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 хостинг.

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

Пікірлер

Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
Кіріңіз немесе Тіркеліңіз
Г

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

  • Нәтиже:66ұпай,
  • Бағалау ұпайлары-1
t

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

  • Нәтиже:33ұпай,
  • Бағалау ұпайлары-10
t

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

  • Нәтиже:52ұпай,
  • Бағалау ұпайлары-4
Соңғы пікірлер
G
GoattRockҚыр. 3, 2024, 1:50 Т.Қ.
Linux жүйесінде файлдарды қалай көшіруге болады Задумывались когда-нибудь о том, как мы привыкли доверять свои вещи службам грузоперевозок? Сейчас такие услуги стали неотъемлемой частью нашей жизни, особенно когда речь идет о переездах между …
d
dblas5Шілде 5, 2024, 11:02 Т.Ж.
QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
k
kmssrАқп. 8, 2024, 6:43 Т.Қ.
Qt Linux - Сабақ 001. Linux астында Autorun Qt қолданбасы как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
АК
Анатолий КононенкоАқп. 5, 2024, 1:50 Т.Ж.
Qt WinAPI - Сабақ 007. Qt ішінде ICMP Ping арқылы жұмыс істеу Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
Енді форумда талқылаңыз
Evgenii Legotckoi
Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
F
FynjyШілде 22, 2024, 4:15 Т.Ж.
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
BlinCT
BlinCTМаусым 25, 2024, 1 Т.Ж.
Нарисовать кривую в qml Всем привет. Имеется Лист листов с тосками, точки получаны интерполяцией Лагранжа. Вопрос, как этими точками нарисовать кривую? ChartView отпадает сразу, в qt6.7 появился новый элемент…
BlinCT
BlinCTМамыр 5, 2024, 5:46 Т.Ж.
Написать свой GraphsView Всем привет. В Qt есть давольно старый обьект дял работы с графиками ChartsView и есть в 6.7 новый но очень сырой и со слабым функционалом GraphsView. По этой причине я хочу написать х…
Evgenii Legotckoi
Evgenii LegotckoiМамыр 2, 2024, 2:07 Т.Қ.
Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Добрый день. По моему мнению - да, но то, что будет касаться вызовов к функционалу Андроида, может создать огромные трудности.

Бізді әлеуметтік желілерде бақылаңыз