Flutter Web 调用JS实现一些特定功能

本文主要介绍flutterweb如何调用js完成一些特定的功能,比如定位、三方支付等。本文使用定位来介绍。
官方给开发者提供了js与dart交互的api:
https://api.flutter.dev/flutter/dart-js/dart-js-library.html

在使用时引入:

import 'dart:js' as js;

首先 flutter端:
1.在web文件夹下创建js文件:
在这里插入图片描述
location.js实现如下:


function getLocation () {
    // 百度地图API功能
       var geolocation = new BMap.Geolocation();
       geolocation.getCurrentPosition(function(r){
           if(this.getStatus() == BMAP_STATUS_SUCCESS){
                var geoc = new BMap.Geocoder();
                geoc.getLocation(r.point, function(rs){
                    var addComp = rs.addressComponents;
                    locationSuccess(r.point.lng,r.point.lat,addComp.province , addComp.city , addComp.district ,addComp.street ,addComp.streetNumber);
                });
           }
           else {
               return null;
           }
       },{enableHighAccuracy: true})
}

其中locationSuccess是flutter端的一个函数。
在index.html中引入我们的js文件:

  <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=EwfacWSKrCMCUiX1O40wMZc3cYHhItsX"></script>
  <script src="js/location.js" type="application/javascript"></script>
  <script src="main.dart.js" type="application/javascript"></script>

我们用到的其他的js最好是放到main.dart.js上面

  <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=EwfacWSKrCMCUiX1O40wMZc3cYHhItsX"></script>

这个是百度地图的js依赖。

2.flutter跟js的交互:

//将dart方法传给js,通过js调用locationSuccess来实现js与dart的通信
   js.context["locationSuccess"]=locationSuccess;
   //调用js的函数来执行想要的操作
   js.context.callMethod("getLocation");

这里 callMethod在dart:js中定义如下:

  /// Calls [method] on the JavaScript object with the arguments [args] and
  /// returns the result.
  ///
  /// The type of [method] must be either [String] or [num].
  external dynamic callMethod(method, [List args]);

通过注释可以看到callMethod可以传两个参数,一个是js 的函数名称,一个是参数,参数的类型只能是String或者num。
callMethod 是可以用一个参数来接收返回值,使用场景是,js的函数有返回值。例如:

function check () {

return "now wifi";
}

在flutter里可以使用如下代码来接收js的返回值:

   var result=js.context.callMethod("getLocation");
   println(result);

dart中回调函数定义如下:

  void  locationSuccess(lng,lat,province , city , district ,street ,streetNumber){
println(lng.toString()+","+lat.toString()+","+city.toString()+","+district.toString()+","+street.toString()+streetNumber);
  }

dart提供给js调用的函数可以有多个参数。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
可以使用Flutter的camera插件来实现在Android Studio中调用手机模拟器摄像头实现拍照功能。以下是实现步骤: 1. 在pubspec.yaml文件中添加camera插件依赖: ``` dependencies: camera: ^0.9.4+5 ``` 2. 在Flutter项目中引入camera插件: ``` import 'package:camera/camera.dart'; ``` 3. 初始化摄像头: ``` List<CameraDescription> cameras; Future<void> initCamera() async { cameras = await availableCameras(); // 选择第一个摄像头 final firstCamera = cameras.first; final camera = CameraController( firstCamera, ResolutionPreset.medium, ); await camera.initialize(); setState(() { _camera = camera; }); } ``` 4. 在Flutter页面中显示摄像头预览: ``` @override void initState() { super.initState(); initCamera(); } @override void dispose() { _camera.dispose(); super.dispose(); } @override Widget build(BuildContext context) { return Scaffold( body: _camera == null ? Container() : AspectRatio( aspectRatio: _camera.value.aspectRatio, child: CameraPreview(_camera), ), ); } ``` 5. 实现拍照功能: ``` void takePicture() async { final picturePath = join( (await getTemporaryDirectory()).path, '${DateTime.now()}.png', ); await _camera.takePicture(picturePath); } ``` 6. 在Flutter页面中添加一个按钮,调用takePicture()方法实现拍照: ``` FloatingActionButton( onPressed: takePicture, child: Icon(Icons.camera_alt), ), ``` 完成上述步骤后,您就可以在Android Studio中调用手机模拟器摄像头实现拍照功能了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

倚栏静望

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值