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
.Все виджеты кнопок в комплекте Qt — потомки абстрактного класса QButton
Вам никогда не придется обрабатывать виджет типа QButton
QPushButton
!), поэтому нет смысла приводить конструкторы. Далее перечислено несколько полезных функций-методов этого класса:#include
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
, если кнопка была нажата или активизирована.Часто вам нужно отключить или сделать серым вариант, если он недоступен в данный момент. Сделать недоступным любой виджет, включая QButton, можно с помощью вызова метода QWidget::setEnable(FALSE)
У QButton
QPushButton
QCheckBox
QRadioButton
QPushButton
QButton
, она порождает при активизации сигнал clicked
и обычно используется для связи со слотом и выполнения некоторого действия.Вы уже применяли кнопку QPushButton
QPushButton
можно превратить из кнопки, не помнящей своего состояния, в кнопку-выключатель (т.е. способную быть включенной и выключенной), вызвав метод setToggleButton
. (Если помните, у комплекта GTK+ из предыдущей главы есть для этих целей разные виджеты.)