Qt交叉编译工具建立 中篇

移动开发
本文介绍了Qt交叉编译工具建立,主要介绍了Qt/Embedded 的交叉编译,建立本机Qtopia 虚拟平台,其他内容想要了解请看本文指引。先来看本篇内容。

继续上面的内容继续讲 Qt交叉编译工具建立 上篇 ,主要介绍了Qt/Embedded 的交叉编译,建立本机Qtopia 虚拟平台这两个方面介绍的!

一、Qt/Embedded的交叉编译
 
   要将我们写好的程序发布到开发板上,我们需要对Qt/Embedded 重新编译,与前面在宿主机上编译类似,步骤如下:

1. Build Qt/Embedded

  1. tar –xzvf qt-embedded-2.3.10-free.tar.gz  
  2. mv  qt-2.3.10  
  3. qt-2.3.10-target  
  4. export TMAKEDIR=$PWD/tmake-1.13  
  5. export QT2DIR=$PWD/qt-2.3.2  
  6. export QTEDIR=$PWD/qt-2.3.10-target  
  7. cd $QTEDIR  
  8. export TMAKEPATH=$TMAKEDIR/lib/qws/linux-arm-g++  
  9. export QTDIR=$QTEDIR  
  10. export PATH=$QTDIR/bin:$PATH  
  11. export LD_LIBRARY_PATH=$QTDIR/lib:$LD_LIBRARY_PATH  
  12. make  clean  
  13. ./configure -xplatform linux-arm-g++ -no-xft -no-qvfb -depths 4,8,16,32  
  14. make 

这步完成后,我们会在/$QTEDIR/lib/目录下面看到libqte.so libqte.so.2 libqte.so.2.3 libqte.so.2.3.10 这四个文件,我们可以使用file 命令来查看这个库文件是否是我们需要的在开发板上跑的库。

  1. file libqte.so.2.3.10  
  2. libqte.so.2.3.10: ELF 32-bit LSB shared object, ARM, version 1 (ARM), stripped 

有了这个库以后我们就可以把它拷贝到我们的开发板中相应的库目录下面,这里我们选择了开发板上的/usr/lib 目录,将/$QTEDIR/lib/下的libqte.so*复制到/usr/lib 目录下。

首先要建立宿主机和开发板的通讯,假设本机的ip 地址为192.168.0.56 并且/root/share 为共享文件夹。

  1. cp –arf /$QTEDIR/lib/libqte.so*  /root/share  
  2. 启动minicom  
  3. mount –t nfs –o nolock 192.168.0.56:/root/share /mnt/nfs将文件复制到开发板上  
  4. cp –arf /mnt/nfs/libqte.so* /usr/lib 

 2. 修改tmake 配置文件

  1. vi $ TMAKEDIR/lib/qws/linux-arm-g++/tmake.conf  
  2. 将其中“TMAKE_LINKarm-linux-gcc”  
  3. TMAKE_LINK_SHLIBarm-linux-gcc”  
  4. 修改为:“TMAKE_LINKarm-linux-g++”  
  5. TMAKE_LINK_SHLIBarm-linux-g++” 

 3.生成可执行文件
 
 这里我们采用了Qt/Embedded自带的一个demo,它在/$QTEDIR/examples/progressbar目录下,这个目录包括下面几个文件: main.cpp、Makefile.in 、progressbar.h 、

Makefile、progressbar.cpp、progressbar.pro,如果已经有了progressbar 的执行文件,可以使用make clean删除。

  1. progen –t app.t –o progressbar.pro  
  2. echo $TMAKEPATH 

查看返回的结果的结尾字符是否是“……/qws/linux-arm-g++”,如果不是的话需要在命令行中重新设置TMAKEPATH

export TMAKEPATH=/tmake 的安装路径(如$TMAKEDIR)/lib/qws/linux-arm-g++

此外还要使QTDIR指向Qt/Embedded 的安装路径,如:

export QTDIR=$QTEDIR 或者直接指定路径

  1. export QTDIR=……/qt-2.3.10-target 

完成了上面的环境变量的设置,并用echo 命令检查无误以后,就可以使用tmake 工具来生成我们需要的makefile 文件,在命令行中输入如下命令:

  1. tmake –o makefile progressbar.pro  
  2. make 

如果没出现错误的话就可以在当前目录下找到progressbar这个可执行文件,它就是在我们开发板上的相应目录中运行“./progressbar -qws”就可以运行程序了。
 
 注: (1)如果执行命令

  1. [/mnt/nfs]./progressbar -qws  
  2. ./progressbar: error while loading shared libraries: libstdc++.so.6: cannot open shared object file: No such file or direy 

我的解决办法是从编译器目录下查找,并拷贝到开发板/usr/lib/中

  
即拷贝/usr/local/arm/3.4.1/arm-linux/lib/libstdc++.so*  到开发板/usr/lib/中

(2).[/mnt/nfs]./progressbar –qws

  1. /progressbar: error while loading shared libraries: libgcc_s.so.1: cannot open shared object file: No such fy 

方法同上

二、建立本机Qtopia 虚拟平台
 
软件:Redhat Linux9.0 for PC + minicom + Embeded Linux for 2410

  1. tmake-1.13.tar.gz qtopia-free-source-2.1.1.tar.bz2 qt-embedded-2.3.10-free.tar.gz qt-x11-2.3.2.tar.gz 

将本次实验所需的四个文件拷贝到/root/qtopia 目录下,我们以下的实验都是在这个目录下进行的。

