Qt —— 创建 hello world

文章目录

  • [1. 图形化方式](#1. 图形化方式)
  • [2. 纯代码方式](#2. 纯代码方式)

1. 图形化方式

通过图形化方式 在界面上创建出一个控件 显示 hello world


点击 widget.ui 并打开 调用 Qt designer 这个图形化工具 完成窗口界面的编辑


在左侧 Display Wigets 中 找到 label 控件 并将其拖拽到右侧界面上


可以通过 拖动边框 来放大 label


通过双击 可以进行 编辑的状态 然后输入 Hello World
就可以显示出 Hello World 了


此时就存在了一个 label 控件
Qt designer 的右上角 通过树形结构 显示出了当前界面上都有那些控件


此时在 widget.ui中 就会 多出一句 Hello World


在界面上拖拽 一个 QLabel 控件 ui文件的xml中就会多出来这一段代码
进一步 的 qmake 就会编译项目的时候 基于这个内容 生成一段C++代码
通过C++代码构建出界面内容


2. 纯代码方式

点击 widget.cpp 并打开


其中包含 一个 Widget 的构造函数
一般通过代码来构造界面的时候 通常会把构造界面的代码 放到 Widget 的构造函数中

Qt中 每个类都有一个对应同名的头文件 所以在 widget.cpp 中 使用 #include < QLabel >

label 表示 界面上一个用来显示内容的字符串统计


使用C++中的new 去创建一个 Qlabel类的对象
并在构造函数中添加参数 this 即 给当前的label对象 指定一个 父对象
在Qt中存在 对象数的概念 本质为 一个 n叉树 即有n个子节点 并且只有一个父节点
所以当指定父对象时 就知道在树的那个位置


this 指向的是 当前构造函数所对应的对象 即 main.cpp 中的 widget对象

创建的 label 对象 父元素 为 widget 对象


调用 label对象中的 setText 函数 表示 设置控件中 要显示的文本是啥
其中参数为 Qstring

Qt 为了让自己的开发能够更顺畅 就自己发明了一套轮子
搞了一系列的基础类 来支持 Qt的开发
包括但不限于 字符串 QString 动态数组 QVector 链表 QList


在Qstring 中提供 C 风格字符串作为参数的构造函数
不显式构造 QString 上述代码中 C风格字符串也会隐式构造 Qstring对象

QString对应的头文件 已经被很多 Qt内置的其他类间接包含了 因此一般不需要显式包含QString头文件


此时就显示出了 hello world

相关推荐
春日见12 分钟前
车辆动力学:前后轮车轴
java·开发语言·驱动开发·docker·计算机外设
锐意无限16 分钟前
Swift 扩展归纳--- UIView
开发语言·ios·swift
低代码布道师16 分钟前
Next.js 16 全栈实战(一):从零打造“教培管家”系统——环境与脚手架搭建
开发语言·javascript·ecmascript
念何架构之路34 分钟前
Go进阶之panic
开发语言·后端·golang
亓才孓37 分钟前
[Properties]写配置文件前,必须初始化Properties(引用变量没执行有效对象,调用方法会报空指针错误)
开发语言·python
傻乐u兔41 分钟前
C语言进阶————指针3
c语言·开发语言
两点王爷1 小时前
Java基础面试题——【Java语言特性】
java·开发语言
Swift社区1 小时前
Gunicorn 与 Uvicorn 部署 Python 后端详解
开发语言·python·gunicorn
码农阿豪1 小时前
Python Flask应用中文件处理与异常处理的实践指南
开发语言·python·flask
岁岁种桃花儿1 小时前
CentOS7 彻底卸载所有JDK/JRE + 重新安装JDK8(实操完整版,解决kafka/jps报错)
java·开发语言·kafka