1 Star 0 Fork 24

艾特何 / Qt GUI从简单到复杂

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README

从零开始学习Qt GUI编程

作者 将狼才鲸
创建日期 2021-11-23
  • 注:所有的代码都是参考的网上的资料,有贴上源地址
  • 编译环境1(002_GuiDisplay/下001~012cases期间):
    Win10 + Qt6.2.1(MSVC 2019 64-bit) + Qt Creator5.0.3
  • 编译环境2(004_MultiMedia_VideoAudio/下002~003cases期间):
    Win10 + Qt5.15.2(MSVC 2019 64-bit) + Qt Creator5.0.3
  • 编译环境3(004_MultiMedia_VideoAudio/下001、004~00xcases期间,005_Qt_with_C_language/及以后所有):
    Win10 + Qt6.2.3(MSVC 2019 64-bit) + Qt Creator7.0.0

一、目录结构

$ tree
.
|-- backup							// 待删的一些旧文件
|-- projects						// 已弃用,对同一份代码有makefile、qt、visual studio三个工程
|   |-- 001_HelloWorld_makefile
|   |-- 001_HelloWorld_qt
|   `-- 001_HelloWorld_vs
|-- readme.md
`-- source							// 源码
    |-- 001_HelloWorld				/* Hello world */
    |   `-- hello_world.c
    |-- 002_GuiDisplay				// 演示GUI
    |   |-- 001_Window				/* 主窗口 + HelloWorld */
    |   |   |-- 001_Window.pro		// Qt工程文件
    |   |   |-- documents			// 该Demo存放文档路径
    |   |   |   |-- 001_Window.md	// 该Demo说明文档
    |   |   |   `-- 001_Window.png	// 该Demo演示效果的图片
    |   |   |-- main.cpp			// 主程序,程序入口
    |   |   |-- mainwindow.cpp		// 主窗口显示逻辑
    |   |   |-- mainwindow.h		// 主窗口头文件
    |   |   `-- mainwindow.ui		// 主窗口布局
    |   |-- 002_Dialog				/* 对话框 */
    |   |-- 003_LoginDialog			/* 登录功能 */
    |   |-- 004_menu_logo			/* 添加菜单栏和图标 */
    |   |-- 005_icon_and_layout		/* 完整菜单栏和居中动态布局 */
    |   |-- 006_text_file_edit		/* 记事本编辑功能 */
    |   |-- 007_text_find			/* 文本查找功能 */
    |   |-- 008_keyboard_mouse		/* 键盘和鼠标功能 */
    |   |-- 009_2D_painter			/* 2D绘图 */
    |   |-- 010_image				/* 图片绘制 */
    |   |-- 011_3D_painter          /* 3D三维绘制 */
    |   |-- 012_media_play			/* Qt老版本的视频播放 */
    |   |   xxx_xxx
    |   |   ……
    |   `-- documents
    |       `-- GuiDisplay.md
    |-- 003_QtExamples_Qt-6.2.3		// Qt官方的各种经典示例
    |   |-- 001_xxx
    |   `-- documents
    |       `-- QtExamples_Qt-6.2.3.md
    |-- 004_MultiMedia_VideoAudio	// 演示如何使用音视频播放与录制
    |   |-- 001_qt6.2.3_multimedia  /* Qt6.2.3提供的完整播放器代码 */
    |   |-- 002_pcm_audio_play      /* PCM音频播放 */
    |   |-- 003_yuv_video_play      /* YUV视频播放 */
    |   |-- 004_pcm_input_save_file /* 从麦克风录制pcm文件 */
    |   |-- 005_yuv_input_save_file /* 从摄像头录制yuv文件 */
    |   `-- documents
    |       `-- MultiMedia_VideoAudio.md
    |-- 005_Qt_with_C_language		/* C++与C混合编程 */
    |-- 006_AudioVideo_Codec   		/* Qt中ffmpeg音视频编解码 */
    `-- 007_Embeded_Player			/* 自行实现音视频编解码与播放器(嵌入式仿真用) */
        `-- documents

二、Qt介绍(针对没接触过Qt的人)

二、GUI Demo介绍

  • qt_gui_simple2complex\source\002_GuiDisplay\下的GUI部分:

001_Window:创建一个主窗口

步骤:
第1篇 Qt5基础(一)Qt开发环境的搭建和hello world
效果:
image


002_Dialog:在主窗口之外创建一个对话框

步骤:
第2篇 Qt5基础(二)编写Qt多窗口程序
效果:
image


003_LoginDialog:登录功能

正确的用户名:demo,正确的密码:demo123456
步骤:
第3篇 Qt5基础(三)Qt登录对话框
效果:
image


004_menu_logo:添加菜单栏和图标


005_icon_and_layout:完整菜单栏和居中动态布局


006_text_file_edit:记事本编辑功能

image

007_text_find:文本查找功能


008_keyboard_mouse.md:键盘和鼠标功能


009_2D_painter.md:2D绘图


010_image.md:图片绘制


011_3D_painter:3D绘制


012_media_play:视频播放

image

三、多媒体Demo介绍

  • qt_gui_simple2complex\source\004_MultiMedia_VideoAudio\下的多媒体部分:

001_qt6.2.3_multimedia:音视频多媒体播放


002_pcm_audio_play:PCM音频播放


003_yuv_video_play:YUV视频播放


004_pcm_input_save_file:从麦克风保存PCM音频文件

  • 步骤:
    详见源码中文档和注释

  • 注意事项:
    使用Qt6.2.3编译,实现方式和Qt5不同


005_yuv_input_save_file:从摄像头保存YUV视频文件

  • 步骤:
    详见源码中文档和注释

  • 注意事项:
    使用Qt6.2.3编译,实现方式和Qt5不同


006_qt6-2-3_pcm_play:Qt6.2.3 PCM音频播放

  • 步骤:
    详见源码中文档和注释

  • 注意事项:
    使用Qt6.2.3编译,实现方式和Qt5不同


四、Qt官方Demo介绍

  • qt_gui_simple2complex\source\003_QtExamples_Qt-6.2.3\下的Demo部分:

  • Qt官方Demo的整体介绍详见 子文档QtExamples_Qt-6.2.3.md


001_animation_动画_缓冲曲线.gif

image


002_Screenshot_截屏.png

image


003_Systray_修改系统托盘.gif

image


004_ClassWizart_翻页.gif

image


005_Extension_扩展列表.gif

image


006_FindFiles_打开文件夹_查找文件.gif

image


007_LicenseWizard_注册向导.gif

image


008_StandardDialogs_常用对话框.gif

image


009_TabDialog_列表对话框.gif

image


010_TrivialWizard_简单向导.gif

image


011_DraggableIcons_拖动图标.gif

image


012_DraggableText_拖动文本.gif

image


013_DropSite.png

image


014_FridgeMagnets_拖动贴靠.gif

image


015_Puzzle_拼图游戏.gif

image


016_BlurPicker_模糊选择器.gif

image


017_FadeMessage_界面渐变.gif

image


018_Gallery_综合界面和主题.gif

image


019_ImageGestures_打开图片.gif

image


  • 前面已列出的官方用例还不到1/5,Qt\Examples\Qt-6.2.3\下的Demo还有非常多, 建议先了解有哪些类型的Demo,需要用到相关功能的时候先去找官方示例,后续的示例效果图省略。

  • 官方所有示例的介绍有文字简介和示意图地址(英文版,可以用浏览器翻译成中文查阅,先看Qt Widgets章节,主页只有文字介绍,点开具体示例可以看到演示图片和使用说明): All Qt Examples

  • 其它的演示效果图参考网址:
    Qt Examples Qt实例汇总
    Qt Examples


五、Qt C++与C语言混合编程


六、Qt ffmpeg音视频编解码


七、用于嵌入式仿真用的音视频播放器

  • qt_gui_simple2complex\source\007_Embeded_Player\下的Demo部分:
  • 只使用Qt的pcm、yuv输入输出和GUI界面显示,音视频编解码库使用ffmpeg,其它封装解封装、音视频同步、播放器API部分都使用C语言自行实现,非常容易就移植到有硬件视频编解码器、硬件音频编解码器、display显示模块的嵌入式开发板。
  • 查看项目说明文档:qt_gui_simple2complex/ source / 007_Embeded_Player

空文件

简介

注重于GUI的基础元素,用Qt从最简单的主界面到很复杂的综合页面进行演示。 展开 收起
取消

发行版

暂无发行版

贡献者

全部

近期动态

加载更多
不能加载更多了
1
https://gitee.com/at_He/qt_gui_simple2complex.git
git@gitee.com:at_He/qt_gui_simple2complex.git
at_He
qt_gui_simple2complex
Qt GUI从简单到复杂
develop

搜索帮助