目录

使用 package:jnigen 进行 Java 互操作

运行在 Dart Native 平台 上的 Dart 移动应用、命令行应用和服务器应用,以及运行在 Android、Windows、macOS 和 Linux 上的应用,可以使用 package:jnipackage:jnigen 调用 Java 和 Kotlin API。

package:jni 允许 Dart 代码通过 JNI 与 Java 交互。但是,这样做会涉及大量的样板代码,因此您可以使用 package:jnigen 自动生成给定 Java API 的 Dart 绑定。

您可以将 Kotlin 编译为 Java 字节码,从而允许 package:jnigen 也为 Kotlin 生成绑定。

简单 Java 示例

#

本指南将引导您完成 一个示例 ,该示例使用 package:jnigen 为一个简单的类生成绑定。

预备条件

#

配置 jnigen

#

首先,将 package:jni 添加为依赖项,并将 package:jnigen 添加为 开发依赖项

$ dart pub add jni dev:jnigen

接下来,创建一个名为 jnigen.yaml 的顶级文件。此文件包含生成绑定的配置。

yaml
output:
  dart:
    path: lib/example.dart
    structure: single_file

source_path:
  - 'java/'
classes:
  - 'dev.dart.Example'

path 指定生成 dart 绑定的路径。

source_path 指定要为其生成绑定的 Java 源文件的路径, classes 指定 Java 类。

java/dev/dart/Example.java 包含一个非常简单的类,它具有一个名为 sum 的公共静态方法:

java
package dev.dart;

public class Example {
  public static int sum(int a, int b) {
    return a + b;
  }
}

生成 Dart 绑定

#

要生成 Dart 绑定,请运行 jnigen 并使用 --config 选项指定配置文件:

$ dart run jnigen --config jnigen.yaml

在此示例中,这将生成 lib/example.dart ,正如您在 jnigen.yaml 中指定的。

此文件包含一个名为 Example 的类,它具有一个名为 sum 的静态方法,就像 Java 文件一样。

使用绑定

#

现在您可以加载并与生成的库进行交互了。示例应用程序 bin/sum.dart 获取两个数字作为参数并打印它们的和。使用 Example.sum 方法与 Java 完全相同。

dart
// a 和 b 是整数参数
print(Example.sum(a, b));

运行示例

#

在运行示例之前,必须为 jni 构建动态库。Java 源代码也必须编译。为此,请运行:

$ dart run jni:setup
$ javac java/dev/dart/Example.java

现在您可以运行示例了:

$ dart run jnigen_example:sum 17 25

输出结果为 42

更多示例

#

以下是使用 package:jnigen 的一些更全面的示例:

示例描述
in_app_java演示如何在 Flutter 应用程序中包含自定义 Java 代码并使用 jnigen 调用它。
pdfbox_plugin一个 Flutter 插件示例,它提供对 Apache PDFBox 库的绑定。
notification_plugin一个可重用的 Flutter 插件示例,它包含使用 Android 库的自定义 Java 代码。