flutter系列之:在flutter中使用相机拍摄照片

简介

在app中使用相机肯定是再平常不过的一项事情了,相机肯定涉及到了底层原生代码的调用,那么在flutter中如何快速简单的使用上相机的功能呢?


(相关资料图)

一起来看看吧。

使用相机前的准备工作

flutter中为使用camera提供了一个叫做camera的插件,我们首先需要安装这个插件。

安装插件的步骤很简单,如下所示:

flutter pub add camera  

该命令会在pubspec.xml中添加下面的内容:

dependencies:  flutter:    sdk: flutter  camera: ^0.10.0+1

除了camera之外,我们还需要对照相机拍摄的照片进行保存,这样我们还需要用到path_provider和path这两个plugin。

我们使用同样的方式对这两个插件进行安装。

安装好之后,我们就可以在flutter中的代码中愉快的使用camera了。

在使用camera之前,我们还需要获取相应的权限信息,比如在IOS中,我们需要在 ios/Runner/Info.plist中添加下面的权限信息:

NSCameraUsageDescriptionflutter需要用到你的照相机

在andorid中需要配合minSdkVersion>=21来使用。

在flutter中使用camera

camera插件为我们提供了一系列的功能来方便camera的使用。

camera的使用需要遵循下面的步骤,因为现在的手机可能会有多个摄像头,所以我们需要通过api获取到可以使用的摄像头列表。

接下来我们使用选中的摄像头,进行一些控制操作,然后需要使用相应的camera视图来展示相应的照相机图像.

最后调用摄像头相关的拍摄功能进行拍摄。

听起来好像挺复杂的,事实上只要遵照上面的顺序,一切都是非常简单的。

首先我们需要获取可用的摄像头列表,这个步骤是通过调用camera包中的availableCameras方法来实现的:

Future> availableCameras() async {  return CameraPlatform.instance.availableCameras();}

availableCameras是一个异步方法,返回的是一个Future对象,其中的值是CameraDescription列表。

CameraDescription是对camera的描述文件:

const CameraDescription({    required this.name,    required this.lensDirection,    required this.sensorOrientation,  });

name是摄像头的名称,lensDirection是摄像头面对的方向,sensorOrientation是传感器的方向,也就说你的手机是正常放置,还是选择90度放置。

因为availableCameras是一个异步方法,所以我们需要把它包裹在一个异步方法中进行调用:

