跳到主要内容
版本:v3

自定义原生 Android 代码

使用 Capacitor 时,我们鼓励您编写 Java 或 Kotlin 代码来实现应用所需的原生功能。

并非所有功能都有现成的 Capacitor 插件——这完全没问题!您可以直接在应用中编写 WebView 可访问的原生代码。

WebView 可访问的原生代码

在 JavaScript 和原生代码之间通信最简单的方式,是构建一个仅限当前应用使用的自定义 Capacitor 插件。

创建 EchoPlugin.java

首先,通过以下步骤创建 EchoPlugin.java 文件:打开 Android Studio,展开 app 模块和 java 文件夹,右键点击应用的 Java 包,从上下文菜单中选择 New -> Java Class,然后创建文件。

Android Studio 应用包结构

将以下 Java 代码复制到 EchoPlugin.java

package com.example.myapp;

import com.getcapacitor.JSObject;
import com.getcapacitor.Plugin;
import com.getcapacitor.PluginCall;
import com.getcapacitor.PluginMethod;
import com.getcapacitor.annotation.CapacitorPlugin;

@CapacitorPlugin(name = "Echo")
public class EchoPlugin extends Plugin {

@PluginMethod()
public void echo(PluginCall call) {
String value = call.getString("value");

JSObject ret = new JSObject();
ret.put("value", value);
call.resolve(ret);
}
}

注册插件

我们需要在 Android 和 Web 两端都注册自定义插件,这样 Capacitor 才能在 Java 和 JavaScript 之间建立桥梁。

MainActivity.java

在应用的 MainActivity.java 中,使用 registerPlugin()registerPlugins() 来注册自定义插件。

 public class MainActivity extends BridgeActivity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
+ registerPlugin(EchoPlugin.class);
}
}

JavaScript 部分

在 JS 中,我们使用 @capacitor/coreregisterPlugin() 创建一个与 Java 插件关联的对象。

import { registerPlugin } from '@capacitor/core';

const Echo = registerPlugin('Echo');

export default Echo;

registerPlugin() 的第一个参数是插件名称,必须与 EchoPlugin.java@CapacitorPlugin 注解的 name 属性一致。

TypeScript 支持

我们可以通过定义接口并在 registerPlugin() 调用中使用它,为关联对象添加类型定义。

 import { registerPlugin } from '@capacitor/core';

+export interface EchoPlugin {
+ echo(options: { value: string }): Promise<{ value: string }>;
+}

-const Echo = registerPlugin('Echo');
+const Echo = registerPlugin<EchoPlugin>('Echo');

export default Echo;

registerPlugin() 的泛型参数定义了关联对象的结构。如果需要,可以使用 registerPlugin<any>('Echo') 来忽略类型检查。我们完全理解 ❤️

使用插件

使用导出的 Echo 对象来调用插件方法。以下代码片段将在 Android 上调用 Java 方法并打印结果:

import Echo from '../path/to/echo-plugin';

const { value } = await Echo.echo({ value: 'Hello World!' });
console.log('Response from native:', value);

后续步骤

阅读 Android 插件开发指南 ›