欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Android?Flutter如何使用相機實現拍攝照片

 更新時間:2023年04月06日 08:25:35   作者:flydean  
在app中使用相機肯定是再平常不過的一項事情了,相機肯定涉及到了底層原生代碼的調用,那么在flutter中如何快速簡單的使用上相機的功能呢?一起來看看吧

簡介

在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中添加下面的權限信息:

<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進行控制, 我們需要創(chuàng)建一個CameraController對象:

class CameraAppState extends State<CameraApp> {
  late CameraController _controller;
  late Future<void> _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<void>(
        future: _initializeControllerFuture,
        builder: (context, snapshot) {
          if (snapshot.connectionState == ConnectionState.done) {
            return CameraPreview(_controller);
          } else {
            return const Center(child: CircularProgressIndicator());
          }
        },
      )

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

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

最后就是調用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

到此這篇關于詳解Android Flutter如何使用相機實現拍攝照片的文章就介紹到這了,更多相關Android Flutter相機拍攝照片內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Android Studio Gradle插件版本與Gradle版本之間的對應關系

    Android Studio Gradle插件版本與Gradle版本之間的對應關系

    今天小編就為大家分享一篇關于Android Studio Gradle插件版本與Gradle版本之間的對應關系,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • Android開發(fā)中多進程共享數據簡析

    Android開發(fā)中多進程共享數據簡析

    這篇文章主要為大家簡單分析Android開發(fā)中多進程共享數據,怎么做才能讓這兩邊共享數據,感興趣的小伙伴們可以參考一下
    2016-04-04
  • Android自定義折線圖控件的完整步驟

    Android自定義折線圖控件的完整步驟

    折線圖是常用的圖表之一,最近的工作中又遇到了相關的需求,所以下面這篇文章主要給大家介紹了關于Android自定義折線圖控件的完整步驟,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-06-06
  • 給大家分享一些安卓自學心得

    給大家分享一些安卓自學心得

    本文是筆者在學習安卓開發(fā)的過程中的一些經驗之談的分享,希望對大家學習安卓開發(fā)能夠有所幫助。
    2015-12-12
  • 淺談RecyclerView(完美替代ListView,GridView)

    淺談RecyclerView(完美替代ListView,GridView)

    RecyclerView絕對是一款功能強大的控件,涵蓋了ListView,GridView,瀑布流等數據表現的形式。本文對其進行系統介紹,有需要的朋友可以看下
    2016-12-12
  • 解析Android開發(fā)優(yōu)化之:對界面UI的優(yōu)化詳解(三)

    解析Android開發(fā)優(yōu)化之:對界面UI的優(yōu)化詳解(三)

    本篇文章主要討論一下復雜界面中常用的一種技術——界面延遲加載技術
    2013-05-05
  • Android實現地理定位功能

    Android實現地理定位功能

    這篇文章主要為大家詳細介紹了Android實現地理定位功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • Flutter模仿實現微信底部導航欄流程詳解

    Flutter模仿實現微信底部導航欄流程詳解

    這篇文章主要介紹了Flutter模仿實現微信底部導航欄流程,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2023-05-05
  • Flutter實現底部導航欄創(chuàng)建詳解

    Flutter實現底部導航欄創(chuàng)建詳解

    ConvexBottomBar是一個底部導航欄組件,用于展現凸起的TAB效果,支持多種內置樣式與動畫交互。本文將利用ConvexBottomBar創(chuàng)建漂亮的底部導航欄,感興趣的可以學習一下
    2022-01-01
  • Android實現文件資源管理器雛形

    Android實現文件資源管理器雛形

    這篇文章主要為大家詳細介紹了Android實現文件資源管理器雛形,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03

最新評論