【嵌入式开发技术之Qtopia】安装和交叉编译文档(2)——编译安装X86主机版各种QT

简介:

1. 编译安装X86主机版各种QT:
1)准备工作
$sudo apt-get install gcc-3.3 g++-3.3 build-essential libx11-dev
libxext-dev uuid-dev libjpeg-dev zlib1g-dev zhcon
其中:
Gcc-3.3,G++-3.3是GCC3.3版本,没有使用系统自带的4.3.1,原因是GCC4在编译QT3-X11时可能会出错。
Build-essential是ubuntu/debian下编译程序所必需的。
Lib-x11-dev是X11的一个开发库。
libxext-dev是Xfree86 3.x的一些扩展开发库。以上两个都是编译基于X11的Qt所必须的包。
uuid-dev,UUID是一个标帜系统中的存储设备的字符串,其目的是帮助使用者唯一的确定系统中的所有存储设备。可以标识DVD驱动器,USB存储设备以及系统中的硬盘设备等。这个是UUID的一个开发库。
libjpeg-dev是JPEG的开发库。
Zlib 是常用的压缩库。以上三个都是必须的一些外围库。
Zhcon是中文控制台。它是外挂式平台,与内核汉化不同,不需要对linux的
kernel打补丁,在主控制台上执行zhcon后,就可以进入中文平台。
<- -------------------------------------------------
$cd /usr/bin
$sudo ln -sf gcc-3.3 gcc
$sudo ln -sf g++-3.3 g++
建立gcc3.3的软链接
<- -------------------------------------------------
$cd ~
$mkdir myqt
$mv Desktop/qtopia-free-src-2.2.0.tar.gz myqt/.
$mv Desktop/qt-x11-free-3.3.8b.tar.gz myqt/.
$mv Desktop/qt-embedded-free-3.3.8b.tar.gz myqt/.
$cd myqt/
$tar zxvf qtopia-free-src-2.2.0.tar.gz
$mv qtopia-free-2.2.0/ qtopia-host
$tar zxvf qt-embedded-free-3.3.8b.tar.gz
$mv qt-embedded-free-3.3.8b qt-embedded-host
$tar zxvf qt-x11-free-3.3.8b.tar.gz
$mv qt-x11-free-3.3.8b qt3-x11
从桌面上把几个安装包移动到家目录的myqt目录,然后解压更名,目录名及其
含义如下:
Qt3-x11是主机版本的Qt-X11,qt-embedded-host是主机版本的Qt/Embedded,
qtopia-host是主机板qtopia。
2)Qt-X11的安装和基本使用
$cd qt3-x11
$( echo yes )|./configure
$make
$sudo make install
$sudo cp -R lib/* /usr/local/lib
$sudo cp -R include/* /usr/local/include
这是编译安装qt-X11的基本方法,若有错误,要看一看前边的包是否都装齐。
<- -------------------------------------------------
$export QTDIR=$PWD
$export PATH=$QTDIR/bin:$PATH
$export LD_LIBRARY_PATH=$QTDIR/lib:$LD_LIBRARY_PATH
临时设置QT所需变量
$mkdir qtprogram/hello –p
$cd qtprogram/thello
$vi hello.cpp
源文件如下:

#include <qapplication.h>
#include <qlabel.h>
int main(int argc, char *argv[])
{
QApplication app(argc, argv);
QLabel *label = new QLabel("Hello Qt!", 0);
app.setMainWidget(label);
label->show();
return app.exec();
}

现在来编译我们的程序。
产生.pro工程文件
$ qmake –project
生成Makefile文件:
$qmake
编译:
$make
运行:
$./hello
这时会出现一个很小的hello窗口。
3)Qtopia2.2.0主机的安装和运行
$cd qtopia-host/
$cp /usr/local/bin/uic qt2/bin/.
$( echo yes )|./configure
$make
$make install
这是编译安装Qtopia的基本方法。Make install后系统会在image文件夹中生成Qtopia的整个文件树,其中的结构和文件都是Qtopia所要用的,当然某些库、字库以及帮助文档是可以精简的,在嵌入式移植部分我们会进行。
<- -------------------------------------------------
$cd qtopia/
$mkdir -p image/opt/qt/lib
$cp -R ../qt2/lib/ image/opt/qt/lib
$rm image/opt/qt/lib/*
将qt2目录中的字库复制到image中,这样整体文件架构比较清晰,然后删去qt2所用的链接库。
<- -------------------------------------------------
$export QTDIR=/home/inno/myqt/qtopia-host/qtopia/image/opt/qt
$export QPEDIR=/home/inno/myqt/qtopia-host/qtopia/image/opt/Qtopia
$export LD_LIBRARY_PATH=$QTDIR/lib:$QPEDIR/lib:$LD_LIBRARY_PATH
$../qt2/bin/qvfb &
$cd image/opt/Qtopia/bin/
$./qpe &
这是运行Qtopia的基本步骤,首先设置环境变量R,Qtopia会在运行时查看QTDIR/lib/fonts,这个操作的主要目的是完成字库的加载。然后设置QPEDIR和LD_LIBRARY_PATH,Qtopia在运行时会在根据此寻找相关系统基础和Plugin插件的动态链接库。进一步要把虚拟Framebuffer开启,虚拟帧缓冲使用了共享存储区域(虚拟的帧缓冲)来模拟帧缓冲并且在一个窗口中(qvfb)模拟一个应用来显示帧缓冲。
Qtopia要在其上运行。
Qpe是qtopia的主程序
$make lupdate
这是确保翻译所必须的文件都存在并且是最新的,make lupdate针对每种语言通过调整Qtopia的“语言”这个配置选项产生了翻译文件,命名就是以appname-cn-ZH.ts这样的名字来命名的。
$bin/nct_lupdate
产生那些在源代码中没有办法找到的字符串的翻译文件。
$vi /qtopia-host/qtopia/i18n/zh_CN/.directory
[Translation]
File=QtopiaI18N
Context=Chinese(MainLand)
[Desktop Entry]
Name[]=Chinese(MainLand)
每种语言都需要一个.directory以设定语言,这个会在Qtopia的Language中显示。
$cd http://www.cnblogs.com/
$make lupdate
再次更新。
$cd i18n/zh_CN
$linguist
打开每个ts文件在Translation处写入中文,注意在确认时按Crtl+Enter,看到绿色的对勾就是更新成功了,每个文件注意要保存。
$touch QtopiaRingTones.ts QtopiaThemes.ts
在make install时可能会出现两个文件不存在的错误,所以建立两个空的就可以了。
$vi $QPEDIR/i18n/zh-CN/QtopiaDefaults.ts.
在<name>FontMap</name>将small部分修改为
<message encoding="UTF-8">
<source>Small,helvetica,10</source>
<translation>Simsun,simsun,11</translation>
</message>
修改默认字体为simsun字体。这个字体及其配置的目录fonts我已经放在http://blogimg.chinaunix.net/blog/upfile2/081109125513.gz供下载。
$lrelease *.ts
用lrelease产生QT消息文件。会有两个warning,当然是刚才那两个没有意义的空文件造成的
$cd http://www.cnblogs.com/
$make lupdate
$make install
安装文件到image目录
export QPEDIR=/home/inno/myqt/qtopia-host/qtopia/image/opt/Qtopia
export QTDIR=$QPEDIR
export PATH=$QPEDIR/bin:/home/inno/myqt/qtopia-host/qt2/bin:$PATH
export LD_LIBRARY_PATH=$QPEDIR/lib:$LD_LIBRARY_PATH
然后在image/opt/Qtopia下设置环境变量,
$cd $QPEDIR/bin
$qvfb &
$./qpe &
运行Qtopia。
然后在settings里的Appearance settings中进行Fonts的选择,在language中选择Chinese即可。
5)Qt-embedded的安装
$export QT2DIR=/home/inno/qt/qt-embedded-host/
$export QTDIR=$QT2DIR
$export QTEDIR=$QT2DIR
$export PATH=$QTDIR/bin:$PATH
$export LD_LIBRARY_PATH=$QTDIR/lib:$LD_LIBRARY_PATH
$cd qt-embedded-host/
$./configure
$make
$make install
注意选色深时选16位即可。



本文转自gnuhpc博客园博客,原文链接:http://www.cnblogs.com/gnuhpc/archive/2012/01/08/2316288.html,如需转载请自行联系原作者

相关文章
|
9天前
|
Oracle 关系型数据库 Linux
讲解linux下的Qt如何编译oracle的驱动库libqsqloci.so
通过这一连串的步骤,可以专业且有效地在Linux下为Qt编译Oracle驱动库 `libqsqloci.so`,使得Qt应用能够通过OCI与Oracle数据库进行交互。这些步骤适用于具备一定Linux和Qt经验的开发者,并且能够为需要使用Qt开发数据库应用的专业人士提供指导。
19 1
讲解linux下的Qt如何编译oracle的驱动库libqsqloci.so
|
1月前
Qt安装之后添加或移除组件(Qt Creator 10.0.1)
Qt安装之后添加或移除组件(Qt Creator 10.0.1)
24 2
|
1月前
|
IDE 开发工具 数据安全/隐私保护
【干货】Qt Creator快速下载、安装、使用教程
【干货】Qt Creator快速下载、安装、使用教程
207 2
|
1月前
|
SQL Linux 数据库
Linux上sqlite的安装和使用方法以及在QT中如何使用sqlite&笔记总结
Linux上sqlite的安装和使用方法以及在QT中如何使用sqlite&笔记总结
|
22天前
|
机器学习/深度学习 人工智能 计算机视觉
好的资源-----打卡机+Arm+Qt+OpenCV嵌入式项目-基于人脸识别的考勤系统-----B站神经网络与深度学习,商城
好的资源-----打卡机+Arm+Qt+OpenCV嵌入式项目-基于人脸识别的考勤系统-----B站神经网络与深度学习,商城
|
29天前
|
XML 存储 JSON
技术笔记:Qt基础之配置文件(QSettings)
技术笔记:Qt基础之配置文件(QSettings)
17 0
|
1月前
|
调度
技术笔记:QT之深入理解QThread
技术笔记:QT之深入理解QThread
18 0
|
1月前
|
并行计算 Ubuntu 计算机视觉
【边缘智能】Jetson板卡上安装QT5与OpenCV集成
【边缘智能】Jetson板卡上安装QT5与OpenCV集成
50 0
|
23天前
|
数据安全/隐私保护 C++ 计算机视觉
Qt(C++)开发一款图片防盗用水印制作小工具
文本水印是一种常用的防盗用手段,可以将文本信息嵌入到图片、视频等文件中,用于识别和证明文件的版权归属。在数字化和网络化的时代,大量的原创作品容易被不法分子盗用或侵犯版权,因此加入文本水印成为了保护原创作品和维护知识产权的必要手段。 通常情况下,文本水印可以包含版权声明、制作者姓名、日期、网址等信息,以帮助识别文件的来源和版权归属。同时,为了增强防盗用效果,文本水印通常会采用字体、颜色、角度等多种组合方式,使得水印难以被删除或篡改,有效地降低了盗用意愿和风险。 开发人员可以使用图像处理技术和编程语言实现文本水印的功能,例如使用Qt的QPainter类进行文本绘制操作,将文本信息嵌入到图片中,
69 1
Qt(C++)开发一款图片防盗用水印制作小工具
|
1月前
|
关系型数据库 MySQL 项目管理
数据库大作业——基于qt开发的图书管理系统(四)项目目录的整理与绘制登录页面
数据库大作业——基于qt开发的图书管理系统(四)项目目录的整理与绘制登录页面

推荐镜像

更多