宿主机上建立虚拟的Qtopia 环境需要以下几个步骤:

1. 解压缩安装文件:

  1. tar jxvf qtopia-free-source-2.1.1.tar.bz2  
  2.  mv qtopia-2.1.1  qtopia-2.1.1-target  
  3.  tar xzf tmake-1.13.tar.gz  
  4.  tar xzf qt-x11-2.3.2.tar.gz  
  5.  tar xzf qt-embedded-2.3.10-free.tar.gz  
  6.  mv qt-2.3.10  qt-2.3.10-target  
  7.  export QPEDIR=$PWD/qtopia-2.1.1-target  
  8.  export TMAKEDIR=$PWD/tmake-1.13  
  9. export QT2DIR=$PWD/qt-2.3.2  
  10.  export QTEDIR=$PWD/qt-2.3.10-target 

 2. Build Qt/X11: 

  1. cd $QT2DIR  
  2. export TMAKEPATH=$TMAKEDIR/lib/linux-g++  
  3. export QTDIR=$QT2DIR  
  4. export PATH=$QTDIR/bin:$PATH  
  5. export LD_LIBRARY_PATH=$QTDIR/lib:$LD_LIBRARY_PATH  
  6. ./configure -no-xft  
  7. make  
  8. mkdir $QTEDIR/bin  
  9. cp bin/uic $QTEDIR/bin/ 

3. Build Qvfb:

  1. export TMAKEPATH=$TMAKEDIR/lib/linux-g++  
  2. export QTDIR=$QT2DIR  
  3. export PATH=$QTDIR/bin:$PATH:$TMAKEDIR/bin  
  4. export LD_LIBRARY_PATH=$QTDIR/lib:$LD_LIBRARY_PATH  
  5. cd $QTEDIR/tools/qvfb  
  6. tmake -o Makefile qvfb.pro  
  7. make  
  8. mv qvfb $QTEDIR/bin/ 

4.Build libqte:

  1. cd $QTEDIR  
  2. export TMAKEPATH=$TMAKEDIR/lib/qws/linux-x86-g++  
  3. export QTDIR=$QTEDIR  
  4. export PATH=$QTDIR/bin:$PATH  
  5. export LD_LIBRARY_PATH=$QTDIR/lib:$LD_LIBRARY_PATH  
  6. cp -f $QPEDIR/src/qt/qconfig-qpe.h src/tools/  
  7. ./configure -system-jpeg -no-xft -qconfig qpe -qvfb -depths 4,8,16,32  
  8. make sub-src 

5.Build Qtopia:

  1. cd $QPEDIR  
  2. export QTDIR=$QTEDIR  
  3. export PATH=$QPEDIR/bin:$PATH  
  4. export  
  5. LD_LIBRARY_PATH=$QPEDIR/lib:$LD_LIBRARY_PATH  
  6. ./configure  
  7. make 

和前面编译Qt/Embedded 的基本步骤一样,还可以参考“./configure --help”,来进行选择。为了保证qvfb 能够正确显示qtopia 的结果,我们必须保证环境变量设置正确,我们可以通过“env”命令来检查下面的环境变量,也可以用下面的方法来检查。

  1.  echo $QPEDIR  
  2. /root/qtopia/qtopia-free-2.1.1/  
  3. echo $QTDIR  
  4. /root/qtopia/qt-2.3.10  
  5. echo $LD_LIBRARY_PATH  
  6. /root/qtopia/qtopia-free-2.1.1/lib:/root/qtopia/qt-2.3.10/lib  
  7. echo $PATH  
  8. /root/qtopia/qt-2.3.10/bin:/usr/kerberos/sbin:/usr/kerberos/bin:/usr/local 
  9. /sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/X11R6/bin:/root/bin 

出现上面的结果就可以正常的显示Virtual framebuffer,我们可以通过下面的命令在Virtual framebuffer 中实现Qtopia。

  1. cd $QPEDIR/bin  
  2. qvfb &  
  3. sleep 10  
  4. ./qpe.sh 

 小结:关于Qt交叉编译工具建立的内容介绍完了,想要深入了解的话,请继续关注 Qt交叉编译工具建立 下篇 ,***希望本文对你有所帮助!

责任编辑:zhaolei 来源: 互联网
相关推荐

2011-06-23 16:24:21

Qt Embedded 交叉编译

2011-06-23 18:16:59

Qt Qtopia

2011-06-28 13:47:37

Embedded QT ARM

2011-07-04 15:13:31

QT MPlayer 移植

2011-06-13 14:49:57

Qt Designer

2010-02-02 15:13:42

Linux ARM

2011-06-17 17:01:22

Qt Eclipse Windows

2011-06-09 16:47:56

Qt 嵌入式

2011-06-30 10:22:48

QT Graphics View

2021-05-13 09:45:53

GolangLinux交叉编译

2011-06-27 14:31:29

Qt 数据库 SQL语句

2011-06-21 14:34:30

Qt Designer mini2440

2010-03-02 10:55:47

Linux SkyEy

2010-02-24 16:49:24

Fedora SkyE

2011-07-05 16:31:17

Qtopia 交叉编译

2011-06-08 15:27:24

QT QT 4.5 编译

2011-06-09 15:18:07

QT 编译

2011-06-21 16:51:21

Qt 静态 编译

2011-07-04 15:48:57

Qt 桌面

2011-06-22 14:38:09

QT 多线程 线程安全
点赞
收藏

51CTO技术栈公众号