簡介
在app中使用相機肯定是再平常不過的一項事情了,相機肯定涉及到了底層原生代碼的調(diào)用,那么在flutter中如何快速簡單的使用上相機的功能呢?
一起來看看吧。
(資料圖片僅供參考)
使用相機前的準備工作
flutter中為使用camera提供了一個叫做camera的插件,我們首先需要安裝這個插件。
安裝插件的步驟很簡單,如下所示:
flutter pub add camera
該命令會在pubspec.xml中添加下面的內(nèi)容:
dependencies: flutter: sdk: flutter camera: ^0.10.0+1
除了camera之外,我們還需要對照相機拍攝的照片進行保存,這樣我們還需要用到path_provider和path這兩個plugin。
我們使用同樣的方式對這兩個插件進行安裝。
安裝好之后,我們就可以在flutter中的代碼中愉快的使用camera了。
在使用camera之前,我們還需要獲取相應的權限信息,比如在IOS中,我們需要在 ios/Runner/Info.plist中添加下面的權限信息:
NSCameraUsageDescription flutter需要用到你的照相機
在andorid中需要配合minSdkVersion>=21來使用。
在flutter中使用camera
camera插件為我們提供了一系列的功能來方便camera的使用。
camera的使用需要遵循下面的步驟,因為現(xiàn)在的手機可能會有多個攝像頭,所以我們需要通過api獲取到可以使用的攝像頭列表。
接下來我們使用選中的攝像頭,進行一些控制操作,然后需要使用相應的camera視圖來展示相應的照相機圖像.
最后調(diào)用攝像頭相關的拍攝功能進行拍攝。
聽起來好像挺復雜的,事實上只要遵照上面的順序,一切都是非常簡單的。
首先我們需要獲取可用的攝像頭列表,這個步驟是通過調(diào)用camera包中的availableCameras方法來實現(xiàn)的:
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是一個異步方法,所以我們需要把它包裹在一個異步方法中進行調(diào)用:
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進行控制, 我們需要創(chuàng)建一個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的構造函數(shù)需要一個CameraDescription對象和分辨率等信息,并且還需要進行初始化,這里我們調(diào)用了它的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()); } }, )
具體要展示什么內(nèi)容呢?這里使用的是camera包中自帶的CameraPreview組件。
CameraPreview需要傳入一個CameraController對象,也就是之前我們創(chuàng)建的對象。
最后就是調(diào)用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), )
具體的邏輯就是調(diào)用controller.takePicture方法進行拍照。將拍好照的image放在一個新的widget中展示。
總結
攝像頭是app中常用的功能,flutter中的camera插件為我們提供了攝像頭的控制功能,非常簡單。
本文的例子:https://github.com/ddean2009/learn-flutter.git
標簽:
- 【聚看點】flutter系列之:在flutter中使用相機拍攝照片
- 汝南縣委宣傳部開展“傳承紅色基因·清明祭英烈”主題活動 今日最新
- 焦點日報:西安烈士陵園回應剛獻的花束被保潔收走:會反映處理
- 上海有全國首家“安樂死”醫(yī)院?安寧療護醫(yī)生:太多人有誤解 每日快報
- 足協(xié)取消欠薪俱樂部注冊資格
- 今日要聞!日本暴發(fā)禽流感1740萬只雞被撲殺 被撲殺死禽已無處可埋
- 【世界報資訊】郵儲銀行北京分行攜手北京如易行公司推出“1分錢乘地鐵”活動 助力美好出行
- 《愛情而已》明白一件事,姐弟戀的關鍵在“弟”不在“姐”
- 北京市中小學科技教育示范學校名單出爐,241所學校入選
- “環(huán)西自行車挑戰(zhàn)賽”首次落地中國,北京昌平站已開啟報名 天天熱訊
- 北京今明兩天北風主場!周末氣溫明顯回升
- 環(huán)球觀點:中紀委典型案例!“碩鼠”徐寶義今日受審
- 今日熱文:工行宿遷分行多舉措提升制造業(yè)服務質效
- 環(huán)球快報:工行宿遷分行發(fā)揮科技賦能助力地方“四化”同步集成改革
- 農(nóng)發(fā)行安順分行:開展“賡續(xù)英烈精神汲取奮進力量”主題黨日活動
- 【全球快播報】情系教育 愛心幫扶——蘇陜聯(lián)合舉辦“小海豚計劃”公益活動
- 農(nóng)發(fā)行瀏陽市支行:履行政策性金融職能 走好普惠小微萬里路|每日精選
- 世界頭條:今日匯市觀察:美元指數(shù)上漲至101.98 澳洲聯(lián)儲在8月份前可能都將按兵不動 五大貨幣最新技術分析
- 開發(fā)商回應山西晉城一小區(qū)外墻掉落:系大風影響
- 北京免費海葬排到2025年 海葬是將骨灰放進降解罐沉入水_焦點訊息
- 全球觀焦點:廠家稱蜂蜜罐兩個生產(chǎn)日期系外包裝重新處理啟用
- 上百人進山挖黃金?官方:挖的是昆蟲,當?shù)厝朔Q為“土黃金”|天天快訊
- 普京:立場不同,俄美關系正處于嚴重危機之中
- 露營必備:青島白啤遇上櫻花季 滿滿儀式感 全球速看料
- 【世界時快訊】水鄉(xiāng)周莊:撐一把油紙傘 走進煙雨江南的春天
- 快資訊丨嘉實基金李濤:以信創(chuàng)為突破口,構建循環(huán)經(jīng)濟產(chǎn)業(yè)鏈
- 香港理工大學人工智能機器人實驗室正式啟用 鼓勵科研創(chuàng)新|動態(tài)焦點
- 天天快播:法源寺內(nèi)丁香花如期綻放
- 世界看點:FIFA發(fā)布新一期國家隊排名,國足下滑一位至第81位
- 世界新資訊:賈魏被查
- 1 【世界報資訊】郵儲銀行北京分行攜手北京如易行公司推出“1分錢乘地鐵”活動 助力美好出行
- 2 《愛情而已》明白一件事,姐弟戀的關鍵在“弟”不在“姐”
- 3 北京市中小學科技教育示范學校名單出爐,241所學校入選
- 4 “環(huán)西自行車挑戰(zhàn)賽”首次落地中國,北京昌平站已開啟報名 天天熱訊
- 5 北京今明兩天北風主場!周末氣溫明顯回升
- 6 環(huán)球觀點:中紀委典型案例!“碩鼠”徐寶義今日受審
- 7 露營必備:青島白啤遇上櫻花季 滿滿儀式感 全球速看料
- 8 【世界時快訊】水鄉(xiāng)周莊:撐一把油紙傘 走進煙雨江南的春天
- 9 快資訊丨嘉實基金李濤:以信創(chuàng)為突破口,構建循環(huán)經(jīng)濟產(chǎn)業(yè)鏈
- 10 天天快播:法源寺內(nèi)丁香花如期綻放