近来想到尝试用python开发一款app,google搜索了一番后linux下应用程序开发,发觉确实有路可寻,目前也有了一些相对成熟的模块,于是便开始了动手实战,过程中发觉这其中有好多坑,好在最终借助google解决了,因而杂记一番。
说在上面的话
python语言似乎很万能,但用它来开发app还是变得有点不对路,因而用python开发的app应该是作为编码练习、或者自娱自乐所用,加上目前这方面的模块还不是非常成熟,bug比较多,总而言之,劝君莫轻入。
打算工作
借助python开发app须要用到python的一个模块–kivy,kivy是一个开源的,跨平台的Python开发框架,用于开发使用创新的应用程序。简而言之linux下应用程序开发,这是一个python桌面程序开发框架(类似wxpython等模块),强悍的是kivy支持linux、mac、windows、android、ios平台,这也是为何开发app须要用到这个模块。
尽管kivy是跨平台的,并且想要在不同的平台使用python代码,还须要将python代码打包成对应平台的可执行程序,好在kivy项目下有个打包工具项目–buildozer,这是官方推荐的打包工具,由于相对比较简单,手动化程度高,其他项目例如:python-for-android也能起到类似的作用,这儿不展开介绍。
搭建kivy开发环境
须要在pc上安装kivy开发环境,这儿演示下mac与linux下的安装过程。
install kivy for mac
安装一些依赖包:
brew install pkg-config sdl2 sdl2_image sdl2_ttf sdl2_mixer gstreamer
安装cython以及kivy:
pip install cython==0.25
pip install kivy
假如安装kivy报错,则使用下边的形式安装kivy:
git clone https://github.com/kivy/kivy
python setup.py install
安装后测试:
$python
Python 2.7.10 (default, Jul 15 2017, 17:16:57)
[GCC 4.2.1 Compatible Apple LLVM 9.0.0 (clang-900.0.31)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>>
>>> import kivy
[INFO ] [Logger ] Record log in /Users/didi/.kivy/logs/kivy_18-05-08_4.txt
[INFO ] [Kivy ] v1.10.1.dev0, git-5f6c66e, 20180507
[INFO ] [Python ] v2.7.10 (default, Jul 15 2017, 17:16:57)
[GCC 4.2.1 Compatible Apple LLVM 9.0.0 (clang-900.0.31)]
说明:导出kivy模块没有报错则说明安装成功。
install kivy for centos7
先安装依赖:
yum install
make
mercurial
automake
gcc
gcc-c++
SDL_ttf-devel
SDL_mixer-devel
khrplatform-devel
mesa-libGLES
mesa-libGLES-devel
gstreamer-plugins-good
gstreamer
gstreamer-python
mtdev-devel
python-devel
python-pip
java-devel
安装cython以及kivy:
pip install Cython==0.20
pip install kivy
centos安装kivy参考:#using-software-packages
说明:其他安装kivy方法可移步:#download(须要翻墙)
用kivy开发第一个pythonapp
安装完kivy就可以开发app程序了,这儿演示下hello-world程序,关于kivy更复杂的用法不是本文重点,前面再成文介绍。
创建一个main.py文件,写入:
#! -*- coding:utf-8 -*-
from kivy.app import App
class HelloApp(App):
pass
if __name__ == '__main__':
HelloApp().run()
2)创建一个hello.kv文件,写入:
Label:
text: 'Hello, World! I am nMask'
简单说明:main.py是入口函数,定义了一个HelloApp类,该类承继kivy.app;hello.kv文件是kivy程序,相当于定义界面风格等,该文件命名规则为类名大写且清除app。
运行第一个pythonapp
python main.py
运行结果:
安装buildozer工具
通过以上的编码,我创建了自己的第一个pythonapp程序,该程序可以直接在mac、linux、windows平台下运行,这么怎么让它在安卓或则苹果手机上运行呢?我们晓得在安卓上运行,须要将其打包成apk安装程序,因而就须要用到上面提及过的buildozer工具,(buildozer工具可以打包kivy程序,支持android、ios等),buildozer的安装过程比较简单:
pip install buildozer
使用buildozer工具将kivy程序打包成apk
在python项目目录下运行:
buildozer init
运行成功将会创建一个配置文件buildozer.spec,可以通过更改配置文件修改app的名称等,之后运行:
buildozer android debug deploy run
运行以上命令将会生成跨平台的安装包,可适用安卓、ios等,假如用于安卓,则是借助python-for-android项目。
在第一次运行以上命令的时侯,会手动在系统中下载安卓sdk等必要文件,如右图。(过程须要翻墙,并且有好多依赖须要下载)
说明:这儿只演示打包成apk文件,iso平台的可自行研究,参考文档:。
pythonapk程序测试
假如以上步骤都运行成功的话,应当会在项目目录下的bin目录下生成一个apk文件,类似如下:
之后将apk下载到安卓系统的手机上,安装即可,测试疗效如下:
打开app
buildozer使用说明
Usage:
buildozer [--profile <name>] [--verbose] [target] <command>...
buildozer --version
Available targets:
android Android target, based on python-for-android project
ios iOS target, based on kivy-ios project
android_old Android target, based on python-for-android project (old toolchain)
Global commands (without target):
distclean Clean the whole Buildozer environment.
help Show the Buildozer help.
init Create a initial buildozer.spec in the current directory
serve Serve the bin directory via SimpleHTTPServer
setdefault Set the default command to run when no arguments are given
version Show the Buildozer version
Target commands:
clean Clean the target environment
update Update the target dependencies
debug Build the application in debug mode
release Build the application in release mode
deploy Deploy the application on the device
run Run the application on the device
serve Serve the bin directory via SimpleHTTPServer
Target "android_old" commands:
adb Run adb from the Android SDK. Args must come after --, or
use --alias to make an alias
logcat Show the log from the device
Target "ios" commands:
list_identities List the available identities to use for signing.
xcode Open the xcode project.
Target "android" commands:
adb Run adb from the Android SDK. Args must come after --, or
use --alias to make an alias
logcat Show the log from the device
p4a Run p4a commands. Args must come after --, or use --alias
to make an alias
buildozer打包过程中的坑点
若果在打包过程中遇见报错,可以更改buildozer.spec配置文件中的log_level为2,之后重新运行,可以看具体的错误信息。
报错:Youmighthavemissedtoinstall32bitslibs
这个错是我在centos7上运行晨报的错嵌入式linux驱动程序设计从入门到精通,大意是系统缺乏了个别32位的依赖文件。
解决方案:
yum -y install --skip-broken glibc.i686 arts.i686 audiofile.i686 bzip2-libs.i686 cairo.i686 cyrus-sasl-lib.i686 dbus-libs.i686 directfb.i686 esound-libs.i686 fltk.i686 freeglut.i686 gtk2.i686 hal-libs.i686 imlib.i686 lcms-libs.i686 lesstif.i686 libacl.i686 libao.i686 libattr.i686 libcap.i686 libdrm.i686 libexif.i686 libgnomecanvas.i686 libICE.i686 libieee1284.i686 libsigc++20.i686 libSM.i686 libtool-ltdl.i686 libusb.i686 libwmf.i686 libwmf-lite.i686 libX11.i686 libXau.i686 libXaw.i686 libXcomposite.i686 libXdamage.i686 libXdmcp.i686 libXext.i686 libXfixes.i686 libxkbfile.i686 libxml2.i686 libXmu.i686 libXp.i686 libXpm.i686 libXScrnSaver.i686 libxslt.i686 libXt.i686 libXtst.i686 libXv.i686 libXxf86vm.i686 lzo.i686 mesa-libGL.i686 mesa-libGLU.i686 nas-libs.i686 nss_ldap.i686 cdk.i686 openldap.i686 pam.i686 popt.i686 pulseaudio-libs.i686 sane-backends-libs-gphoto2.i686 sane-backends-libs.i686 SDL.i686 svgalib.i686 unixODBC.i686 zlib.i686 compat-expat1.i686 compat-libstdc++-33.i686 openal-soft.i686 alsa-oss-libs.i686 redhat-lsb.i686 alsa-plugins-pulseaudio.i686 alsa-plugins-oss.i686 alsa-lib.i686 nspluginwrapper.i686 libXv.i686 libXScrnSaver.i686 qt.i686 qt-x11.i686 pulseaudio-libs.i686 pulseaudio-libs-glib2.i686 alsa-plugins-pulseaudio.i686 python-matplotli
参考:
报错:ErrorcompilingCythonfile
错误大意为cython文件出错wps for linux,可能是cython模块没有安装,或则版本有问题。
解决方案:
pip install cython==0.25
报错:IOError:[Errno2]Nosuchfileordirectory……
这是在打包的最后一步,将apk文件copy到项目bin目录下晨报的错,是buildozer的一个bug。
解决方案:
更改/usr/local/lib/python2.7/dist-packages/buildozer/tagets/android.py文件:
(1)在文件开头导出:
from distutils.version import LooseVersion
(2)将786行:XXXfoundhowtheapknameisreallybuiltfromthetitle这一行以下的代码替换为:
__sdk_dir = self.android_sdk_dir
build_tools_versions = os.listdir(join(__sdk_dir, 'build-tools'))
build_tools_versions = sorted(build_tools_versions, key=LooseVersion)
build_tools_version = build_tools_versions[-1]
gradle_files = ["build.gradle", "gradle", "gradlew"]
is_gradle_build = any((exists(join(dist_dir, x)) for x in gradle_files)) and build_tools_version >= ’25.0'
buildozer虚拟机
kivy官方推出了一个buildozer虚拟机镜像,早已安装好了buildozer以及一些依赖文件,为buildozer打包测试提供平台。因为之前我在mac上借助buildozer打包仍然报错,后来换成centos也仍然没有成功,因而便下载了此虚拟机,测试疗效如下:
虚拟机下载地址:
说明:对于未能解决依赖问题的同学,可以使用此虚拟机进行程序打包,开发环境还是推荐用自己的本机。
kivy开发实例
由于本文重点在于介绍怎样借助kivy+buildozer开发一款pythonapp,因而对于kivy的开发过程,以及app功能进行了最简化。想要学习怎么开发更复杂的app,可参考:#