当前位置:   article > 正文

Flutter图片与文件选择器_flutter imagepicker

flutter imagepicker

春节已过,今天是开工的第一天。我已经一个多星期没碰过电脑了,今日上班,打开电脑的第一件事就是想着写点什么。反正大家都还沉浸在节后的喜悦中,还没进入工作状态,与其浪费时间,不如做些更有意义的事情。

今天就跟大家简单分享一下Flutter开发过程中经常会用到的图片和文件选择器。

一、image_picker

一个适用于iOS和Android的Flutter插件,能够从图像库中选取图片、视频,还能够调用相机拍摄新的照片。

该插件由Flutter官方提供,github的Star高达16.7k,算是比较成熟且流行的插件了。

1、安装
flutter pub add image_picker
  • 1

或者

/// pubspec.yaml文件添加依赖,并在执行flutter pub get命令
dependencies
  image_picker: ^0.8.6+1
  • 1
  • 2
  • 3
2、使用
import 'package:image_picker/image_picker.dart';

/// 图片选取
Future<void> getImage() async {
    final XFile? file = await ImagePicker().pickImage(
      source: ImageSource.gallery, // 图库选择
      maxWidth: 1000.0, // 设置图片最大宽度,间接压缩了图片的体积
    );

    /// 选取图片失败file为null,要注意判断下。
    /// 获取图片路径后可以上传到服务器上
    print('${file?.path}');
}

/// 视频选取
Future<void> getImage() async {
    final XFile? file = await ImagePicker().pickVideo(
      source: ImageSource.camera, // 调用相机拍摄
    );

    print('${file?.path}');
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22

在项目中,调用getImage方法就会打开图片选择器。

3、属性
  • source

图片来源,ImageSource.gallery图片库中选择,ImageSource.camera调用相机拍摄新图片。

  • maxWidth

图片的最大宽度,source为ImageSource.camera时有用,等于间接的压缩了图片的体积。如果不设置,以目前手机的相机性能,动不动就拍出了4、5M的照片,对于app来说,图片上传到服务端,将会很慢,建议设置此属性。

4、注意

iOS端如果出现闪退并且控制台报出:

The app’s Info.plist must contain an NSPhotoLibraryAddUsageDescription key with a string value explaining to the user how the app uses this data.

那么,需要打开Xcode在Info.plist配置隐私提示语。

二、flutter_document_picker

文档选择器,image_picker只能选择图片和视频,如果要选择PDF,word文档、excel表格等就没办法了。这个时候可以使用flutter_document_picker插件,直接选取手机中的文件。

1、安装
flutter pub add flutter_document_picker
  • 1

或者

/// pubspec.yaml文件添加依赖,并在执行flutter pub get命令
dependencies
  flutter_document_picker: ^5.1.0
  • 1
  • 2
  • 3
2、使用
import 'package:image_picker/image_picker.dart';

/// 图片选取
Future<void> getDocument() async {
    FlutterDocumentPickerParams? params = FlutterDocumentPickerParams(
        // 允许选取的文件拓展类型,不加此属性则默认支持所有类型
        allowedFileExtensions: ['pdf', 'xls', 'xlsx', 'jpg', 'png', 'jpeg'],
    );

    String? path = await FlutterDocumentPicker.openDocument(
      params: params,
    );

    print('$path');
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

总结

image_picker插件用于图片选取,而flutter_document_picker则用于文件选择,在日常开发中都是很常用的。在iOS中使用要注意隐私权限的配置,不然就会闪退。如果想了解更多的参数属性,可以查看官方文档:

image_picker document

flutter_document_picker document

作者:半点橘色
链接:https://juejin.cn/post/7193605274920288317

最后

如果想要成为架构师或想突破20~30K薪资范畴,那就不要局限在编码,业务,要会选型、扩展,提升编程思维。此外,良好的职业规划也很重要,学习的习惯很重要,但是最重要的还是要能持之以恒,任何不能坚持落实的计划都是空谈。

如果你没有方向,这里给大家分享一套由阿里高级架构师编写的《Android八大模块进阶笔记》,帮大家将杂乱、零散、碎片化的知识进行体系化的整理,让大家系统而高效地掌握Android开发的各个知识点。

在这里插入图片描述
相对于我们平时看的碎片化内容,这份笔记的知识点更系统化,更容易理解和记忆,是严格按照知识体系编排的。

### 全套视频资料:

一、面试合集
在这里插入图片描述
二、源码解析合集

在这里插入图片描述
三、开源框架合集

在这里插入图片描述
欢迎大家一键三连支持,若需要文中资料,直接点击文末CSDN官方认证微信卡片免费领取↓↓↓

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/586286
推荐阅读
相关标签
  

闽ICP备14008679号