轉自 https://blog.csdn.net/Chiang2018/article/details/102888785
----------------------
版權聲明:本文為CSDN博主「王木木1214」的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/Chiang2018/article/details/102888785
-----------------------
1、設置tab鍵的聚焦順序:static void QWidget::setTabOrder(QWidget * first, QWidget * second);
如果不想某子部件被聚焦,可為子部件設置:setFocusPolicy(Qt::NoFocus);
2、設置編輯無右鍵菜單:setContextMenuPolicy(Qt::NoContextMenu);
3、若要監視對話框內的某些子控件,可以在對話框的構造函數內為每個子控件安裝事件過濾器,然后在對話框的eventFilter函數實現中做判斷。注意:
1、如果指定的事件被過濾及不需要通知子控件則必須返回true,否則返回false。
2、如果在eventFilter()函數中刪除接收對象,一定要返回true。如果返回false,Qt給已刪除的對象發送事件,程序會crash。
3、對話框和子控件必須處于同一線程,否則,過濾器將不被調用。
CustomerInfoDialog::CustomerInfoDialog(QWidget *parent)? ? : QDialog(parent)
{
? ? firstNameEdit->installEventFilter(this);
? ? lastNameEdit->installEventFilter(this);
? ? cityEdit->installEventFilter(this);
? ? phoneNumberEdit->installEventFilter(this);
}
4、Q_UNSED(object),僅僅是為了消除變量未使用的編譯警告
5、QKeySequence是鍵系列類,通常用它來判斷一些常用的響應。
例如:在事件過濾時,通過QKeyEvent的bool QKeyEvent::matches(QKeySequence::StandardKey key) const函數來判斷當前的按鍵組合狀態,常用的有:QKeySequence::SelectAll、QKeySequence::Copy、QKeySequence::Paste等,也可以自行構造來判斷,例如:QKeySequence(Qt::CTRL + Qt::Key_P);或QKeySequence(tr("Ctrl+p"));
6、軟件重啟實現方式:
void Widget::reboot()
{
? ? QString program = QApplication::applicationFilePath();
? ? QStringList arguments = QApplication::arguments();
? ? QString workingDirectory = QDir::currentPath();
? ? //startDetached()將已分離的方式啟動一個新進程
? ? QProcess::startDetached(program, arguments, workingDirectory);
? ? QApplication::exit();
}
7、MSVC與MinGW的區別:
MSVC是指微軟的VC編譯器
MinGW是指是Minimalist GNU on Windows的縮寫。它是一個可自由使用和自由發布的Windows特定頭文件和使用GNU工具集導入庫的集合,允許你在GNU/Linux和Windows平臺生成本地的Windows程序而不需要第三方C運行時庫。
8、QT尋找子控件函數:
1、T QObject::findChild(const QString & name = QString(), Qt::FindChildOptions options = Qt::FindChildrenRecursively)
2、QList<T> QObject::findChildren(const QString &name=QString()) const
例子:
QPushButton *button = parentWidget->findChild<QPushButton *>("button1");
QList<QLineEdit *> lineEdit = tabWidget.findChildren<QLineEdit *>("lineEdit");
9、QDialog及QMainWindow的右下角默認有個QSizeGrip(提示窗口拉伸標志),使用setSizeGripEnabled()使能它
10、QDialog對話框類型:
模態對話框:整個應用程序窗口都無法接受用戶響應,處于等待狀態,后面的代碼也得不到運行。
非模態對話框:用戶仍然可以對其他窗口進行操作,不會因為這個對話框未關閉就不能操作其他窗口。
半模態對話框:阻塞窗口的響應,但是不會影響后續代碼的執行。調用setModal(true)或者setWindowModality(),然后show()。
11、QWidget提供了setWindowModality()方法設置窗口半模態or非模態:
Qt::NonModal:非模態對話框(默認值)
Qt::WindowModal:只會阻塞父窗口、父窗口的父窗口及兄弟窗口。(半模態對話框)
Qt::ApplicationModal:阻塞整個應用程序的所有窗口。(半模態對話框)
12、QDialog的open()方法是顯示一個半模態對話框,show()是顯示對話框,不關心對話框類型,exec()顯示模態對話框,并且阻塞整個程序,即內部將對話框屬性設置為:Qt::ApplicationModal
13、QLabel設置文本對齊方式:
????????1) 成員函數:setAlignment(Qt::AlignCenter);
????????2) 樣式表:setStyleSheet("qproperty-alignment: 'AlignBottom | AlignRight';");
14、QLabel設置文本過長時,自動換行:setWordWrap(true);需要文本內含有空格。
一般情況下,自動換行之后文本上下行會距離比較近,我們可以通過下面方式來設置行高。
pLabel->setWordWrap(true);
QString strText = QStringLiteral("一去二三里,煙村四五家。亭臺六七座,八九十枝花。");
QString strHeightText = "<p style=\"line-height:%1%\">%2<p>";
strText = strHeightText.arg(150).arg(strText);
pLabel->setText(strText);
15、QLabel 如果過長,我們又不想換行,只想把其中一部分省略為…,那么我們可以通過QFontMetrics來實現:
QString strText = QStringLiteral("一去二三里,煙村四五家。亭臺六七座,八九十枝花。");
QString strElidedText = pLabel->fontMetrics().elidedText(strText, Qt::ElideRight, 200, Qt::TextShowMnemonic);
pLabel->setText(strElidedText);
16、設置多個按鈕互斥,可以先把幾個按鈕設置setCheckable(true),表示可以被選中,然后全部放到QButtonGroup中,設置setExclusive(true),表示其子按鈕為互斥,通過關聯信號buttonClicked(QAbstractButton*),知道哪個按鈕被按下了
17、QCheckBox使用setTristate(true),啟用其三態功能
18、QLineEdit默認具有由平臺風格指南規定的邊框,可以通過setFrame(false)將其關閉。
19、QLineEdit 可以通過addAction函數添加小部件,并指定其顯示位置
QAction * addAction(const QIcon & icon, ActionPosition position)
20、QLineEdit 可以設置驗證器(setValidator()),也可以設置輸入掩碼(setInputmask())
21、QSpinBox和QDoubleSpinBox均派生自QAbstractSpinBox。常用方法:
pSpinBox->setRange(20, 200);? // 范圍
pSpinBox->setSingleStep(10); // 步長
pSpinBox->setValue(150);? // 當前值
pSpinBox->setPrefix("$ ");? // 前綴
pSpinBox->setSuffix(" %");? // 后綴
pSpinBox->setWrapping(true);? // 開啟循環
pSpinBox->setSpecialValueText(tr("Automatic"));? // 特殊文本值即默認值
如果使用prefix()、suffix()和specialValueText()沒有提供足夠的控制,可以子類化QSpinBox,重寫valueFromText()和textFromValue()。
21、QProgressBar-如果最小值和最大值都設置為0,進度條會顯示一個繁忙指示,而不會顯示當前值。setInvertedAppearance()用于設置進度條的行進方向。setTextVisible()設置進度條上的文本是否顯示。setFormat()設置文本顯示格式。
22、QDateTimeEdit-setCalendarPopup(true)設置添加日歷彈出
23、QScrollArea通過成員函數setWidget()為一個控件指定一個滾動條。可以使用widget()函數來獲取部件,視圖可以使用setWidgetResizable()函數來調整大小。使用takeWidget()函數將部件從滾動區域中移除,移除的同時,會將部件的所有權傳遞到調用者,可以用QWidget來接收。
24、QToolBox類提供了一個列(選項卡式的)部件條目。Item的添加使用addItem(),或通過insertItem()在特定位置插入。
25、QSystemTrayIcon類為應用程序在系統托盤中提供一個圖標。
26、QFileSystemWatcher類用于提供監視文件和目錄修改的接口。
27、QDesktopServices類提供的函數用于訪問常見的桌面服務。其常用靜態成員函數如下:
bool openUrl(const QUrl & url);//如果成功,返回true;否則,返回false。
//1、如果是網絡URL,則以用戶桌面環境的適當Web瀏覽器打開指定的的url。
//2、如果是本地文件,將會使用默認程序打開,例如.txt使用notepad
//3、如果是文件夾,則使用window直接打開
//4、如果指定一個mail地址,將會打開e-mail客戶端(例如:Outlook)
//例如,下面的URL包含收件人(user@qt.com)、主題(Qt)和正文(I am a Qter):
//QString strUrl = QString("mailto:%1?subject=%2&//body=%3").arg("user@qt.com").arg("Qt").arg("I am a Qter");
//QDesktopServices::openUrl(QUrl(strUrl));
//為給定的scheme設置handler,receiver是接受者,method為receiver提供的處理函數。
void setUrlHandler(const QString & scheme, QObject * receiver, const char * method)
//例如:QDesktopServices::setUrlHandler("http", this, "openUrl_wmm");
//表示所有使用QDesktopServices::openUrl()處理的http形式的url都不在使用默認的web瀏覽器打開,而是直//接調用你的成員函數openUrl_wmm(),注意此函數只有一個參數(即const QUrl &url),且必須為公有槽函數
//刪除以上面方式指定的scheme預先設定的URL handler。
void unsetUrlHandler(const QString & scheme)
28、QTimer可以設置定時器的類型,默認為:Qt::CoarseTimer
void setTimerType(Qt::TimerType atype)
如果直接調用QTimer的start()函數,而沒有設置間隔,則定時器將會在沒有事件的情況下,不停的發出timeout信號。
————————————————
版權聲明:本文為CSDN博主「王木木1214」的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/Chiang2018/article/details/102888785