Android flutter_plugin插件开发之使用第三方jar包

创建flutter_plugin项目

在这里插入图片描述

点击代码编辑窗口右上角Open for Editing in Android Studio

在这里插入图片描述

在新的窗口选择project目录

在这里插入图片描述

创建一个libs文件夹用来放第三方jar包

展开 flutter_plugin->Android 在此目录下创建libs文件夹用来存放jar包
在这里插入图片描述

复制测试用的jar包到flutter_plugin->Android->libs里面

添加后jar包长这样
在这里插入图片描述

build.gradle上添加配置引入AppTest.jar包

dependencies {
    implementation files('libs/AppTest.jar')
}

在这里插入图片描述
同步后此时会发现AppTest.jar可以正常使用了,也可以看到jar包里面的方法.如图
在这里插入图片描述

编写java代码调用jar包

打开Flutter_plugin->Android->src->main->java->com.example.flutter_plugin->FlutterPlugin.java
注释掉原来代码.添加以下代码如图:
在这里插入图片描述

编写dart文件创建方法

切换到第一个窗口
编写 flutter_plugin->lib->flutter_plugin.dart
注释原来代码,添加以下代码

  static Future<String> get getResult async {
    //这个getResult就是调用我们之前在java代码编写getresult
    /***
     * if (call.method.equals("getResult"))
        {
        AppTest apptest = new AppTest();
        result.success(apptest.getResult());
        }
      */
    final String version = await _channel.invokeMethod('getResult');
    return version;
  }

在这里插入图片描述

编写main.dart

注释原来代码添加以下代码

import 'package:flutter/material.dart';
import 'dart:async';

import 'package:flutter/services.dart';
import 'package:flutter_plugin/flutter_plugin.dart';

void main() => runApp(MyApp());

class MyApp extends StatefulWidget {
  @override
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  //String _platformVersion = 'Unknown';
  String _appTestResult;
  @override
  void initState() {
    super.initState();
    //initPlatformState();
    getResult();
  }

  Future<void> getResult() async {
    String appTestResult;
    appTestResult = await FlutterPlugin.getResult;
    setState(() {
      _appTestResult = appTestResult;
    });
  }

  // Platform messages are asynchronous, so we initialize in an async method.
  /*Future<void> initPlatformState() async {
    String platformVersion;
    // Platform messages may fail, so we use a try/catch PlatformException.
    try {
      platformVersion = await FlutterPlugin.platformVersion;
    } on PlatformException {
      platformVersion = 'Failed to get platform version.';
    }

    // If the widget was removed from the tree while the asynchronous platform
    // message was in flight, we want to discard the reply rather than calling
    // setState to update our non-existent appearance.
    if (!mounted) return;

    setState(() {
      _platformVersion = platformVersion;
    });
  }*/

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: const Text('Plugin example app'),
        ),
        body: Center(
          //child: Text('Running on: $_platformVersion\n'),
            child: Text('Result =  $_appTestResult\n'),
        ),
      ),
    );
  }
}

在这里插入图片描述
此时会发现还有一个错误.是flutter_plugin_test.dart文件的…这个文件没啥用.直接注释错误后编译运行

在这里插入图片描述
运行结果如下.直接输出java包的good
在这里插入图片描述

到此就结束了.由于没有mac电脑.和mac测试的第三方库.暂时没有ios教程~
附上AppTest.jar包给大家练手
链接: https://pan.baidu.com/s/1bmAA9vLIdX7AF6HDqgcO3g 提取码: v3tu

  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 11
    评论
flutter_map是一个用于在Flutter应用程序中集成地图的插件[^2]。下面是一个使用flutter_map插件的示例: 首先,您需要在`pubspec.yaml`文件中添加flutter_map的依赖项: ```yaml dependencies: flutter_map: ^0.3.0 ``` 然后,运行`flutter packages get`命令来获取依赖项。 接下来,您可以在Flutter应用程序中使用flutter_map插件。以下是一个简单的示例,展示如何在地图上显示一个标记点: ```dart import 'package:flutter/material.dart'; import 'package:flutter_map/flutter_map.dart'; import 'package:latlong/latlong.dart'; void main() { runApp(MyApp()); } class MyApp extends StatelessWidget { @override Widget build(BuildContext context) { return MaterialApp( title: 'Flutter Map Demo', home: Scaffold( appBar: AppBar( title: Text('Flutter Map Demo'), ), body: FlutterMap( options: MapOptions( center: LatLng(51.5, -0.09), zoom: 13.0, ), layers: [ TileLayerOptions( urlTemplate: "https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png", subdomains: ['a', 'b', 'c'], ), MarkerLayerOptions( markers: [ Marker( width: 80.0, height: 80.0, point: LatLng(51.5, -0.09), builder: (ctx) => Container( child: FlutterLogo(), ), ), ], ), ], ), ), ); } } ``` 在上面的示例中,我们创建了一个Flutter应用程序,并在地图上显示了一个标记点。我们使用了`FlutterMap`小部件来显示地图,并使用`MapOptions`来设置地图的中心点和缩放级别。我们还使用了`TileLayerOptions`来指定地图瓦片的URL模板,以及`MarkerLayerOptions`来添加标记点。 请注意,为了使用flutter_map插件,您还需要在`pubspec.yaml`文件中添加`latlong`库的依赖项: ```yaml dependencies: latlong: ^0.6.1 ``` 这是一个简单的示例,您可以根据自己的需求进行更多的定制和功能扩展。希望对您有帮助!
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值