国产精品久久福利_亚洲成人网久久久_国产丝袜美腿一区二区三区_亚洲三级小视频_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 m.gaofoto.cn All Rights Reserved豫ICP備2022016495號-7

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

国内精品免费在线观看| caoporn97免费视频公开| 成人黄色免费短视频| 日韩欧美一级二级| 欧美一区二区三区啪啪| 国产大学生校花援交在线播放| 欧美成人艳星乳罩| 日韩经典一区二区三区| 黄网站色大毛片| 国产小视频福利在线| 26uuu国产电影一区二区| 香蕉久久夜色精品国产使用方法 | 亚洲成人人体| 伊人久久大香线蕉精品组织观看| 国产精品激情电影| 久久国产精品成人免费观看的软件| www.久久久久爱免| 伊人色综合一区二区三区影院视频| 日本综合在线| av在线电影院| 亚洲黄色网址| 日本福利小视频| 亚洲国产日韩a在线播放| 99精品欧美| 国产乱人伦丫前精品视频| 国产美女在线观看| 色综合天天色| 日韩国产一区| 欧美精品1区| 麻豆国产精品官网| 亚洲国产精品自拍| 黄页视频在线免费观看| 欧美大片网址| 国产精品午夜免费| 国产视频资源| 国产欧美久久久久久久久| 亚洲男人av| www.久久爱.com| 在线成人国产| 亚洲天堂a在线| 欧美大片日本大片免费观看| 欧美精品一二三区| 99久久国产免费看| 九一九一国产精品| av成人国产| 99在线精品视频在线观看| 欧美一区二区三区久久精品茉莉花| aaa亚洲精品一二三区| 欧美午夜精品久久久| 日韩午夜在线观看| 国内福利写真片视频在线| 国产一区二区三区朝在线观看| 国产精品久久久久久久久久妞妞| 日韩精品在线看| 国产精品二区影院| 国产一级电影网| av不卡在线| 亚洲成人精品视频在线观看| aiai在线| 欧美a级片视频| 国产美女久久久久| 欧美www视频| 国产黄在线播放| 九九在线精品| 日韩av在线发布| 久久综合导航| 高清国产一区二区| 亚洲情趣在线观看| 欧美日韩国产a| 亚洲欧美中文另类| 日本在线天堂| 国产真实乱子伦精品视频| 欧美喷潮久久久xxxxx| 亚洲一区二区三区美女| 7878视频在线观看| 亚洲精品成人影院| 在线观看区一区二| 2021年精品国产福利在线| 亚洲第一在线视频| 久久久精品午夜少妇| 日av在线播放| 亚洲精品视频在线| 国产劲爆久久| 91精品在线麻豆| 久久99免费视频| 久久久亚洲精品石原莉奈 | 99久久婷婷国产| 伊人av免费在线观看| 88国产精品视频一区二区三区| 免费视频一区二区| 在线观看亚洲精品| 亚洲精品v天堂中文字幕| 亚洲影视在线| 免费高清完整在线观看| 国产精品—色呦呦| 福利一区福利二区| 樱桃视频成人在线观看| 亚洲天堂精品视频| 日韩欧美一级二级三级| 一级毛片久久久| 亚洲国产成人tv| 日韩成人精品一区二区三区| 亚洲日韩中文字幕| 国产精品不卡在线| 日本人妖一区二区| 久久精品66| 国产三级av在线| 久久综合久久99| 亚洲欧洲免费| 亚洲欧洲免费视频| 麻豆91精品视频| 黄页网站在线播放| av不卡一区二区三区| 99re6在线精品视频免费播放| 成人深夜视频在线观看| 精品免费av一区二区三区| 91丝袜美腿高跟国产极品老师| 中文字幕在线视频区| 美女一区二区久久| 偷偷www综合久久久久久久| 伊人色综合网| av电影在线观看完整版一区二区| av资源网在线播放| 亚洲电影激情视频网站| 国产亚洲成av人片在线观黄桃| 久久中文在线| 一区二区精品伦理...| 色狠狠色狠狠综合| 精品高清久久| 中文字幕成人| heyzo高清在线| 午夜成人影视| 精品资源在线看| 91精品国产一区二区人妖| 91偷拍与自偷拍精品| 成人免费观看49www在线观看| 日韩精品视频在线观看网址 | 国产精品大片| eeuss影院在线观看| 天堂av一区| 日日噜噜噜夜夜爽爽狠狠| 亚洲经典在线看| 欧美一区二区成人| 国产成人亚洲综合色影视| 黄色另类av| 国产精品色婷婷在线观看| 亚洲精品之草原avav久久| 国内精品久久久久影院薰衣草| 3d性欧美动漫精品xxxx软件| 3344永久| 五月天丁香久久| 国产91在线视频蝌蚪| 一级日本不卡的影视| 久久成人免费网站| 国产精品极品| 外国成人直播| 新欧美整片sss第一页| 日韩视频在线永久播放| av在线播放不卡| 欧美gayvideo| av2020不卡| 婷婷综合在线观看| 激情综合网最新| 校园春色另类视频| 免费av在线| 一个人免费视频www在线观看| 国产精品一级在线| 国产一区二区三区四区五区3d| 伪装者在线观看完整版免费| 精品国偷自产国产一区| 丰满白嫩尤物一区二区| 久久99高清| 伊人久久国产| 日韩在线精品强乱中文字幕| 亚洲福利合集| 永久www成人看片| 欧美一区2区视频在线观看| 91久久精品国产91性色tv| 国产婷婷一区二区| 欧美人成在线观看ccc36| 欧美精品三级在线观看| 亚洲一区自拍偷拍| 一区二区欧美在线观看| 成人av网址在线| 久久嫩草精品久久久精品| 天天色天天爱天天射综合| 欧美色倩网站大全免费| 一级黄色av| 毛片免费在线观看| 日本一本草久在线中文| 中文字幕在线观看网站| 97视频免费| 亚洲精品一区二区三区蜜桃下载| 欧美性猛交xxxx富婆弯腰| 91偷拍与自偷拍精品| 99精品视频免费观看视频| 先锋资源久久| 亚洲激情影院| 日本aⅴ亚洲精品中文乱码| 欧美专区18|