0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

嵌入式Qt-动手编写并运行自己的第1个ARM-Qt程序

码农爱学习 来源:码农爱学习 作者:码农爱学习 2022-06-02 09:06 次阅读

上篇文章介绍了如何搭建在Linux开发板中搭建Qt的运行环境,并测试了Qt自带的例程。

本篇,来介绍如何自己编写一个Qt程序,并将编译结果放到Linux开发板中运行。

1 Windows上编写Qt程序

因为Qt是支持跨平台的,所以我们可以先在Windows平台上编写和查看Qt的运行效果,然后再通过交叉编译,编译出ARM Linux平台的可执行文件,最终放到开发板中查看运行结果。

Windows上需要安装Qt Creator软件来开发Qt程序,该软件的安装过程,和大多数软件的安装过程都差不多,在此不再演示安装过程。

下面介绍如何创建一个Qt工程。

1.1 新建Qt工程

Qt Creator本质也是一个集成开发环境,与Visual Studio之类的创建工程的流程类似,其软件界面如下:

poYBAGKXfviACv21AAEijaCVbAg618.png

创建工程,选择左上角菜单中的“文件”->"新建文件或项目",弹出如下窗口,然后默认选择Qt Widgets Application,然后右下加点击“Choose"按键:

pYYBAGKXfv6ACFgOAABV9vt-L84049.png

出现选择项目工程的存放位置,然后再下一步:

poYBAGKXfwaAejQwAAAkwzfLE7s296.png

这里会用到Visual Studio中的一些功能,默认即可,然后下一步:

pYYBAGKXfwyAXFQ0AAAkcLkzY5E226.png

然后要选择类信息,基类里可选的有QMainWindow、QWidget和QDialog,这里我们选择QWidget。

下面还有一个”创建界面“的勾选框,那个是用来通过图形化的方式设计显示界面,本篇暂用不到,先取消勾选,然后点下一步

poYBAGKXfxOALLBTAAA02acWN-A919.png

到这里,Qt工程就创建好了,点完成:

poYBAGKXfxiARD60AAAmzaE7fls127.png

创建的Qt工程如下,主要包含4个文件:

clock.pro:Qt工程的配置文件

main.cpp:主程序

widget.cpp:窗口程序

widget.h:窗口程序的头文件

pYYBAGKXfx2AA02ZAAD1xORuFww084.png

1.2 代码编写(时钟程序)

Widget的构造函数

Widget::Widget(QWidget *parent)
    : QWidget(parent)
{
    QTimer *timer = new QTimer(this);
    connect(timer, SIGNAL(timeout()), this, SLOT(update()));
    timer->start(1000);

    setWindowTitle(tr("Clock"));
    setMinimumSize(200, 200); //设置最小尺寸
}

首先创建了一个Qt的定时器,设置超时时间为1s(1000ms),超时时间到,更新表盘的显示。

第2行是Qt中最常用的信号和槽机制:

connect(timer, SIGNAL(timeout()), this, SLOT(update()));

信号和槽,简单的立即,就是信号SIGNAL出现后(1s定时器超时),触发槽SLOT函数执行(更新表盘的显示)

界面设计

时钟程序中的表盘,表针等,都是通过画图的方式实现的,具体的代码如下:

