Python是非常實用的編程語言,學習簡單,有豐富的三方庫,如果想在Android手機中使用Python,實現Android和Python的混編,可以使用Chaquopy。
Chaquopy是Android基于gradle的構建系統的插件。它可以在滿足以下要求的任何應用程序中使用:
- 在項目的build.gradle文件,Android的gradle插件版本應該在4.1到7.2之間。Chaquopy的舊版本支持最早可追溯到2.2的舊版本。
- minSdkVersion必須至少為16。Chaquopy的舊版本支持最早可以追溯到15的舊版本。
基礎設置
在模塊構建的build.gradle中,在android plugin之后應用Chaquopy插件。
apply plugin: 'com.android.application'
apply plugin: 'com.chaquo.python'
在項目的build.gradle中,設置如下:
buildscript {
repositories {
maven{url "https://chaquo.com/maven"}
google()
jcenter()
mavenCentral()
}
dependencies {
classpath "com.android.tools.build:gradle:4.2.2"
classpath "com.chaquo.python:gradle:12.0.1"
}
}
allprojects {
repositories {
maven{url "https://chaquo.com/maven"}
google()
jcenter()
mavenCentral()
}
}
ABI選擇
Python解釋器是一個本地組件,所以你必須使用abiFilters設置來指定你希望應用程序支持哪些ABIs。
目前可用的api有:
- armeabi-v7a,幾乎所有Android設備都支持。
- arm64-v8a,由最新的Android設備支持。
- x86,用于Android模擬器。
- x86_64,用于Android模擬器。
在開發過程中,你可能想要啟用所有這些功能,例如:
defaultConfig {
ndk {
abiFilters "armeabi-v7a", "arm64-v8a", "x86", "x86_64"
}
}
實際上不需要安裝NDK,因為Chaquopy的所有本機庫都已經預先編譯和剝離了。
每個ABI都會將應用程序的大小增加幾個MB,再加上任何本地需求的大小。根據自己的需求,添加需要的ABI。
Python構建
默認情況下,chaquopy將嘗試使用您的操作系統的標準命令在PATH上查找Python,首先是匹配的小版本,然后是匹配的主版本。
如果不生效,請使用buildPython設置設置您的Python命令。例如,在Windows上,您可能使用以下其中之一:
defaultConfig {
python {
buildPython "D:/python3.8.3/python.exe"
}
}
開發源代碼
默認情況下,Chaquopy會在每個源代碼集的Python子目錄中查找Python源代碼。例如,主源碼集的Python代碼應該放在src/main/Python中。
要包含來自其他目錄的Python源代碼,請使用android.sourceSets。例如:
android {
sourceSets {
main {
python.srcDir "some/other/dir"
}
}
}
初始化
chaquopy初始化有兩種方式:
第一種:
AndroidManifest.xml中<application>使用PyApplication的子類
第二種:
AndroidManifest.xml中<application>指定application時,需要啟動,如下:
// "context" must be an Activity, Service or Application object from your app.
if (! Python.isStarted()) {
Python.start(new AndroidPlatform(context));
}
python依賴
外部Python包可以使用build.gradle中的pip塊構建到應用程序中。在這個塊中,添加安裝行,它可以采用pip install所接受的任何形式。
defaultConfig {
python{
buildPython "D:/python3.8.3/python.exe" //指定python解釋器
pip{
options "--extra-index-url","https://pypi.tuna.tsinghua.edu.cn/simple/" //設置下載鏡像
install "opencv-python"
install "requests==2.24.0" //可以指定下載的版本號
install "-r", "requirements.txt" //可以將需要導入的三方庫在requirements.txt中集中管理,通過此命令統一下載
}
}
}
HelloWorld
Android調用代碼:
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
public void usePython(View view) {
Python python = Python.getInstance();
python.getModule("hello").callAttr("sayHello");
}
}
Python實現代碼:
def sayHello():
print("Hello Python")