Основы программирования в Linux
Шрифт:
Все остальные символы в
inputMask
действуют как разделители в поле ввода QLineEdit
. В табл. 17.3 приведены примеры масок ввода и соответствующий им текст для ввода.
Таблица 17.3
Пример | Допустимый ввод |
---|---|
"AAAAAA-999D" | Допустимо Athens-2004, но не Sydney-2000 или Atlanta-1996 |
"ААААnn-99-99;" | Допустимо March-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
, если кнопка была нажата или активизирована.
Поделиться с друзьями: