国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 學(xué)院 > 開(kāi)發(fā)設(shè)計(jì) > 正文

qt (2) —— 部分部件

2019-11-11 06:39:58
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

本文大部分內(nèi)容學(xué)習(xí)自《Foundations of Qt Development》

notes

qt name rules

類的名字以大寫(xiě)字母開(kāi)始,每一個(gè)新的詞也以大寫(xiě)字母開(kāi)頭,也即駱駝拼寫(xiě)法 (CamelCasing) 方法的名字也遵從CamelCase,但是需要注意的是它以小寫(xiě)字母開(kāi)頭。

PRotected slots

被protect的slot只有被用作方法的時(shí)候才會(huì)被保護(hù)。私有的或者受保護(hù)的slots仍然能夠用于connect sigals

meta-object和信號(hào)槽機(jī)制

meta-object自己知道signals和slots,meta-object compiler (moc) 會(huì)用c++實(shí)現(xiàn)相關(guān)的內(nèi)容。

signals and slots

qt使用指針實(shí)現(xiàn)信號(hào)槽,當(dāng)我們發(fā)出信號(hào),實(shí)際上也就在調(diào)用信號(hào)方法,該方法被moc實(shí)現(xiàn)。signal方法隨即調(diào)用slots。源對(duì)象和目標(biāo)對(duì)象就是指向QObject或者它的子類的指針。

LIFO and FIFO

LIFO means “l(fā)ast in, first out”. 代表:棧 FIFO means “fist in, first out”. 代表:隊(duì)列

Qt designer

命令行啟動(dòng):shell> designer qt4可能是shell> designer-qt4

widgets

QSlider and progressBar

下面的小應(yīng)用由dialog, horizontalSlider, progressBar, pushButton, label構(gòu)成。 第三個(gè)progressBar的范圍是(0,0),結(jié)果時(shí)不顯示數(shù)值結(jié)果并不斷運(yùn)動(dòng)的,第4個(gè)progressBar的范圍我想設(shè)置成無(wú)窮大,但不確定這種方法setRange(-1,-1)是否正確。

