Чтение онлайн

ЖАНРЫ

Основы программирования в Linux
Шрифт:

Все остальные символы в

inputMask
действуют как разделители в поле ввода
QLineEdit
.

В табл. 17.3 приведены примеры масок ввода и соответствующий им текст для ввода.

Таблица 17.3

Пример Допустимый ввод
"AAAAAA-999D"
Допустимо Athens-2004, но не Sydney-2000 или Atlanta-1996
"ААААnn-99-99;"
Допустимо March-03-12,
но не Мау-03-12 или September-03-12
"000.000.000.000"
Допустим IP-адрес, например, 192.168.0.1

Выполните упражнение 17.4.

Упражнение 17.4. Виджет
QLineEdit

Посмотрим, как действует виджет

QLineEdit
.

1. Сначала — заголовочный файл LineEdit.h:

#include <qmainwindow.h>

#include <qlineedit.h>

#include <qstring.h>

class LineEdit : public QMainWindow {

 Q_OBJECT

public:

 LineEdit(QWidget *parent = 0, const char *name = 0);

 QLineEdit *password_entry;

private slots:

 void Clicked;

};

2. LineEdit.cpp — уже знакомый файл реализации класса:

#include "LineEdit.moc"

#include <qpushbutton.h>

#include <qapplication.h>

#include <qlabel.h>

#include <qlayout.h>

#include <iostream>

LineEdit::LineEdit(QWidget *parent, const char *name) :

 QMainWindow(parent, name) {

 QWidget *widget = new QWidget(this);

 setCentralWidget(widget);

3. Для компоновки виджетов примените

QGridLayout
. Задайте число строк и столбцов, величины отступов и расстояния между виджетами:

 QGridLayout *grid = new QGridLayout(widget, 3, 2, 10, 10, "grid");

 QLineEdit *username_entry = new QLineEdit(widget, "username_entry");

 password_entry = new QLineEdit(widget, "password_entry");

 password_entry->setEchoMode(QLineEdit::Password);

 grid->addWidget(new QLabel("Username", widget, "userlabel"), 0, 0, 0);

 grid->addwidget(new QLabel("Password", widget, "passwordlabel"), 1, 0, 0);

 grid->addWidget(username_entry, 0, 1, 0);

 grid->addWidget(password_entry, 1, 1, 0);

 QPushButton *button = new QPushButton("Ok", widget, "button");

 grid->addWidget(button, 2, 1, Qt::AlignRight);

 resize(350, 200);

 connect(button, SIGNAL(clicked), this, SLOT(Clicked));

}

void LineEdit::Clicked(void) {

 std::cout << password_entry->text << "\n";

}

int main(int argc, char **argv) {

 QApplication app(argc, argv);

 LineEdit *window = new LineEdit;

 app.setMainWidget(window);

 window->show;

 return app.exec;

}

Выполнив

эту программу, вы должны получить результат, показанный на рис. 17.5.

Рис. 17.5

Как это работает

Вы создали два виджета

QLineEdit
, один подготовили для ввода пароля, задав
EchoMode
, и заставили его выводить содержимое при щелчке мышью кнопки
PushButton
. Обратите внимание на виджет
QGridLayout
, который очень полезен для размещения виджетов в табличной сетке. Когда виджет вставляется в сетку таблицы, вы передаете номер строки и столбца, нумерация начинается с 0, нулевые номера строки и столбца у верхней левой ячейки.

Кнопки Qt

Кнопки виджетов вездесущи и мало отличаются внешним видом, способом применения и API в разных комплектах инструментов. Неудивительно, что Qt предлагает стандартные кнопки

PushButton
, флажки
CheckBox
и радиокнопки (или зависимые переключатели)
RadioButton
.

QButton: базовый класс кнопок

Все виджеты кнопок в комплекте Qt — потомки абстрактного класса

QButton
. У этого класса есть методы для опроса и переключения включенного/выключенного состояния кнопки и задания текста кнопки или ее графического представления.

Вам никогда не придется обрабатывать виджет типа

QButton
(не путайте с виджетом
QPushButton
!), поэтому нет смысла приводить конструкторы. Далее перечислено несколько полезных функций-методов этого класса:

#include <qbutton.h>

virtual void QButton::setText(const QString&);

virtual void QButton::setPixmap(const QPixmap&);

bool QButton::isToggleButton const;

virtual void QButton::setDown(bool);

bool QButton::isDown const;

bool QButton::isOn const;

enum QButton::ToggleState { Off, NoChange, On }

ToggleState QButton::state const;

У функций

isDown
и
isOn
одно назначение. Обе они возвращают
TRUE
, если кнопка была нажата или активизирована.

Поделиться с друзьями: