日日噜噜噜夜夜爽亚洲精品_欧美视频在线观看一区_久久久久久久久久久久久久久99_成人在线视频网站_国产丝袜美腿一区二区三区_亚洲黄页视频免费观看_国产成+人+综合+亚洲欧洲_日韩一级精品视频在线观看_欧美激情极品视频_亚洲精品国产精品国自产在线

首頁 | 資訊 | 財(cái)經(jīng) | 公益 | 彩店 | 奇聞 | 速遞 | 前瞻 | 提點(diǎn) | 網(wǎng)站相關(guān) | 科技 | 熱點(diǎn) | 生活 |
【聚看點(diǎn)】flutter系列之:在flutter中使用相機(jī)拍攝照片

發(fā)稿時(shí)間:2023-04-06 18:28:03 來源: 騰訊云

簡介

在app中使用相機(jī)肯定是再平常不過的一項(xiàng)事情了,相機(jī)肯定涉及到了底層原生代碼的調(diào)用,那么在flutter中如何快速簡單的使用上相機(jī)的功能呢?

一起來看看吧。


(資料圖片僅供參考)

使用相機(jī)前的準(zhǔn)備工作

flutter中為使用camera提供了一個(gè)叫做camera的插件,我們首先需要安裝這個(gè)插件。

安裝插件的步驟很簡單,如下所示:

flutter pub add camera  

該命令會(huì)在pubspec.xml中添加下面的內(nèi)容:

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

除了camera之外,我們還需要對(duì)照相機(jī)拍攝的照片進(jìn)行保存,這樣我們還需要用到path_provider和path這兩個(gè)plugin。

我們使用同樣的方式對(duì)這兩個(gè)插件進(jìn)行安裝。

安裝好之后,我們就可以在flutter中的代碼中愉快的使用camera了。

在使用camera之前,我們還需要獲取相應(yīng)的權(quán)限信息,比如在IOS中,我們需要在 ios/Runner/Info.plist中添加下面的權(quán)限信息:

NSCameraUsageDescriptionflutter需要用到你的照相機(jī)

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

在flutter中使用camera

camera插件為我們提供了一系列的功能來方便camera的使用。

camera的使用需要遵循下面的步驟,因?yàn)楝F(xiàn)在的手機(jī)可能會(huì)有多個(gè)攝像頭,所以我們需要通過api獲取到可以使用的攝像頭列表。

接下來我們使用選中的攝像頭,進(jìn)行一些控制操作,然后需要使用相應(yīng)的camera視圖來展示相應(yīng)的照相機(jī)圖像.

最后調(diào)用攝像頭相關(guān)的拍攝功能進(jìn)行拍攝。

聽起來好像挺復(fù)雜的,事實(shí)上只要遵照上面的順序,一切都是非常簡單的。

首先我們需要獲取可用的攝像頭列表,這個(gè)步驟是通過調(diào)用camera包中的availableCameras方法來實(shí)現(xiàn)的:

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

availableCameras是一個(gè)異步方法,返回的是一個(gè)Future對(duì)象,其中的值是CameraDescription列表。

CameraDescription是對(duì)camera的描述文件:

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

name是攝像頭的名稱,lensDirection是攝像頭面對(duì)的方向,sensorOrientation是傳感器的方向,也就說你的手機(jī)是正常放置,還是選擇90度放置。

因?yàn)閍vailableCameras是一個(gè)異步方法,所以我們需要把它包裹在一個(gè)異步方法中進(jìn)行調(diào)用:

Future main() async {  // 保證所有的插件都加載完畢  WidgetsFlutterBinding.ensureInitialized();  //獲取攝像頭列表  final cameras = await availableCameras();  //拿到第一個(gè)攝像頭  final firstCamera = cameras.first;  ....

這里我們拿到了第一個(gè)攝像頭,注意,這里的firstCamera是一個(gè)CameraDescription對(duì)象。

因?yàn)槟M器上沒有攝像頭,如果你是在模擬器上運(yùn)行上面的程序的話,將會(huì)拋出下面的異常:

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

為了對(duì)這個(gè)camra進(jìn)行控制, 我們需要?jiǎng)?chuàng)建一個(gè)CameraController對(duì)象:

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的構(gòu)造函數(shù)需要一個(gè)CameraDescription對(duì)象和分辨率等信息,并且還需要進(jìn)行初始化,這里我們調(diào)用了它的initialize方法。