Dialog::Dialog(QWidget *parent) : QDialog(parent), ui(new Ui::Dialog){ ui->setupUi(this);/* *for QProgressBar format : QString *This property holds the string used to generate the current text. *%p - is replaced by the percentage completed. %v - is replaced by the current value. %m - is replaced *by the total number of steps. The default value is "%p%". */ ui->progressBar->setFormat("%p%"); // default ui->progressBar_2->setFormat("%v out of %m"); //custom text ui->progressBar_3->setRange(0,0); // hide text and keep moving. ui->progressBar_4->setRange(-1,-1); // static connect(ui->horizontalSlider,SIGNAL(valueChanged(int)),ui->progressBar,SLOT(setValue(int))); connect(ui->horizontalSlider,SIGNAL(valueChanged(int)),ui->progressBar_2,SLOT(setValue(int))); connect(ui->horizontalSlider,SIGNAL(valueChanged(int)),ui->progressBar_3,SLOT(setValue(int))); connect(ui->horizontalSlider,SIGNAL(valueChanged(int)),ui->progressBar_4,SLOT(setValue(int))); connect(ui->pushButton,SIGNAL(clicked()),this,SLOT(close()));}

這里寫(xiě)圖片描述

QLineEdit

LineEdit的echo mod可以設(shè)置成不同的格式,屬性MaxLength則設(shè)定了能夠填寫(xiě)的最大字符數(shù)。

Dialog::Dialog(QWidget *parent) : QDialog(parent), ui(new Ui::Dialog){ ui->setupUi(this); ui->lineEdit_2->setEchoMode(QLineEdit::PassWord); ui->lineEdit_3->setMaxLength(9); connect(ui->lineEdit,SIGNAL(textChanged(QString)),ui->lineEdit_4,SLOT(setText(QString))); connect(ui->lineEdit_2,SIGNAL(textChanged(QString)),ui->lineEdit_5,SLOT(setText(QString))); connect(ui->lineEdit_3,SIGNAL(textChanged(QString)),ui->lineEdit_6,SLOT(setText(QString)));}

這里寫(xiě)圖片描述

QListWidget

將listWidget放進(jìn)Dialog后,合理設(shè)置layout,我們可以在改變dialog的大小同時(shí)產(chǎn)生上下滑動(dòng)條。 下面的例子對(duì)choose and click做了一些處理。 dialog.cpp:

#include "dialog.h"#include "ui_dialog.h"Dialog::Dialog(QWidget *parent) : QDialog(parent), ui(new Ui::Dialog){ ui->setupUi(this); for(int i=0;i<10;i++){ ui->listWidget->addItem(QString::number(i)+" item"); }}Dialog::~Dialog(){ delete ui;}void Dialog::on_pushButton_clicked(){ QListWidgetItem *it = ui->listWidget->currentItem(); it->setText("you click "+it->text()); it->setBackground(Qt::black); it->setTextColor(Qt::red);}

這里寫(xiě)圖片描述 好好利用QListWidget,如takeItem, addItem等方法,我們可以創(chuàng)建出類似于管理書(shū)單的應(yīng)用窗體。 dialog.h

#ifndef DIALOG_H#define DIALOG_H#include <QDialog>#include <QListWidget>#include <QPushButton>namespace Ui {class Dialog;}class Dialog : public QDialog{ Q_OBJECT QListWidget *listLeft, *listRight; QPushButton *buttonLeft, *buttonRight;public: explicit Dialog(QWidget *parent = 0); ~Dialog();private: Ui::Dialog *ui;public slots: void moveRight(); void moveLeft();};#endif // DIALOG_H

dialog.cpp

#include "dialog.h"#include "ui_dialog.h"#include <QGridLayout>#include <QStringList>#include <QList>#include <QMessageBox>Dialog::Dialog(QWidget *parent) : QDialog(parent), ui(new Ui::Dialog){ ui->setupUi(this); listLeft = new QListWidget(this); listRight = new QListWidget(this); buttonLeft = new QPushButton(">>",this); buttonRight = new QPushButton("<<",this); QGridLayout *gLayout = new QGridLayout(this); gLayout->addWidget(listLeft,0,0); gLayout->addWidget(listRight,0,1); gLayout->addWidget(buttonLeft,1,0); gLayout->addWidget(buttonRight,1,1); QStringList items; items<<"apple"<<"pear"<<"banana"<<"peach"; listLeft->addItems(items); connect(buttonLeft,SIGNAL(clicked()),this,SLOT(moveRight())); connect(buttonRight,SIGNAL(clicked()),this,SLOT(moveLeft()));}Dialog::~Dialog(){ delete ui;}void Dialog::moveLeft(){ if(listRight->selectedItems().count()!=1) return; QListWidgetItem *item = listRight->takeItem(listRight->currentRow()); listLeft->addItem(item);}void Dialog::moveRight(){ if(listLeft->selectedItems().count()!=1) return; QListWidgetItem *item = listLeft->takeItem(listLeft->currentRow()); listRight->addItem(item);}

這里寫(xiě)圖片描述

QPushButton

QPushButton可以被設(shè)置觸發(fā)(pressed),接著舉一個(gè)例子,應(yīng)用QMessageBox,QPushButton,QString. 工程ButtonDialog,程序運(yùn)行后,點(diǎn)擊toggle me按鈕,直到下一次點(diǎn)擊它,它一直處于pressed狀態(tài)。 pro文件:

#-------------------------------------------------## Project created by QtCreator 2017-02-04T18:29:24##-------------------------------------------------QT += core guigreaterThan(QT_MAJOR_VERSION, 4): QT += widgetsTARGET = ButtonDialogTEMPLATE = appSOURCES += main.cpp/ dialog.cppHEADERS += dialog.hFORMS += dialog.ui

Dialog.h:

#ifndef DIALOG_H#define DIALOG_H#include <QDialog>#include <QPushButton>namespace Ui {class Dialog;}class Dialog : public QDialog{ Q_OBJECTpublic: explicit Dialog(QWidget *parent = 0); ~Dialog(); public slots: void buttonClicked(); void buttonToggled();private: Ui::Dialog *ui; QPushButton *clickButton; QPushButton *toggleButton;};#endif // DIALOG_H

Dialog.cpp

#include "dialog.h"#include "ui_dialog.h"#include <QVBoxLayout>#include <QMessageBox>Dialog::Dialog(QWidget *parent) : QDialog(parent), ui(new Ui::Dialog){ ui->setupUi(this); clickButton = new QPushButton("click me",this); toggleButton = new QPushButton("toggle me",this); toggleButton->setCheckable(true); QVBoxLayout *vLayout = new QVBoxLayout(this); vLayout->addWidget(clickButton); vLayout->addWidget(toggleButton); connect(clickButton,SIGNAL(clicked()),this,SLOT(buttonClicked())); connect(toggleButton,SIGNAL(clicked()),this,SLOT(buttonToggled()));}Dialog::~Dialog(){ delete ui;}void Dialog::buttonClicked(){ QMessageBox::information(this,"Clicked","the Button is cliecked.");}void Dialog::buttonToggled(){ QMessageBox::information(this,"Toggled",QString("the button is %1!")/ .arg(toggleButton->isChecked()?"pressed":"released"));}

main.cpp

#include "dialog.h"#include <Qapplication>int main(int argc, char *argv[]){ QApplication a(argc, argv); Dialog w; w.show(); return a.exec();}

這里寫(xiě)圖片描述

QLabel

QLabel可是設(shè)置shortCut,setBuddy。 在下面的例子中,按下”Alt+1”, 光標(biāo)會(huì)聚焦于LineEdit1,按下”Alt +2”, 光標(biāo)聚焦于LineEdit2。 這里寫(xiě)圖片描述 dialog.cpp

#include "dialog.h"#include "ui_dialog.h"Dialog::Dialog(QWidget *parent) : QDialog(parent), ui(new Ui::Dialog){ ui->setupUi(this); ui->label->setText("Line&1"); ui->label_2->setText("Line&2"); ui->label->setBuddy(ui->lineEdit); ui->label_2->setBuddy(ui->lineEdit_2);}Dialog::~Dialog(){ delete ui;}

QComboBox

假設(shè)在類中聲明了slot,我們一定要在cpp中定義。 comboBox.h

#ifndef COMBOBOX_H#define COMBOBOX_H#include <QDialog>namespace Ui {class ComboBox;}class ComboBox : public QDialog{ Q_OBJECTpublic: explicit ComboBox(QWidget *parent = 0); ~ComboBox();public slots: void myshow(); //show is key word, care about it.private: Ui::ComboBox *ui;};#endif // COMBOBOX_H

comboBox.cpp

#include "combobox.h"#include "ui_combobox.h"#include <QFontComboBox>#include <QMessageBox>ComboBox::ComboBox(QWidget *parent) : QDialog(parent), ui(new Ui::ComboBox){ ui->setupUi(this); QFont font("KaiTi_GB2312",16); ui->comboBox->setFont(font); int i; for(i=0;i<10;i++){ ui->comboBox->addItem(QString::number(i)+" item"); } connect(ui->pushButton,SIGNAL(clicked(bool)),this,SLOT(myshow()));}void ComboBox::myshow(){ QMessageBox::information(this,"choosed",ui->comboBox->currentText());}ComboBox::~ComboBox(){ delete ui;}

main.cpp

#include "combobox.h"#include <QApplication>int main(int argc, char *argv[]){ QApplication a(argc, argv); ComboBox w; w.show(); return a.exec();}

這里寫(xiě)圖片描述

QSPinBox + LCD Number

在designer中進(jìn)行connect設(shè)置,連接spinBox的valueChanged()和LCD number的display()。QDoubleSpinBox相比QSpinBox提供了更高的精度。 這里寫(xiě)圖片描述 這里寫(xiě)圖片描述

QCalender + QDateTime

QCalender和QDateTime(QDate)均可表示日期。前者更加直觀,后者更加精確,容易修改。

)