void Widget::paintEvent(QPaintEvent *event)
{
    int side = qMin(width(), height());
    QTime time = QTime::currentTime();

    QPainter painter(this);
    painter.setRenderHint(QPainter::Antialiasing);
    painter.translate(width()/2, height()/2); //画图的基准位置
    painter.scale(side/200.0, side/200.0); //随窗口尺寸自动缩放

    //表盘
    for (int i=0; i;>

第2句:

QTime time = QTime::currentTime();

是来获取系统的当前时间。

1.3 编译运行

现在Windows平台中编译运行,查看效果:

pYYBAGKXfyaAWkg1AAHFzNAdmQs888.png

该时钟是可以根据窗口大小的变化,自动进行放到或缩小显示的:

pYYBAGKXfyuACZ49AABJoS-M_wo902.png

2 Ubuntu中交叉编译Qt

Windows中测试通过后,就需要编译出能够在ARM平台运行的可执行程序了,这里需要在Ubuntu中进行编译。

2.1 复制源文件到Ubuntu中

将Windows中的QT工程源码,复制到Ubuntu中,注意.user文件是不需要的,这个是Windows平台的编译配置。

poYBAGKXfzGAbDjRAABQvuWe9qk049.png

复制到Ubuntu中的合适位置:

pYYBAGKXfziAX0eTAAAzxIo-gRY421.png

2.2 交叉编译

编译ARM平台的Qt程序,需要使用ARM平台的编译工具链。

上篇文章,在搭建Qt环境,编译Qt源码时,已经生成了ARM平台的Qt编译工具链,其位置是在上篇文章介绍的make install那一步的安装位置,我的是在”/home/xxpcb/myTest/imx6ull/otherlib/qt/qt-everywhere-src-5.12.9/arm-qt/“,这里需要先用到它的qmake工具先自动生成Makefile文件,再通过make指令进行编译。

首先的使用qmake生成Makefile,进入程序源码目录,执行qmake指令:

/home/xxpcb/myTest/imx6ull/otherlib/qt/qt-everywhere-src-5.12.9/arm-qt/bin/qmake

成功执行之后,就可以看到自动生成的Makefile文件:

pYYBAGKXfz-AHhnJAACvLQXs1SM877.png

然后执行make指令进行编译:

make
poYBAGKXf0aAUiwlAAHXhcKuUfU908.png

编译完可以看到可执行文件clock。

我们可以再使用file命令查看该可执行文件的平台信息:

file clock
poYBAGKXf02AalYqAAHj4jcziv8433.png

可以看到该可执行文件是ARM平台的。

3 Linux开发板中运行Qt程序

3.1 复制可执行文件到开发板中

此次测试,仍然使用的是网络位置挂载根文件系统的方式,通过如下指令将可执行文件复制到根文件系统中(开发板中):

sudo cp clock ~/myTest/nfs/rootfs/myProj/qt/mytest/
pYYBAGKXf1WALW_FAAHLQaP6e1U234.png

3.2 查看开发板中的运行效果

然后就可以在开发板中执行该程序,查看效果了:

./clock

运行效果如下:

pYYBAGKXf1uAOfwrAAJK_7y7SJc130.png

由于板子的网络时间还不能正确获取,这里显示的时间其实是不对的,不过表针仍然会1秒1秒的走动。

4 总结

本篇详细介绍了如何自己编写一个Qt程序,如何通过交叉编译,最终放到开发板中执行的过程。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • ARM
    ARM
    +关注

    关注

    134

    文章

    8651

    浏览量

    361777
  • 嵌入式
    +关注

    关注

    4981

    文章

    18281

    浏览量

    288407
  • Linux
    +关注

    关注

    87

    文章

    10990

    浏览量

    206733
  • 开发板
    +关注

    关注

    25

    文章

    4429

    浏览量

    93991
  • Qt
    Qt
    +关注

    关注

    1

    文章

    299

    浏览量

    37338
收藏 人收藏

    评论

    相关推荐

    飞凌嵌入式ElfBoard ELF 1板卡-卸载ubuntu上安装的QT Creator的方法

    进入QT安装的目录,例如安装的QT版本是Qt5.6.2:elf@ubuntu:~$ cd /opt/Qt5.6.2/运行命令:elf@ubu
    发表于 04-10 10:15

    3562-Qt工程编译说明

    Qt 环境、交叉编译 工具链等。当用户使用 Qt Creator 工具和 X86 端 Qt 环境编写并编译 Qt 工程后,生成的
    的头像 发表于 03-05 09:19 117次阅读
    3562-<b class='flag-5'>Qt</b>工程编译说明

    如何用RK3588编写应用程序

    由于笔者平时的嵌入式开发工作,主要是集中在嵌入式Linux和Qt应用开发方向,因此,本篇文章我们尝试参考飞凌官方提供的嵌入式Linux+Qt
    发表于 12-19 13:24

    嵌入式学习——ElfBoard ELF1板卡 编译运行qt应用的方法

    :~# chmod 777 audio (3)设置QT环境变量 root@ELF1:~# export DISPLAY=:0.0 (4)运行audio应用程序 root@ELF
    发表于 11-15 11:04

    基于嵌入式Linux与QT的汽车虚拟仪表设计

    电子发烧友网站提供《基于嵌入式Linux与QT的汽车虚拟仪表设计.pdf》资料免费下载
    发表于 10-26 14:38 0次下载
    基于<b class='flag-5'>嵌入式</b>Linux与<b class='flag-5'>QT</b>的汽车虚拟仪表设计

    迅为RK3568开发板QT学习手册

    2.2.4 Ubuntu系统编写运行QT工程 2.3 QtCreator简单使用 2.3.1 主界面介绍 2.3.2 常用快捷键 3章
    发表于 10-25 10:29

    基于QT-E的嵌入式Linux系统的软键盘实现

    电子发烧友网站提供《基于QT-E的嵌入式Linux系统的软键盘实现.pdf》资料免费下载
    发表于 10-24 10:42 0次下载
    基于<b class='flag-5'>QT</b>-E的<b class='flag-5'>嵌入式</b>Linux系统的软键盘实现

    基于Qt嵌入式交通信号机GUI设计

    电子发烧友网站提供《基于Qt嵌入式交通信号机GUI设计.pdf》资料免费下载
    发表于 10-13 10:14 0次下载
    基于<b class='flag-5'>Qt</b>的<b class='flag-5'>嵌入式</b>交通信号机GUI设计

    Qt For OpenHarmony

    、OS X、iOS、Windows、VxWorks、QNX等,涵盖从嵌入式平台、移动平台及PC桌面,基于Qt框架典型的桌面应用,从娱乐到工业软件都有所涉及,如暴雪的战网客户端、WPS、VirtualBox
    发表于 09-15 15:39

    【米尔-全志T113-S3开发板- 极致双核A7国产处理器-试用体验】从零开始在开发板上跑通QT程序

    时要修改成自己的路径。 如果在终端下打arm-linux-gnueabi-gcc -v能够正确获取编译链的相关版本信息,你也可以不指定绝对路径。 接着我们要在当前qt源码目录下写一
    发表于 09-07 21:48

    【米尔MYD-JX8MMA7开发板-ARM+FPGA架构试用体验】十一、QT-HMI V2.0系统

    编译环境,旨在帮助用户更好更快捷的通过QT5来开发自己的产品。其中包括嵌入式QT5运行环境搭建,qmake编译环境的搭建,
    发表于 05-23 09:34

    嵌入式Qt-表格使用测试

    本篇介绍了Qt中QTable Widget这个表格组件的使用,后续可增加SQLite数据库功能,利用表格可以直观的展示出嵌入式设备的数据库中的数据信息。
    的头像 发表于 05-14 12:27 1154次阅读
    <b class='flag-5'>嵌入式</b><b class='flag-5'>Qt-</b>表格使用测试

    基于QT的简单的上位机

    一、前言大家好,我是ZhengN,本次来教大家编写一个基于QT的简单的上位机。学习一个新的东西我们都从最基础地实例开始,比如学习C语言我们会从编写一个hello程序开始、学习
    发表于 05-08 10:57 16次下载
    基于<b class='flag-5'>QT</b>的简单的上位机

    QT|编写一个简单的上位机

    QT | 编写一个简单的上位机 时间 :2023-03-19文章目录QT | 编写一个简单的上位机 参考及资料: 1.打开`QT Creat
    发表于 05-08 10:12 2次下载
    <b class='flag-5'>QT</b>|<b class='flag-5'>编写</b>一个简单的上位机

    QTQT上位机串口编程

    版本:QT Creater 4.80硬件:stm32 + 串口转ttl模块 默认安装好QT了 1.新建工程 选择Qt Widgets 然后下一步自己填一个项目名字和项目路径我只安装了这
    发表于 05-08 10:02 19次下载
    <b class='flag-5'>QT</b>篇<b class='flag-5'>QT</b>上位机串口编程