這里的initialize方法也是一個(gè)異步方法。

為了在CameraController初始化之后再對(duì)Camera進(jìn)行使用,我們需要在返回的widget中使用FutureBuilder來構(gòu)建:

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

具體要展示什么內(nèi)容呢?這里使用的是camera包中自帶的CameraPreview組件。

CameraPreview需要傳入一個(gè)CameraController對(duì)象,也就是之前我們創(chuàng)建的對(duì)象。

最后就是調(diào)用CameraController的方法進(jìn)行拍照了。我們把拍照的邏輯放在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),      )

具體的邏輯就是調(diào)用controller.takePicture方法進(jìn)行拍照。將拍好照的image放在一個(gè)新的widget中展示。

總結(jié)

攝像頭是app中常用的功能,flutter中的camera插件為我們提供了攝像頭的控制功能,非常簡單。

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

標(biāo)簽:

責(zé)任編輯:mb01

網(wǎng)站首頁 | 關(guān)于我們 | 免責(zé)聲明 | 聯(lián)系我們

生活晚報(bào)網(wǎng)版權(quán)所有

Copyright @ 1999-2017 m.islamic-portal.net All Rights Reserved豫ICP備2022016495號(hào)-7

聯(lián)系郵箱:939 674 669@qq.com    

日日噜噜噜夜夜爽亚洲精品_欧美视频在线观看一区_久久久久久久久久久久久久久99_成人在线视频网站_国产丝袜美腿一区二区三区_亚洲黄页视频免费观看_国产成+人+综合+亚洲欧洲_日韩一级精品视频在线观看_欧美激情极品视频_亚洲精品国产精品国自产在线
777久久久精品| 日韩一区二区电影| 777精品伊人久久久久大香线蕉| 91婷婷韩国欧美一区二区| 精品国产一区a| 日韩av电影免费观看高清完整版在线观看| 色悠悠久久综合| 欧美一区在线视频| 99热99精品| 日本一区二区三区四区| 99久久精品免费观看| 中文字幕第一区二区| 久久久久久9999| 一级中文字幕一区二区| 欧美视频在线不卡| 亚洲一区二区三区四区五区中文| 久久久精品国产免费观看同学| 欧美精品丝袜中出| 国产欧美精品在线观看| 久久久久久久久久美女| 日韩高清在线观看| 日韩天堂在线观看| 亚洲最大成人综合| 亚洲第一成人在线| 在线不卡中文字幕播放| 激情综合色播五月| 久久国产人妖系列| 91丨porny丨国产| 色综合天天综合在线视频| 欧美亚洲免费在线一区| 亚洲成人三级小说| 91丨国产丨九色丨pron| 日韩欧美亚洲国产精品字幕久久久| 国产日本欧洲亚洲| 国产中文字幕精品| 麻豆国产精品视频| 久久99精品国产.久久久久久 | 中文字幕一区二区三区四区不卡 | 6080午夜不卡| 黄色日韩网站视频| 日本久久精品电影| 欧美理论片在线| 欧美精品一区二区精品网| 色狠狠综合天天综合综合| 国产综合久久久久影院| 亚洲动漫第一页| 欧美一区二区在线看| 欧美一区二区在线播放| 欧美韩日一区二区三区| 欧美日韩精品综合在线| 五月激情六月综合| 日韩精品中文字幕一区| 国产成人精品影视| 国产精品理论片| 久久精品在线免费观看| www.欧美日韩| 日本欧美肥老太交大片| 国产精品成人一区二区三区夜夜夜| 欧美在线不卡一区| 国产成人鲁色资源国产91色综| jiyouzz国产精品久久| 国产视频911| 麻豆精品视频在线观看视频| 欧美日韩精品欧美日韩精品一 | 日韩欧美一区在线| 亚洲精品乱码久久久久久久久| 一区二区三区在线观看动漫| 日韩欧美精品在线视频| 日韩和欧美一区二区三区| 亚洲一区二区综合| 国产精品看片你懂得| 99天天综合性| 91福利国产精品| 午夜不卡在线视频| 欧美sm极限捆绑bd| 国产91精品一区二区| 亚洲精品日产精品乱码不卡| 欧美日韩综合色| 国产美女一区二区三区| 亚洲欧美区自拍先锋| 91精品国产综合久久久久| 国产乱子伦视频一区二区三区| 国产精品久久久久久久久久久免费看 | 国产精品一区一区| 伊人婷婷欧美激情| 久久男人中文字幕资源站| 欧美中文字幕一区二区三区亚洲 | 日本中文字幕一区二区视频| 国产精品久久久久一区二区三区| 欧美精品日韩一本| av在线免费不卡| 久久爱www久久做| 亚洲综合精品自拍| 国产精品三级电影| 精品国产亚洲在线| 91精品国产色综合久久ai换脸| 波多野结衣91| 成人一区二区三区视频 | 91久久精品国产91性色tv| 国产精品99久久久久久久vr| 午夜a成v人精品| 亚洲国产成人tv| 亚洲伊人伊色伊影伊综合网 | 欧美激情中文字幕一区二区| 日韩免费看的电影| 日韩欧美色综合网站| 3atv一区二区三区| 91麻豆精品国产91久久久久| 欧美在线观看一区二区| 色乱码一区二区三区88| 91片黄在线观看| 99久久综合国产精品| 99精品欧美一区二区三区小说| 国产大陆a不卡| 国产一区在线观看视频| 精品系列免费在线观看| 国产一级精品在线| 国产精品亲子乱子伦xxxx裸| 99久久综合狠狠综合久久| 成人精品一区二区三区四区| 成人在线综合网| 不卡一区二区在线| 91免费精品国自产拍在线不卡| 91看片淫黄大片一级在线观看| 色系网站成人免费| 制服丝袜中文字幕亚洲| 欧美精品一区二区三区很污很色的 | 777午夜精品免费视频| 欧美欧美欧美欧美首页| 91精品国产综合久久婷婷香蕉| 日韩欧美国产一区二区在线播放| 久久综合久久综合九色| 久久久99精品免费观看| 中文字幕制服丝袜一区二区三区| 一区二区国产盗摄色噜噜| 日韩国产欧美在线播放| 国产在线日韩欧美| 99久久免费国产| 欧美一区二区在线播放| 国产精品麻豆一区二区 | 成人福利电影精品一区二区在线观看| 国产电影一区在线| 欧美另类高清zo欧美| 中文字幕国产一区| 五月激情六月综合| 懂色av中文一区二区三区| 欧美在线一二三四区| 欧美一区二区三区系列电影| 综合电影一区二区三区 | 欧美性受xxxx黑人xyx| 国产三级欧美三级日产三级99| 亚洲精品视频在线看| 国产精品一区免费在线观看| 宅男在线国产精品| 亚洲免费av高清| 丁香另类激情小说| 日韩三级视频在线看| 亚洲一区二区精品视频| 国产美女视频91| 日韩一级二级三级精品视频| 亚洲国产成人av好男人在线观看| 成人性生交大片| 国产日韩欧美精品在线| 久久电影国产免费久久电影| 欧美日韩精品欧美日韩精品一| 综合在线观看色| 不卡av在线网| 国产精品天干天干在线综合| 免费观看在线色综合| 欧美日韩高清影院| 亚洲成av人片一区二区| 欧美性生交片4| 亚洲国产乱码最新视频| 色噜噜狠狠成人网p站| 日韩伦理av电影| 91啪亚洲精品| 亚洲地区一二三色| 欧美日本精品一区二区三区| 午夜精品一区二区三区三上悠亚| 欧美色网站导航| 强制捆绑调教一区二区| 日韩免费视频一区| 成人性生交大片免费看在线播放| 国产精品国产三级国产有无不卡| 成人性生交大片| 一区二区三区四区不卡在线| 欧美日韩成人一区二区| 日韩精品一区第一页| 日韩欧美一区在线| 国产综合色产在线精品 | 国产欧美一区二区三区鸳鸯浴| 国产sm精品调教视频网站| 国产精品福利在线播放| av电影天堂一区二区在线| 自拍偷自拍亚洲精品播放| 在线亚洲人成电影网站色www| 五月天一区二区三区| 久久精品人人做| 日本乱码高清不卡字幕| 国产一区高清在线|