文章目录
- Qt
-
- [5. Qt显示类控件](#5. Qt显示类控件)
-
- [Line Edit](#Line Edit)
- [Text Edit](#Text Edit)
- [Combo Box](#Combo Box)
- [Spin Box](#Spin Box)
- QDateTimeEdit
- Dial
- Slider
Qt
5. Qt显示类控件
Line Edit
QLineEdit 用于表示单行输入框。可以输入一段文本,但是不能换行。
属性 |
说明 |
text |
输入框中的文本 |
inputMask |
输入内容格式约束 |
maxLength |
最大长度 |
frame |
是否添加边框 |
echoMode |
显示方式 |
QLineEdit::Normal |
这是默认值,文本框会显示输入的文本 |
QLineEdit::Password |
在这种模式下,输入的字符会被隐藏,通常用星号(*)或等号(=)代替 |
QLineEdit::NoEcho |
在这种模式下,文本框不会显示任何输入的字符 |
cursorPosition |
光标所在位置 |
alignment |
文字对齐方式, 设置水平和垂直方向的对齐 |
dragEnabled |
是否允许拖拽 |
readOnly |
是否是只读的(不允许修改) |
placeHolderText |
当输入框内容为空的时候, 显示什么样的提示信息 |
clearButtonEnabled |
是否会自动显示出 "清除按钮" |
信号 |
说明 |
void cursorPositionChanged(int old, int new) |
当光标位置改变时发出此信号。old参数表示先前的光标位置,new参数表示新的光标位置。 |
void editingFinished() |
当按下返回键或回车键,或者行编辑失去焦点时,发出此信号。这通常表示用户已完成编辑。 |
void returnPressed() |
当按下返回键或回车键时发出此信号。如果设置了验证器,验证通过后才能触发此信号。 |
void selectionChanged() |
当选中的文本改变时,发出此信号。这可以用于检测用户是否选择了不同的文本片段。 |
void textChanged(const QString &text) |
当QLineEdit中的文本改变时,发出此信号。text参数表示新的文本内容。这个信号对代码和用户输入的文本修改都会触发。 |
void textEdited(const QString &text) |
当QLineEdit中的文本通过用户输入(而非代码修改)改变时,发出此信号。text参数表示新的文本内容。这个信号不会由代码对文本的修改触发。 |
-
代码示例:使用 QLineEdit 创建编辑框,并且用户输入信息可以回响。
-
setPlaceholderText():设置默认文字;setEchoMode(QLineEdit:: ):设置文字样式;setInputMask():设置文字格式。
- 连接槽函数,实现输入信息后的回响操作。
- 代码示例:判断两次输入信息是否一致。
- 使用 QString 接收文字并且进行判断。
Text Edit
QTextEdit 表示多行输入框。也是一个富文本 & markdown 编辑器。并且能在内容超出编辑框范围时自动提供滚动条。
属性 |
说明 |
markdown |
输入框内持有的内容。支持 markdown 格式。能够自动的对 markdown 文本进行渲染成 html。 |
html |
输入框内持有的内容。可以支持大部分 html 标签。包括 img 和 table 等。 |
placeHolderText |
输入框为空时提示的内容。 |
readOnly |
是否是只读的。 |
undoRedoEnable |
是否开启 undo /redo 功能。按下 ctrl + z 触发 undo,按下 ctrl + y 触发 redo。 |
autoFormating |
开启自动格式化。 |
tabstopWidth |
按下缩进占多少空间。 |
overwriteMode |
是否开启覆盖写模式。 |
acceptRichText |
是否接收富文本内容。 |
verticalScrollBarPolicy |
垂直方向滚动条的出现策略。 |
Qt::ScrollBarAsNeeded |
根据内容自动决定是否需要滚动条。这是默认值。 |
Qt::ScrollBarAlwaysOff |
总是关闭滚动条。 |
Qt::ScrollBarAlwaysOn |
总是显示滚动条。 |
horizontalScrollBarPolicy |
水平方向滚动条的出现策略。 |
Qt::ScrollBarAsNeeded |
根据内容自动决定是否需要滚动条。这是默认值。 |
Qt::ScrollBarAlwaysOff |
总是关闭滚动条。 |
Qt::ScrollBarAlwaysOn |
总是显示滚动条。 |
信号 |
说明 |
textChanged () |
文本内容改变时触发。 |
selectionChanged () |
选中范围改变时触发。 |
cursorPositionChanged () |
光标移动时触发。 |
undoAvailable (bool) |
可以进行 undo 操作时触发。 |
redoAvailable (bool) |
可以进行 redo 操作时触发。 |
copyAvaiable (bool) |
文本被选中 / 取消选中时触发。 |
- 代码示例:在多行输入框中输入信息,可以显示到 QLabel 中。
- 建立连接关系。
- selectionChanged():是选中改变时触发的信号。
- 输入位置改变时触发cursorPositionChanged()信号。
-
按下ctrl+z触发undoAvailable()。
-
按下ctrl+y触发redoAvailable()。
- 选中文本时触发copyAvailable()。
Combo Box
QComboBox 表示下拉框。
属性 |
说明 |
currentText |
当前选中的文本。 |
currentIndex |
当前选中的条目下标。从 0 开始计算。如果当前没有条目被选中,值为 -1。 |
editable |
是否允许修改。设为 true 时,QComboBox 的行为就非常接近 QLineEdit,也可以设置 validator。 |
iconSize |
下拉框图标(小三角)的大小。 |
maxCount |
最多允许有多少个条目。 |
方法 |
说明 |
addItem (const QString&) |
添加一个条目。 |
currentIndex () |
获取当前条目的下标,从 0 开始计算。如果当前没有条目被选中,值为 -1。 |
currentText () |
获取当前条目的文本内容。 |
信号 |
说明 |
activated (int)、activated (const QString & text) |
当用户选择了一个选项时发出。这个时候相当于用户点开下拉框,并且鼠标划过某个选项,此时还没有确认做出选择。 |
currentIndexChanged (int)、currentIndexChanged (const QString & text) |
当前选项改变时发出。此时用户已经明确地选择了一个选项。用户操作或者通过程序操作都会触发这个信号。 |
editTextChanged (const QString & text) |
当编辑框中的文本改变时发出(editable 为 true 时有效)。 |
-
addItem(QString)可以向 QComboBox 中添加选项。
-
连接槽函数。
Spin Box
使用 QSpinBox 或者 QDoubleSpinBox 表示 "微调框", 它是带有按钮的输入框。可以用来输入整数 / 浮点数。通过点击按钮来修改数值大小。
属性 |
说明 |
value |
存储的数值。 |
singleStep |
每次调整的 "步长"。按下一次按钮数据变化多少。 |
displayInteger |
数字的进制。例如 displayInteger 设为 10,则是按照 10 进制表示。设为 2 则为 2 进制表示。 |
minimum |
最小值。 |
maximum |
最大值。 |
suffix |
后缀。 |
prefix |
前缀。 |
wrapping |
是否允许换行。 |
frame |
是否带边框。 |
alignment |
文字对齐方式。 |
readOnly |
是否允许修改。 |
buttonSymbol |
按钮上的图标。 |
UpDownArrows |
上下箭头形式。 |
PlusMinus |
加减号形式。 |
NoButtons |
没有按钮。 |
accelerated (加速的) |
按下按钮时是否为快速调整模式。 |
correctionMode |
输入有误时如何修正。 |
QAbstractSpinBox::CorrectToPreviousValue |
如果用户输入了一个无效的值(例如,在只能显示正整数的 SpinBox 中输入了负数),那么 SpinBox 会恢复为上一个有效值。例如,如果 SpinBox 的初始值是 1,用户输入了 -1(无效),然后 SpinBox 会恢复为 1。 |
QAbstractSpinBox::CorrectToNearestValue |
如果用户输入了一个无效的值,SpinBox 会恢复为最接近的有效值。例如,如果 SpinBox 的初始值是 1,用户输入了 -1(无效),那么 SpinBox 会恢复为 0。 |
keyboardTrack |
是否开启键盘跟踪。设为 true,每次在输入框输入一个数字,都会触发一次 valueChanged () 和 textChanged () 信号。设为 false,只有在最终按下 enter 或者输入框失去焦点,才会触发 valueChanged () 和 textChanged () 信号。 |
信号 |
说明 |
textChanged (QString) |
微调框的文本发生改变时会触发。参数 QString 带有前缀和后缀。 |
valueChanged (int) |
微调框的文本发生改变时会触发。参数 int,表示当前的数值。 |
- 创建 QSpinBox 微调框。
QDateTimeEdit
使用 QDateTimeEdit 作为时间日期的微调框。
属性 |
说明 |
dateTime |
时间日期的值。形如 2000/1/1 0:00:00。 |
date |
单纯日期的值。形如 2001/1/1。 |
time |
单纯时间的值。形如 0:00:00。 |
displayFormat |
时间日期格式。形如 yyyy/M/d H:mm。y 表示年份。M 表示月份。d 表示日期。H 表示小时。m 表示分钟。s 表示秒。 |
minimumDateTime |
最小时间日期。 |
maximumDateTime |
最大时间日期。 |
Qt::LocalTime |
显示本地时间。 |
Qt::UTC |
显示协调世界时(UTC)。 |
Qt::OffsetFromUTC |
显示相对于 UTC 的偏移量 (时差)。 |
- 创建 QDateTimeEdit 日期微调框。
Dial
使用 QDial 表示一个旋钮。
属性 |
说明 |
value |
持有的数值。 |
minimum |
最小值。 |
maximum |
最大值。 |
singleStep |
按下方向键的时候改变的步长。 |
pageStep |
按下 pageUp/pageDown 的时候改变的步长。 |
sliderPosition |
界面上旋钮显示的初始位置。 |
tracking |
外观是否会跟踪数值变化。默认值为 true。一般不需要修改。 |
wrapping |
是否允许循环调整。即数值如果超过最大值,是否允许回到最小值。(调整过程能否 "套圈")。 |
notchesVisible |
是否显示刻度线。 |
notchTarget |
刻度线之间的相对位置。数字越大,刻度线越稀疏。 |
信号 |
说明 |
valueChanged (int) |
数值改变时触发。 |
rangeChanged (int, int) |
范围变化时触发。 |
- 创建一个旋钮 QDial 。
Slider
使用 QSlider 表示一个滑动条。
属性 |
说明 |
value |
持有的数值。 |
minimum |
最小值。 |
maximum |
最大值。 |
singleStep |
按下方向键的时候改变的步长。 |
pageStep |
按下 pageUp/pageDown 的时候改变的步长。 |
sliderPosition |
滑动条显示的初始位置。 |
tracking |
外观是否会跟踪数值变化。默认值为 true。一般不需要修改。 |
orientation |
滑动条的方向是水平还是垂直。 |
invertedAppearance |
是否要翻转滑动条的方向。 |
tickPosition |
刻度的位置。 |
tickInterval |
刻度的密集程度。 |
信号 |
说明 |
valueChanged (int) |
数值改变时触发。 |
rangeChanged (int, int) |
范围变化时触发。 |
- 创建一个滑动条 QSlider 。