1. 编辑框
这里以实现 hello world 为例
即 使用 编辑框 完成 Hello World
图形化方式
单行编辑框 QLineEdit
多行编辑框 QTextEdit
data:image/s3,"s3://crabby-images/861ae/861aeaa0e10a23fb536d4f0e0d23073945aa3d62" alt=""
点击 widget.ui 并打开 调用 Qt designer 这个图形化工具 完成窗口界面的编辑
data:image/s3,"s3://crabby-images/56154/561542c8db7deedf67e1ec0d32674266b876a05f" alt=""
在 Input Widgets 下 找到 Line Edit
data:image/s3,"s3://crabby-images/15940/159401d7bd7374145ddf76d8e560bf880aaa8520" alt=""
将 Line Edit 拖拽 到 右侧的框中
data:image/s3,"s3://crabby-images/1ccad/1ccadcd4ec3bdf7d37b34bea9c9b3e06375e53cd" alt=""
在空白处 输入 hello world
data:image/s3,"s3://crabby-images/558ef/558efc1271d119226d120c53ab5eac0079bb7de9" alt=""
也可以通过右侧的属性 编辑区进行修改
text 表示 编辑框中的文本
data:image/s3,"s3://crabby-images/59c45/59c4592ad4d8ba35adfd91fdb6df994b02865ea9" alt=""
若在text 对应的编辑框中进行修改 则 对应的白色框中内容也会被修改
data:image/s3,"s3://crabby-images/655a7/655a7f45c1c8225f16499f07d46d4147c8178fa0" alt=""
同时 点击运行后 生成的文本框 也是可以编辑的
纯代码方式
data:image/s3,"s3://crabby-images/55637/55637b6b6825b874d4bdd462db54e0b17b5432c1" alt=""
在 widget.cpp文件中 先将头文件 #include 加上
再new 一个对象 edit
data:image/s3,"s3://crabby-images/e9ab1/e9ab1c1fe771fd8d5bc43c548c18101eb5b47a47" alt=""
this指向的父对象 是 widget 对象 (与前面QLabel用法类似)
data:image/s3,"s3://crabby-images/83850/83850a2d2304c3130a1a4c191cced2ae7de804a9" alt=""
运行程序后 发现当前文本框 同样是可以编辑的
2. 按钮
这里以实现 hello world 为例
即 使用 按钮 完成 Hello World
图形化方式
data:image/s3,"s3://crabby-images/4d180/4d180fd739f0a65c117929b5189f5f05d302d3a0" alt=""
在 Buttons 中 存在 一个 Push Button
Push Button 表示 普通按钮
data:image/s3,"s3://crabby-images/d9ffa/d9ffa19c43742c2f3aa6556f46103462f056b5c1" alt=""
将 Push Button 拖拽到 右侧框中 并输入 hello world
data:image/s3,"s3://crabby-images/fb145/fb145ca757362fc54e862c82e1ab24424397f2e6" alt=""
运行后 生成文本框 发现框中的 hello world 按钮 可以点击
但是发现点击按钮 并没有反应
就要引入 Qt中的 信号槽 机制 (简单演示使用方式 后续会详细介绍)
本质为 给按钮的点击操作 关联上一个处理函数 即当用户点击的时候 会执行这个处理函数
data:image/s3,"s3://crabby-images/3090a/3090aadd9884aa3e84193e71b6ff74d395955289" alt=""
在 Qt designer 中 创建 一个 控件( push Button) 时 就会给 该控件分配一个objectName 的属性
本这个属性的值 要求在界面上是唯一的 (不能和别人重复)
qmake 在预处理 .ui文件时 就会根据 这里的 objectName 生成对应的 C++代码
C++代码中该 PushButton 对象的变量名字 就是这里的 objectName
data:image/s3,"s3://crabby-images/480e3/480e398ea89e07d1106bccd1dcd2d857228fc8cd" alt=""
给按钮添加 点击处理操作
connect 是 QObject 这个类 提供的静态函数
connect 函数 的作用为 连接信号 和 槽
第一个参数 表示 信号是谁发的 ui->pushButton 就可以访问到 form file (ui 文件) 中创建的控件pushButton
第二个参数 为 函数指针 &QPushButton::clicked 表示 点击按钮时 会触发这样的信号
第三个参数 那个对象的槽函数 this 指向父对象 即 widget对象的槽函数
data:image/s3,"s3://crabby-images/b62fc/b62fc1c5619f019d6fa2fb5b810b7129098000ad" alt=""
connect 函数的 第四个参数 函数指针 指定具体处理的函数 &Widget::hanleClick (自己写的)
若当前按钮为 hello world 则切换为 hello qt
若当前按钮为 hello qt 则切换为 hello world
当点击 ui->pushButton 时 会自动触发 &QPushButton::clicked 信号 由 widget对象处理信号
具体按照 &Widget::hanleClick(自己写的) 处理信号
data:image/s3,"s3://crabby-images/064cc/064cc39bf967ae36d8181538d19156882b9f3143" alt=""
当运行程序时 按钮为 hello world 当点击按钮后 就会变成 hello qt