這里寫(xiě)圖片描述

QGridLayout

GridLayout很強(qiáng)大,因?yàn)樗`活,坐標(biāo)定位,所以用起來(lái)很方便。

#include <QApplication>#include <QGridLayout>#include <QLabel>#include <QDialog>#include <QString>int main(int argc,char *argv[]){ QApplication app(argc,argv); QDialog dlg; dlg.resize(400,400); dlg.show(); QGridLayout *grid = new QGridLayout(&dlg); int i,j; int counter = 1; for(i=0;i<10;i++){ for(j=0;j<10;j++){ QLabel *label = new QLabel(QString::number(counter)); label->setFrameStyle(QFrame::Panel | QFrame::Sunken); grid->addWidget(label,i,j); counter++; } } grid->setMargin(2); return app.exec();}

這里寫(xiě)圖片描述

QVBoxLayout

.pro

SOURCES += / main.cppQT += widgets

main.cpp

#include <QApplication>#include <QLabel>#include <QDialog>#include <QVBoxLayout>#include <QDialogButtonBox>#include <QPushButton>#include <QGridLayout>#include <QDebug>int main(int argc,char *argv[]){ QApplication app(argc,argv); QDialog dlg; dlg.resize(100,200); dlg.show(); QLabel *label = new QLabel("hello world."); label->show(); QDialogButtonBox *buttons = new QDialogButtonBox(QDialogButtonBox::Ok |QDialogButtonBox::Cancel); QVBoxLayout *vLayout = new QVBoxLayout(&dlg); vLayout->addWidget(label); vLayout->addStretch(); vLayout->addWidget(buttons); return app.exec();}

這里寫(xiě)圖片描述


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 陇西县| 南涧| 山阳县| 津南区| 利津县| 宜良县| 寿阳县| 保德县| 韶山市| 镇宁| 轮台县| 遵义市| 武汉市| 集贤县| 黎城县| 石阡县| 武清区| 临桂县| 巴林右旗| 伊宁市| 汤原县| 息烽县| 木兰县| 宜都市| 大化| 资溪县| 天等县| 汽车| 镶黄旗| 沁源县| 宁陕县| 海南省| 监利县| 徐汇区| 四子王旗| 黔江区| 南木林县| 胶南市| 天柱县| 营口市| 乐昌市|