国产精品久久福利_亚洲成人网久久久_国产丝袜美腿一区二区三区_亚洲三级小视频_6080国产精品一区二区_欧美日韩精品一区二区_欧美第一区第二区_亚洲欧美色婷婷

首頁 | 資訊 | 財經 | 公益 | 彩店 | 奇聞 | 速遞 | 前瞻 | 提點 | 網站相關 | 科技 | 熱點 | 生活 |
【聚看點】flutter系列之:在flutter中使用相機拍攝照片

發稿時間:2023-04-06 18:28:03 來源: 騰訊云

簡介

在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

標簽:

責任編輯:mb01

網站首頁 | 關于我們 | 免責聲明 | 聯系我們

生活晚報網版權所有

Copyright @ 1999-2017 www.gaofoto.cn All Rights Reserved豫ICP備2022016495號-7

聯系郵箱:939 674 669@qq.com    

亚洲超碰精品一区二区| 精品国产乱码久久久久久1区2区| 欧美自拍丝袜亚洲| 亚洲精品国产精品久久清纯直播| 特黄特黄的视频| 国产小视频在线播放| 美女91在线| 成功精品影院| 国产精品激情| 大陆成人av片| 五月激情综合网| 亚洲国产天堂久久综合网| 国产毛片av在线| 久久亚洲精品爱爱| 国产一区二区亚洲| 日av在线不卡| 亚洲精选一二三| 亚洲成人黄色在线观看| 亚洲视频tv| 日韩视频一区二区三区四区| 激情视频一区| 久久综合九色综合欧美98 | caopo在线| 国产一二三区在线| 一区二区三区国产精华| 少女频道在线观看免费播放电视剧| 99精品视频一区| 国模一区二区三区| 亚洲女同中文字幕| 日韩三区免费| 日韩精品免费在线| 日韩激情av在线播放| 日本福利在线| 久久资源综合| 免费成人性网站| 亚洲女性喷水在线观看一区| 亚洲第一av网| av成人 com a| 女人色偷偷aa久久天堂| 91视视频在线观看入口直接观看www | 亚洲精品视频网上网址在线观看 | 6080亚洲理论片在线观看| 亚洲欧美色婷婷| 欧美日韩国产专区| 国产日产高清欧美一区二区三区| 人人九九精品视频| 欧美三级日韩三级国产三级| 69av亚洲| 久久av影视| 91在线观看污| 精品国产91洋老外米糕| a级网站在线播放| 精品日本12videosex| 久久午夜老司机| 精品成人一区二区三区四区| 白白色在线观看| 激情视频一区| 亚洲成人精品影院| 国产免费视频在线| 精品久久久亚洲| 中文字幕在线一区二区三区| 午夜影院免费| 免费看久久久| 国产精品网曝门| 三上悠亚在线免费观看| 国产一区二区三区不卡av| 99国产精品久久久久久久久久| 日韩二区三区在线| 国产精选久久| 91免费观看视频| 全部a∨一极品视觉盛宴| 91大神精品| av一二三不卡影片| 亚洲男人av电影| 欧美理论电影在线精品| 99精品视频一区二区三区| 国产va在线观看| 少妇久久久久| 亚洲一区二区三区四区在线观看 | 狠狠狠色丁香婷婷综合久久五月| 日韩欧美一二三区| 玖玖玖视频精品| 国产三级一区二区三区| 日韩国产福利| 狠狠干成人综合网| 欧美日韩一级片在线观看| 日本在线视频一区二区| av高清不卡在线| 你懂的在线视频| 中文亚洲欧美| 亚洲精品狠狠操| 亚洲国产网址| 欧美午夜无遮挡| av亚洲一区| 国产午夜精品一区二区三区嫩草| 黄色网址在线播放| 羞羞答答国产精品www一本| 7777精品伊人久久久大香线蕉经典版下载| 自拍在线观看| 97超碰欧美中文字幕| 日本天堂在线| 久久一区亚洲| 亚洲色在线视频| 911久久香蕉国产线看观看| 91极品美女在线| 精品伊人久久| 亚洲高清免费视频| 国外成人福利视频| 亚洲人成在线播放网站岛国| 超级碰碰不卡在线视频| 99国产精品久久久久久久久久久| 国产三级在线观看| 琪琪一区二区三区| 濑亚美莉一二区在线视频| 激情一区二区| 亚洲色图第一页| 影音先锋久久资源网| 日韩国产高清污视频在线观看| 欧美日韩一区二区三区视频播放| 色狠狠一区二区三区香蕉| 永久免费精品视频| 欧美性xxxx极品hd满灌| 一区二区在线免费播放| 狠狠久久五月精品中文字幕| www.久久热| 色综合久久88色综合天天| 91欧美极品| 欧美日韩免费一区二区三区视频| 任你弄精品视频免费观看| 欧美精品黑人性xxxx| 精品久久成人| 亚洲国产高清福利视频| 国产综合网站| 91美女在线| 国产一区999| 国产在线更新| 国产欧美日韩在线视频| 五月天av在线| 亚洲成av人片在线| 欧美电影在线观看完整版| 欧美日韩卡一卡二| 国产精品99在线观看| 亚洲色图第一页| 捆绑调教美女网站视频一区| 蝌蚪视频在线播放| av日韩在线网站| 日韩成人亚洲| 在线视频国内自拍亚洲视频| 国产成人调教视频在线观看 | av高清在线| 久久狠狠亚洲综合| 成人无遮挡免费网站视频在线观看 | 91色在线看| 亚洲成av人片www| 精品美女视频| 97影院在线观看| 成人av免费在线播放| 欧美va在线观看| 天天av天天翘天天综合网| 欧洲美女日日| 亚洲精华国产| 久久影院午夜论| 国产色99精品9i| 亚洲国产精品va在线看黑人动漫| 久久男女视频| 国产理论在线| 欧美伊人久久久久久午夜久久久久| 久久中文字幕av一区二区不卡| 三上悠亚在线观看二区| www.视频一区| 精品视频一区二区三区| 日韩精品高清视频| 成人av网址在线观看| 电影中文字幕一区二区| 亚洲黄色www| 国产福利电影一区二区三区| 欧美亚洲韩国| 日韩三级精品电影久久久| 日韩精品久久理论片| 国产资源在线观看入口av| 欧美日韩久久不卡| 日韩av在线发布| 久久xxx视频| 日韩电影视频免费| 久久蜜臀精品av| 国产一区二区三区不卡视频网站 | 一级欧洲+日本+国产| 阿v免费在线观看| 欧美日韩免费在线观看| 在线日本成人| 黄色漫画在线免费看| 日韩精品资源二区在线| 国产福利不卡视频| 亚洲婷婷伊人| av在线1区2区| 欧美乱熟臀69xxxxxx| 丁香六月久久综合狠狠色| 亚洲品质自拍| 国产一二区在线观看| 日韩一区二区免费电影|