Android平臺Qt開發入門教程
很多人會問,Android平臺可以不使用Java開發應用程序??
我做Android平臺native開發之前,也有這么想過,但是我又想,底層系統全是c/c++代碼,用c/c++開發Android平臺程序是可能的,只是需要使用系統非公開的API(就是android源代碼,而非NDK里面提供的頭文件),比如libui和skia。
好了,由于我的工作是把C++中間件移植到Android平臺,所以會對Qt for android這個項目比較了解,畢竟國內做這些的還比較少,所以需要參考android-lighthouse如何解決的文字顯示,圖形,鍵盤,觸摸屏事件等等。
言歸正傳,我們開始今天的教程: 在Android平臺開發Qt應用程序。
前提:
- 你的系統必須是linux,或者MAC OS X。在windows平臺使用cygwin開發會遇到問題。
- 你首先需要下載android-ndk-r5或以上版本,android-sdk-r8或以上版本。
- 然后下載好android-lighthouse, 這個就是android平臺的Qt版本,國外個人移植的,nokia官方是不會發布這樣的版本的。git軟件庫地址:git://gitorious.org/~taipan/qt/android-lighthouse.git
- 當然你還可以下載整合了android平臺的qtcreator, 軟件庫地址:git://gitorious.org/~taipan/qt-creator/android-qt-creator.git 這樣你可以直接在qtcreator里面開發測試android應用程序,這里有個視頻介紹qtcreator開發android應用程序(被墻了,可以用VPN或proxy訪問): http://www.youtube.com/watch?v=VU_zPnQrM6E
下載,編譯android-lighthouse:
- 打開終端,輸入"git clone git://gitorious.org/~taipan/qt/android-lighthouse.git",便開始下載android-lighthouse的源碼。下載好后,android-lighthouse目錄結構如下圖:
- 下載android-qtcreator, 在終端中輸入"git clone git://gitorious.org/~taipan/qt-creator/android-qt-creator.git",開始下載;如果你不想使用圖形界面開發Qt應用程序,你可以不用下載,下面是我通過打包下載的qtcreator 2.1 for android的文件目錄結構,壓縮包總共21M.
aries@uu3g:/wp/qt-creator-android-qt-creator$ ls
dist HACKING LICENSE.LGPL qtcreator.pro scripts src
doc LGPL_EXCEPTION.TXT qtcreator.pri README share tests
- 然后我們修改以下環境變量,開始編譯android-lighthouse:
1. androidconfigbuild.sh文件, 把ANDROID_NDK_ROOT, ANDROID_NDK_HOST, ANDROID_NDK_TOOLCHAIN_PREFIX等等這5個變量安裝你下載的android-ndk進行修改,比如下面是我自己電腦上面設置的變量:
export ANDROID_NDK_ROOT=/opt/android-ndk-r5
export ANDROID_NDK_HOST=linux-x86
export ANDROID_NDK_TOOLCHAIN_PREFIX=arm-linux-androideabi
export ANDROID_NDK_TOOLCHAIN_VERSION=4.4.3
export ANDROID_NDK_PLATFORM=android-8
2. mkspecs/android-g++/qmake.conf文件,把NDK_ROOT, NDK_HOST,NDK_TOOLCHAIN_PREFIX, ANDROID_PLATFORM, NDK_TOOLCHAIN_VERSION按照你下載的android-ndk進行修改,比如我使用的是x86平臺的android-ndk-r5(非64位系統),我修改后的mkspecs/android-g++/qmake.conf文件如下圖所示:
- 做好以上2個文件的修改后,我們就開始編譯android-lighthouse,注意androidconfigbuild.sh最后有一個make的指令,你可以去掉他,自己手動輸入,或者現在修改,注意最好充分利用你的多核CPU,我2核的CPU,我就make -j2了,如果你是4核的,你最好make -j4,這樣我想如果3GHz的CPU,最多1個小時就可以編譯好android-lighthouse.修改好后,運行
./androidconfigbuild.sh
然后就等待結果,如果你設置的是手動輸入make,你需要在config完成之后輸入make自行編譯。
編譯結束后,輸入
sudo mkdir /data/local/qt
sudo make install
android-lighthouse默認會安裝到/data/local/qt目錄下。
安裝qt動態庫:
- 手機:首先確保你的手機有足夠大的空間安裝這些動態庫(全部安裝需要200M的空間),其中QtXml有50M, QtGui有90M,QtCore有20多M。這些都是帶調試信息的動態庫。(2011年1月20日注:其實不需要這么大的空間,strip過后的library只需要10多M就可以了,我原來拷貝的所有library是沒有strip過的)
- 模擬器:模擬器默認啟動會把分區大小設置為64M,這里是不夠用的,我們需要手動設置分區大小,我這里設置為256M。首先用android list列出你的AVD列表,如下圖
然后使用emulator -avd <avd_name> -partition-size <size_in_megabyte>指定分區大小并啟動模擬器,如下所示,我啟動的是android2.2, 分區大小為256M的AVD:
aries@uu3g:~$ emulator -avd android2.2 -partition-size 256
- 這里我們使用模擬器來做例子,使用adb -e push把所有Qt庫push到模擬器中,你也可以使用android-lighthouse自帶的腳本來完成這個任務,push_qt_libs.sh腳本內容如下(注意修改你的push_qt_libs.sh里面的strip工具路徑):
#!/bin/sh
adb shell rm -r /data/local/qt || exit 0
rm -fr al
mkdir al
cp -a lib/*.so* al/
/opt/android-ndk-r5/toolchains/arm-linux-androideabi-4.4.3/prebuilt/linux-x86/bin/arm-linux-androideabi-strip --strip-unneeded al/*
adb push al /data/local/qt/lib
adb push imports /data/local/qt/imports
adb push plugins /data/local/qt/plugins
運行Qt應用程序:
- 以上步湊結束后,我們還需要修改一些shell腳本才可以正常的工作,android-lighthouse main trunk里面的shell腳本有一些bug,這里我們就動手開始改他, 在android-lighthouse根目錄下面找到create_android_lighthouse_project.sh,打開,根據你android-ndk的版本路徑, 修改以下內容:
......
#修改以下2行,指向你的android-sdk和android-lighthouse源碼路徑
SDK_ROOT=/home/buus/dev/android-sdk-linux_x86
LIGHTHOUSE_ROOT=/home/buus/dev/android-lighthouse
......
#我的android-sdk里面,adb在platform-tools目錄下面,所以修改為$SDK_ROOT/platform-tools/adb
\$SDK_ROOT/tools/adb install -r bin/\$PROJECT_NAME-debug.apk
......
#同上
\$SDK_ROOT/tools/adb shell am start -n org.\$PROJECT_NAME.qt/.QtMain
......
#同上
\$SDK_ROOT/tools/adb install -r bin/\$PROJECT_NAME-debug.apk
這些路徑設置好后,我們再修改一些可能存在的bug, 把此腳本中的如下代碼
cp $LIGHTHOUSE_ROOT/examples/android/QtAnimatedtiles/AndroidManifest.xml $J_PRO/AndroidManifest.xml
cp -r $LIGHTHOUSE_ROOT/src/android/java/src/com $PROJECT_NAME-java/src
sed -i "s/animatedtiles/$PROJECT_NAME/g" $J_PRO/AndroidManifest.xml
cp \$Q_PRO/lib\$PROJECT_NAME.so* \$J_PRO/libs/armeabi #我們編譯cpp代碼時是生成可執行文件,不是生成動態庫
替換為
cp $LIGHTHOUSE_ROOT/src/android/java/AndroidManifest.xml $J_PRO/AndroidManifest.xml
cp -r $LIGHTHOUSE_ROOT/src/android/java/src/* $PROJECT_NAME-java/src
cp -r $LIGHTHOUSE_ROOT/src/android/java/res/* $PROJECT_NAME-java/res
sed -i "s/animatedtiles/$PROJECT_NAME/g" $J_PRO/src/org/$PROJECT_NAME/qt/QtMain.java
sed -i "s/calculator/$PROJECT_NAME/g" $J_PRO/src/com/nokia/qt/android/QtActivity.java
sed -i "s/example.name/$PROJECT_NAME.qt/g" $J_PRO/AndroidManifest.xml
sed -i "s/Application name/$PROJECT_NAME/g" $J_PRO/res/values/strings.xml
cp \$Q_PRO/\$PROJECT_NAME \$J_PRO/libs/armeabi/lib\$PROJECT_NAME.so #我們編譯cpp代碼時是生成可執行文件,不是生成動態庫,但這里必須以動態庫的形式加載
注意其中的幾個"sed", 你所需要替代的源對象可能和這里的不一樣,請根據你的情況做適當修改。
修改這些主要是由于example里面的代碼沒有及時更新,并且我們還需要res里面的libs.xml文件,然后保存,這里有一份我修改好的,針對2011年1月份的trunk做的修改。
[attach]694[/attach]
- 以上步湊結束后,我們開始拷貝一個例子程序來開始我們的Qt for android之旅。拷貝examples/widgets/calculator整個目錄到android-lighthouse根目錄下面,然后使用"create_android_lighthouse_project.sh"創建此c++代碼對應的java代碼,我們在終端里面運行
./create_android_lighthouse_project.sh -n calculator
- 命令結束后,會在當前目錄產生calculator-cpp和calculator-java 2個目錄,以及build.sh, creatorbuild.sh, run.sh等工具腳本。這里需要注意,calculator-cpp目錄下面的源代碼是stub程序,就是什么事情都不做作的代碼,我們需要把這個目錄下面的所有文件都刪除掉,然后把calculator目錄下面的所有文件拷貝到calculator-cpp目錄下,然后再運行(在這里你的模擬器必須啟動,或者手機已經正確連接上電腦了):
./build.sh
我執行以上幾個步湊后的終端:
aries@uu3g:/wp/android-lighthouse$ rm calculator-cpp/* -rf
aries@uu3g:/wp/android-lighthouse$ cp calculator/* calculator-cpp/
aries@uu3g:/wp/android-lighthouse$ ./build.sh
/opt/android-ndk-r5/toolchains/arm-linux-androideabi-4.4.3/prebuilt/linux-x86/bin/arm-linux-androideabi-g++ -c -Wno-psabi -march=armv5te -mtune=xscale -msoft-float -fpic -mthumb -ffunction-sections -funwind-tables -fstack-protector -fno-short-enums -DANDROID -D__ARM_ARCH_5__ -D__ARM_ARCH_5T__ -D__ARM_ARCH_5E__ -D__ARM_ARCH_5TE__ -DQT_NO_QWS_TRANSFORMED -I/wp/android-lighthouse/src/3rdparty/android/precompiled/android-8/arch-arm/include -Os -g -fomit-frame-pointer -fno-strict-aliasing -finline-limit=64 -Wall -W -D_REENTRANT -DQT_NO_CORESERVICES -DQT_NO_DEBUG -DQT_GUI_LIB -DQT_NETWORK_LIB -DQT_CORE_LIB -DQT_SHARED -I../mkspecs/android-g++ -I. -I../include/QtCore -I../include/QtNetwork -I../include/QtGui -I../include -I.moc/release-shared -I/opt/android-ndk-r5/platforms/android-8/arch-arm/usr/include -I/opt/android-ndk-r5/sources/cxx-stl/gnu-libstdc++/include -I/opt/android-ndk-r5/sources/cxx-stl/gnu-libstdc++/libs/armeabi/include -o .obj/release-shared/button.o button.cpp
.......
-obfuscate:
-dex:
[echo] Converting compiled files and external libraries into /wp/android-lighthouse/calculator-java/bin/classes.dex...
-package-resources:
[echo] Packaging resources
[aapt] Creating full resource package...
-package-debug-sign:
[apkbuilder] Creating calculator-debug-unaligned.apk and signing it with a debug key...
debug:
[echo] Running zip align on final apk...
[echo] Debug Package: /wp/android-lighthouse/calculator-java/bin/calculator-debug.apk
BUILD SUCCESSFUL
Total time: 8 seconds
652 KB/s (304878 bytes in 0.456s)
pkg: /data/local/tmp/calculator-debug.apk
Success
- 到這里,我們就成功編譯并安裝好了Qt版的calculator了,把logcat打開,我們試一試運行這個calculator,并看一看android log的輸出,另起一個終端,里面輸入
adb logcat
- 由于run.sh有bug,所以我們就不用這個腳本來啟動calculator,打開android模擬器或者手機的軟件列表,找到名為calculator的應用程序,點擊就可以運行了,如下圖(左面終端里面是logcat輸出的log信息):
用鼠標點擊下這個計算器試試效果如何。
以后我們便可以按照以上步湊創建自己的Qt應用程序了。
作者: Aries @ 米狗族
網站: http://www.meegozu.com/thread-1199-1-1.html
歡迎轉載,轉載請保留以上信息。
留言列表