Future main() async {  // 保证所有的插件都加载完毕  WidgetsFlutterBinding.ensureInitialized();  //获取摄像头列表  final cameras = await availableCameras();  //拿到第一个摄像头  final firstCamera = cameras.first;  ....

这里我们拿到了第一个摄像头,注意,这里的firstCamera是一个CameraDescription对象。

因为模拟器上没有摄像头,如果你是在模拟器上运行上面的程序的话,将会抛出下面的异常:

[VERBOSE-2:dart_vm_initializer.cc(41)] Unhandled Exception: Bad state: No element#0      List.first (dart:core-patch/growable_array.dart:343:5)

为了对这个camra进行控制, 我们需要创建一个CameraController对象:

class CameraAppState extends State {  late CameraController _controller;  late Future _initializeControllerFuture;  @override  void initState() {    super.initState();    _controller = CameraController(      widget.camera,      ResolutionPreset.medium,    );    _initializeControllerFuture = _controller.initialize();  }

CameraController的构造函数需要一个CameraDescription对象和分辨率等信息,并且还需要进行初始化,这里我们调用了它的initialize方法。

这里的initialize方法也是一个异步方法。

为了在CameraController初始化之后再对Camera进行使用,我们需要在返回的widget中使用FutureBuilder来构建:

body: FutureBuilder(        future: _initializeControllerFuture,        builder: (context, snapshot) {          if (snapshot.connectionState == ConnectionState.done) {            return CameraPreview(_controller);          } else {            return const Center(child: CircularProgressIndicator());          }        },      )

具体要展示什么内容呢?这里使用的是camera包中自带的CameraPreview组件。

CameraPreview需要传入一个CameraController对象,也就是之前我们创建的对象。

最后就是调用CameraController的方法进行拍照了。我们把拍照的逻辑放在floatingActionButton中,如下所示:

floatingActionButton: FloatingActionButton(        onPressed: () async {          try {            await _initializeControllerFuture;            final image = await _controller.takePicture();            if (!mounted) return;            await Navigator.of(context).push(              MaterialPageRoute(                builder: (context) => DisplayPictureScreen(                  imagePath: image.path,                ),              ),            );          } catch (e) {            print(e);          }        },        child: const Icon(Icons.camera_alt),      )

具体的逻辑就是调用controller.takePicture方法进行拍照。将拍好照的image放在一个新的widget中展示。

总结

摄像头是app中常用的功能,flutter中的camera插件为我们提供了摄像头的控制功能,非常简单。

本文的例子:https://github.com/ddean2009/learn-flutter.git

标签:

最近更新

flutter系列之:在flutter中使用相机拍摄照片
2023-04-06 22:41:16
存储器厂商南亚科Q1营收创近14年来新低,“上半年是DRAM最差的时候”
2023-04-06 20:55:38
揭秘杨贵妃为安禄山洗澡真相,杨贵妃和安禄山真的偷情过吗?
2023-04-06 19:54:49
钒钛股份:接受深圳协众等机构调研 当前快报
2023-04-06 18:41:21
三国志战棋版荀彧技能强度解析 世界今头条
2023-04-06 17:46:19
环球热门:保荐工作中对客户背调不到位等,国开证券等被西藏证监局采取监管谈话措施
2023-04-06 17:00:21
福建:将针对“双减”开展经常性督导|当前速读
2023-04-06 15:58:57
虚假广告分为哪几种情形
2023-04-06 15:07:27
什么人群适合做光子嫩肤,做光子嫩肤的功效有哪些?-当前焦点
2023-04-06 14:05:11
恒生银行(00011)委任张嘉琪担任公司秘书及企业管治主管
2023-04-06 13:02:24
4月6日国内市场醋酐行情趋稳
2023-04-06 11:56:11
“大陆各方面发展都非常快”——马英九一行感受大陆建设发展脉动 最新
2023-04-06 11:07:11
房产早报|沈阳、江西赣州等城市的首套房贷款利率再次下调 全球今日报
2023-04-06 10:14:41
世界百事通!总投资约110亿元!丽豪10万吨高纯晶硅项目启动!
2023-04-06 09:35:04
天赐材料:融资净偿还786.19万元,融资余额19.57亿元(04-04) 热点聚焦
2023-04-06 08:48:41
四会富仕:公司持续优化人才梯队建设,对于人才类别的划分会根据研发项目具体进展情况进行动态调整,公司的研发项目均正常进行
2023-04-06 07:21:27
10000MB/s!达墨PCIe 5.0 SSD上架:2TB 1899元|环球热消息
2023-04-06 05:54:22
山奈钓鲤鱼_山奈钓鱼的原理|世界热推荐
2023-04-06 01:02:16
河南淇县出台彩礼等婚俗限高标准事件简单介绍 焦点观察
2023-04-05 21:56:29
万科企业(02202)首季合同销售金额1013.8亿元 同比减少4.81%
2023-04-05 20:12:27
penbeat外国大神_penbeat
2023-04-05 18:13:18
看热讯:组图丨道县:代育代耕 促早稻生产
2023-04-05 16:42:16
雨后泰山,云雾缭绕似仙境 天天热头条
2023-04-05 15:16:58
大国重器+1!创国内多项建造纪录!
2023-04-05 13:51:30
个人房产证明怎么开_房产证明怎么开
2023-04-05 11:55:34
人防+技防 筑牢春季森林防火安全墙
2023-04-05 10:08:48
今日观点!辽宁聚焦突出问题全域净化农村环境
2023-04-05 09:09:19
环球快报:光云科技(688365)4月4日主力资金净卖出815.97万元
2023-04-05 07:55:53
世界今亮点!芬兰正式加入北约,成为第31个成员国
2023-04-05 05:51:58
【世界新要闻】响水大米和五常大米哪个好_响水大米
2023-04-05 01:59:36