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

news/2024/11/23 0:59:50/

文章目录

  • 简介
  • 使用相机前的准备工作
  • 在flutter中使用camera
  • 总结

简介

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

一起来看看吧。

使用相机前的准备工作

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

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

flutter pub add camera  

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

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

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

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

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

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

<key>NSCameraUsageDescription</key>
<string>flutter需要用到你的照相机</string>

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

在flutter中使用camera

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

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

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

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

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

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

Future<List<CameraDescription>> 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<void> 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<CameraApp> {late CameraController _controller;late Future<void> _initializeControllerFuture;@overridevoid initState() {super.initState();_controller = CameraController(widget.camera,ResolutionPreset.medium,);_initializeControllerFuture = _controller.initialize();}

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

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

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

body: FutureBuilder<void>(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


http://www.ppmy.cn/news/37971.html

相关文章

【嵌入式烧录刷写文件】-2.2-合并两个Intel Hex文件

案例背景(共8页精讲)&#xff1a; 1.教你如何合并两个Bootloader.hex和App.hex文件&#xff1b; 2.提供了两种方法合并两个Intel Hex文件&#xff1b; 3.基于批处理Bat脚本&#xff0c;以及Vector HexView工具提供的Command line&#xff0c;自动化完成两个Hex文件的合并&#…

2023美赛春季赛D题思路数据代码论文分享

文章目录赛题思路赛题详情参赛建议&#xff08;个人见解&#xff09;选择队友及任务分配问题&#xff08;重要程度&#xff1a;5星&#xff09;2023美赛春季赛D题思路数据代码【最新】赛题思路 (赛题出来以后第一时间在CSDN分享) 最新进度在文章最下方卡片&#xff0c;加入获取…

【JAVAEE】手把手教学多线程,包教包会~

线程与进程为了实现多个任务并发执行的效果&#xff0c;人们引进了进程。何谓进程&#xff1f;我们电脑上跑起来的每个程序都是进程。每一个进程启动&#xff0c;系统会为其分配内存空间以及在文件描述符表上有所记录等。进程是操作系统进行资源分配的最小单位&#xff0c;这意…

python初级 学习内容分享

课程内容包含 基础语法 和 面向对象编程 基础语法&#xff08;视频课程目录&#xff09; 1开发环境安装介绍 01-计算机组成 02-Python简介 03-课程介绍. 04-解释器的作用和分类. 05-Python解释器的下载和安装. 06-PyCharm的作用 07-下载和安装PyCharm. 08-新建项目 …

Linux快速启动SpringBoot工程

个人简介&#xff1a;Java领域新星创作者&#xff1b;阿里云技术博主、星级博主、专家博主&#xff1b;正在Java学习的路上摸爬滚打&#xff0c;记录学习的过程~ 个人主页&#xff1a;.29.的博客 学习社区&#xff1a;进去逛一逛~ Linux下快速启动SpringBoot工程一、查看JDK版本…

交叉编译器的介绍

一.介绍 1.1何谓交叉编译器 交叉编译通俗地讲就是在一种平台上编译出能运行在体系结构不同的另一种平台上。这种方法在异平台移植和嵌入式开发时用得非常普遍&#xff0c;相对与交叉编译&#xff0c;我们平常做的编译就叫本地编译&#xff0c;也就是在当前平台编译&#xff0…

【python实操】如何改善你的程序,让你的程序更快执行?

作者&#xff1a;20岁爱吃必胜客&#xff08;坤制作人&#xff09;&#xff0c;近十年开发经验, 跨域学习者&#xff0c;目前于海外某世界知名高校就读计算机相关专业。荣誉&#xff1a;阿里云博客专家认证、腾讯开发者社区优质创作者&#xff0c;在CTF省赛校赛多次取得好成绩。…

stm32f10x系列芯片信息

stm32f10x系列芯片信息 STM32F103微控制器采用Cortex-M3内核&#xff0c;CPU最高速度达72 MHz。该产品系列具有16KB ~ 1MB Flash、多种控制外设、USB全速接口和CAN。 引脚及其容量大小关系 Flash memory size / RAM size&#xff08;byte&#xff09;&#xff1a;flash内存大…