Flutter 学习之旅 之 flutter 在 Android 端读取相册图片显示
Flutter 学习之旅 之 flutter 在 Android 端读取相册图片显示
目录
Flutter 学习之旅 之 flutter 在 Android 端读取相册图片显示
一、简单介绍
二、简单介绍 image_picker
三、安装 image_picker
四、简单案例实现
五、关键代码
代码说明:
一、简单介绍
Flutter 是一款开源的 UI 软件开发工具包,由 Google 开发和维护。它允许开发者使用一套代码同时构建跨平台的应用程序,包括移动设备(iOS 和 Android)、Web 和桌面平台(Windows、macOS 和 Linux)。
Flutter 使用 Dart 编程语言,它可以将代码编译为 ARM 或 Intel 机器代码以及 JavaScript,从而实现快速的性能。Flutter 提供了一个丰富的预置小部件库,开发者可以根据自己的需求灵活地控制每个像素,从而创建自定义的、适应性强的设计,这些设计在任何屏幕上都能呈现出色的外观和感觉。

二、简单介绍 image_picker
网址:image_picker | Flutter package
image_picker 是 Flutter 中一个非常流行的插件,用于从设备的相册中选择图片或使用相机拍摄新照片。

三、安装 image_picker
1、直接运行命令
使用 Flutter:flutter pub add image_picker

2、或者在 pubspec.yaml 添加
dependencies:image_picker: ^1.1.2

四、简单案例实现
1、这里使用 Android Studio 进行创建 Flutter 项目

2、创建一个 application 的 Flutter 项目

3、工程创建后如下

4、在安卓端添加文件读取权限
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STTORAGE"/>

5、在 lib/main.dart 编写代码实现相册图片显示

6、连接设备,运行设备上的简单效果如下

五、关键代码
import 'dart:io'; // 导入 Dart 的文件操作库,用于处理图片文件import 'package:flutter/material.dart'; // 导入 Flutter 的 Material Design 组件库
import 'package:image_picker/image_picker.dart'; // 导入图片选择器插件void main() {runApp(MyApp()); // 启动应用
}// 定义一个无状态的 MyApp 组件,作为应用的根组件
class MyApp extends StatelessWidget {@overrideWidget build(BuildContext context) {return MaterialApp(title: 'Flutter Photo Picker', // 应用的标题theme: ThemeData(primarySwatch: Colors.blue), // 设置应用的主题颜色为蓝色home: PhotoPickerPage(), // 设置首页为 PhotoPickerPage 组件);}
}// 定义一个有状态的 PhotoPickerPage 组件,用于实现图片选择功能
class PhotoPickerPage extends StatefulWidget {@override_PhotoPickerPageState createState() => _PhotoPickerPageState();
}// 定义 PhotoPickerPage 的状态类,用于管理图片选择的状态
class _PhotoPickerPageState extends State<PhotoPickerPage> {final ImagePicker _picker = ImagePicker(); // 创建一个图片选择器实例XFile? _imageFile; // 定义一个变量,用于存储选择的图片文件// 定义一个异步方法,用于从图库中选择图片Future<void> _pickImage() async {try {// 调用图片选择器的 pickImage 方法,从图库中选择图片final pickedFile = await _picker.pickImage(source: ImageSource.gallery);setState(() {// 更新状态,将选择的图片文件赋值给 _imageFile_imageFile = pickedFile;});} catch (e) {// 捕获异常并打印错误信息print('Error picking image: $e');}}@overrideWidget build(BuildContext context) {return Scaffold(appBar: AppBar(title: Text('选择照片'), // 设置应用栏的标题),body: Column(mainAxisAlignment: MainAxisAlignment.center, // 将子组件垂直居中children: <Widget>[// 设置图片显示区域Container(width: 300, // 设置容器的固定宽度为 300height: 300, // 设置容器的固定高度为 300decoration: BoxDecoration(border: Border.all(color: Colors.grey), // 添加灰色边框,便于观察容器边界),child: _imageFile == null? Center(child: Text('没有选择照片')) // 如果没有选择图片,显示提示文本: ClipRRect(borderRadius: BorderRadius.circular(8), // 添加圆角,半径为 8child: Image.file(File(_imageFile!.path), // 显示选择的图片文件fit: BoxFit.contain, // 设置图片填充方式为完整显示,保持宽高比例),),),SizedBox(height: 20), // 添加一个高度为 20 的间隔ElevatedButton(onPressed: _pickImage, // 点击按钮时调用 _pickImage 方法选择图片child: Text('选择照片'), // 设置按钮的文本),],),);}
}
代码说明:
导入库:
dart:io用于处理文件操作。
flutter/material提供了 Material Design 风格的组件。
image_picker是一个第三方插件,用于从图库或相机中选择图片。MyApp 组件:
作为应用的根组件,配置了应用的基本信息,如标题和主题颜色。
PhotoPickerPage 组件:
一个有状态的组件,用于实现图片选择和显示功能。
_PhotoPickerPageState 状态类:
管理图片选择的状态。
_pickImage方法用于从图库中选择图片,并更新状态。UI 布局:
使用
Scaffold提供应用的基本结构,包括应用栏。使用
Column垂直排列子组件。使用
Container设置图片显示区域的固定大小,并通过ClipRRect添加圆角。使用
BoxFit.contain确保图片完整显示,同时保持宽高比例。按钮功能:
点击按钮时调用
_pickImage方法,从图库中选择图片并更新显示。
六、一些问题说明
1、未能打开相册
问题描述:
尝试打开相册时,应用无法获取权限或无法打开相册界面。
解决方法:
-
确保在
AndroidManifest.xml文件中正确添加了以下权限声明:<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> -
对于 Android 6.0(API 级别 23)及以上版本,需要动态请求权限。可以使用
permission_handler插件来请求运行时权限。 -
检查是否正确初始化了
image_picker插件,并确保调用权限请求的代码逻辑正确。
2、图片选择后未显示
问题描述:
选择图片后,图片未能正确显示在界面上。
解决方法:
-
检查是否正确处理了选择后的返回值。确保在
pickImage方法的回调中正确更新了图片路径。 -
确保图片路径正确,并且图片文件确实存在。例如,可以打印图片路径进行调试。
-
如果使用了
setState更新图片路径,确保路径更新后界面能够正确刷新。 -
如果图片路径是一个文件路径,确保使用
File类加载图片,例如:Image.file(File(_imageFile!.path));
3、安卓版本过低,无法读取图片
问题描述:
在某些低版本的 Android 设备上,图片无法正确读取或显示。
解决方法:
-
确保设备运行的是 Android 4.0(API 级别 14)或更高版本。
-
如果需要支持更低版本的 Android,建议检查
image_picker的版本兼容性,或者使用其他兼容性更好的插件。 -
如果问题依然存在,可以尝试更新
image_picker插件到最新版本,或者查阅官方文档中的相关说明。
在开发过程中,可能会遇到各种问题或错误。以下是一些实用的建议,帮助您更高效地解决问题:
查阅官方文档:
官方文档是解决问题的首要资源。image_picker的官方文档提供了详细的使用方法、配置说明和常见问题解答。
image_picker 官方文档搜索社区论坛:
如果官方文档中没有找到答案,可以尝试搜索 Stack Overflow、GitHub Issues 或其他社区论坛。许多开发者可能已经遇到并解决了类似的问题。
相关文章:
Flutter 学习之旅 之 flutter 在 Android 端读取相册图片显示
Flutter 学习之旅 之 flutter 在 Android 端读取相册图片显示 目录 Flutter 学习之旅 之 flutter 在 Android 端读取相册图片显示 一、简单介绍 二、简单介绍 image_picker 三、安装 image_picker 四、简单案例实现 五、关键代码 代码说明: 一、简单介绍 Fl…...
RagFlow专题二、RagFlow 核心架构(数据检索、语义搜索与知识融合)
深入解析 RagFlow 核心架构:数据检索、语义搜索与知识融合 在前一篇文章中,我们对 RagFlow 的核心理念、与传统 RAG 的区别以及其适用场景进行了深入探讨。我们了解到,RagFlow 通过动态优化检索、增强生成质量以及实时知识管理,使得大模型在复杂任务中的表现更加稳定和高效…...
解决各大浏览器中http地址无权限调用麦克风摄像头问题(包括谷歌,Edge,360,火狐)后续会陆续补充
项目场景: 在各大浏览器中http地址调用电脑麦克风摄像头会没有权限,http协议无法使用多媒体设备 原因分析: 为了用户的隐私安全,http协议无法使用多媒体设备。因为像摄像头和麦克风属于可能涉及重大隐私问题的API,ge…...
【SpringBoot+Vue】博客项目开发二:用户登录注册模块
后端用户模块开发 制定参数交互约束 当前,我们使用MybatisX工具快速生成的代码中,包含了一个实体类,这个类中包含我们数据表中的所有字段。 但因为有些字段,是不应该返回到前端的,比如用户密码,或者前端传…...
(十 二)趣学设计模式 之 享元模式!
目录 一、 啥是享元模式?二、 为什么要用享元模式?三、 享元模式的实现方式四、 享元模式的优缺点五、 享元模式的应用场景六、 总结 🌟我的其他文章也讲解的比较有趣😁,如果喜欢博主的讲解方式,可以多多支…...
leetcode第77题组合
原题出于leetcode第77题https://leetcode.cn/problems/combinations/ 1.树型结构 2.回溯三部曲 递归函数的参数和返回值 确定终止条件 单层递归逻辑 3.代码 二维数组result 一维数组path void backtracking(n,k,startindex){if(path.sizek){result.append(path);return ;}…...
Linux | Ubuntu 与 Windows 双系统安装 / 高频故障 / UEFI 安全引导禁用
注:本文为 “buntu 与 Windows 双系统及高频故障解决” 相关文章合辑。 英文引文,机翻未校。 How to install Ubuntu 20.04 and dual boot alongside Windows 10 如何将 Ubuntu 20.04 和双启动与 Windows 10 一起安装 Dave’s RoboShack Published in…...
Docker入门指南:Windows下docker配置镜像源加速下载
Windows下docker配置镜像源加速下载 docker的官方镜像是海外仓库,默认下载耗时较长,而且经常出现断站的现象,因此需要配置国内镜像源。 国内镜像源概述 国内现有如下镜像源可以使用 "http://hub-mirror.c.163.com", "http…...
web前端基础修炼手册
目录 引言 1. 安装插件 2. 前端三剑客 3. 开发者模式 第一章 HTML 1.文件结构 2. 常见标签 2.1 注释标签 2.2 标题标签 2.3 段落标签 2.4 换行标签 2.5 格式化标签 2.6 图片标签 2.7 超链接标签 2.8 表格标签 2.9 列表标签 2.10 form标签 2.11 input 标签 2.12 la…...
【无标题】Ubuntu22.04编译视觉十四讲slambook2 ch4时fmt库的报错
Ubuntu22.04编译视觉十四讲slambook2 ch4时fmt库的报错 cmake ..顺利,make后出现如下报错: in function std::make_unsigned<int>::type fmt::v8::detail::to_unsigned<int>(int): trajectoryError.cpp:(.text._ZN3fmt2v86detail11to_unsi…...
macos下myslq图形化工具之Sequel Ace
什么是Sequel Ace 官方github:https://github.com/Sequel-Ace/Sequel-Ace Sequel Ace 是一款快速、易于使用的 Mac 数据库管理应用程序,用于处理 MySQL 和 MariaDB 数据库。 Sequel Ace 是一款开源项目,采用 MIT 许可证。用户可以通过 Ope…...
【AHK】资源管理器自动化办公实例/自动连点设置
此处为一个自动连续点击打开检查的自动化操作案例,没有quicker的鼠键录制,不常用了,做个备份 #MaxThreadsPerHotkey 2 ; 这个是核心!!!!确保可以同时运行多个热键或标签global isRunning : tru…...
通用查询类接口数据更新的另类实现
文章目录 一、简要概述二、java工程实现1. 定义main方法2. 测试运行3. 源码放送 一、简要概述 我们在通用查询类接口开发的另类思路中,关于接口数据的更新,提出了两种方案: 文件监听 #mermaid-svg-oJQjD6jQ8T19XlHA {font-family:"tre…...
Linux ls 命令
Linux ls(英文全拼: list directory contents)命令用于显示指定工作目录下之内容(列出目前工作目录所含的文件及子目录)。 语法 ls [-alrtAFR] [name...] 参数 : -a 显示所有文件及目录 (. 开头的隐藏文件也会列出)-d 只列出目…...
【问题记录】Go项目Docker中的consul访问主机8080端口被拒绝
【问题记录】Go项目Docker中的consul访问主机8080端口被拒绝 问题展示解决办法 问题展示 在使用docker中的consul服务的时候,通过命令行注册相应的服务(比如cloudwego项目的demo_proto以及user服务)失败。 解决办法 经过分析,是…...
面试题:说一下你对DDD的了解?
面试题:说一下你对DDD的了解? 在面试中,关于 DDD(领域驱动设计,Domain-Driven Design) 的问题是一个常见的技术考察点。DDD 是一种软件设计方法论,旨在通过深入理解业务领域来构建复杂的软件系统。以下是一个清晰、详细的回答模板,帮助你在面试中脱颖而出: DDD 的定义…...
React低代码项目:问卷编辑器 I
问卷编辑器 Date: February 20, 2025 4:17 PM (GMT8) 目标 完成问卷编辑器的设计和开发完成复杂系统的 UI 组件拆分完成复杂系统的数据结构设计 内容 需求分析技术方案设计开发 注意事项: 需求指导设计,设计指导开发。前两步很重要页面复杂的话&…...
蓝桥杯2024年真题java B组 【H.拼十字】
蓝桥杯2024年真题java B组 【H.拼十字】 原题链接:拼十字 思路: 使用树状数组或线段树解决。 先将输入的信息存入到一个n行3列的数组中,将信息排序,按照长度小到大,长相同时,宽度小到大 排序。 建立三个…...
Spring MVC 程序开发(1)
目录 1、什么是 SpringMVC2、返回数据2.1、返回 JSON 对象2.2、请求转发2.3、请求重定向2.4、自定义返回的内容 1、什么是 SpringMVC 1、Tomcat 和 Servlet 分别是什么?有什么关系? Servlet 是 java 官方定义的 web 开发的标准规范;Tomcat 是…...
PyCharm接入本地部署DeepSeek 实现AI编程!【支持windows与linux】
今天尝试在pycharm上接入了本地部署的deepseek,实现了AI编程,体验还是很棒的。下面详细叙述整个安装过程。 本次搭建的框架组合是 DeepSeek-r1:1.5b/7b Pycharm专业版或者社区版 Proxy AI(CodeGPT) 首先了解不同版本的deepsee…...
UE5场景漫游跳转避坑指南:从UI交互到资源预热
1. 这不是“做个UI跳个关卡”那么简单:UE5场景漫游的起点陷阱 很多人拿到“UE5场景漫游——开始界面及关卡跳转”这个需求,第一反应是:“不就是加个UMG按钮,绑个OpenLevel节点?”我去年带三个实习生做文旅数字孪生项目…...
1987年4月26日下午15-17点出生性格、运势和命运
1987年4月24日晚上出生的人,如今已步入38岁的门槛。在职业生涯中,这是一个承上启下的关键阶段——既脱离了职场新人的青涩,又尚未到达管理者或专家的巅峰位置。从非命理的角度分析,他们的事业运势与时代变迁、个人选择和社会结构密…...
保姆级教程:用Ansys Zemax从零设计一个汽车HUD(附挡风玻璃反射优化技巧)
从零开始用Ansys Zemax设计汽车HUD:避坑指南与实战技巧 在汽车智能化浪潮中,抬头显示系统(HUD)正从高端车型的选配逐渐成为主流配置。对于光学工程师而言,掌握HUD设计能力已成为职业发展的关键技能。本文将带你从零开始…...
CANN/pypto PASS组件错误码说明
PASS 组件错误码说明文档 【免费下载链接】pypto PyPTO(发音: pai p-t-o):Parallel Tensor/Tile Operation编程范式。 项目地址: https://gitcode.com/cann/pypto 范围:F40000-F44002本文档说明 PASS 组件的错误码定义、场…...
透明化智慧港口码头•装载·存储·集散全流程透明化管控方案
一、方案前言本方案依托黎阳之光镜像孪生、时空AI拓扑、无感全域定位、视频实景融合、边缘实时算力五大核心技术,聚焦港口码头货物装载、堆场存储、集疏运集散三大核心业务,打造实景可视、数字镜像、智能调度、全程透明、风险可控、全程可溯的智慧管控体…...
ZFX山海证券:“消费转向考验零售韧性”
ZFX山海证券:“消费转向考验零售韧性”Target观察到顾客行为出现意外变化,说明通胀和家庭预算压力仍在影响零售消费结构,ZFX山海证券认为,消费者更重视价格和必需品,正在压缩可选品类的增长空间。零售商需要在促销、库…...
GanttProject终极指南:免费开源的项目管理工具完全攻略
GanttProject终极指南:免费开源的项目管理工具完全攻略 【免费下载链接】ganttproject Official GanttProject repository. 项目地址: https://gitcode.com/gh_mirrors/ga/ganttproject GanttProject是一款功能强大的免费开源项目管理软件,通过直…...
技术人的人际关系:建立良好的职业网络
技术人的人际关系:建立良好的职业网络 引言 作为一名技术人,人际关系同样重要。良好的人际关系可以帮助我们获得更多机会,提升职业发展。 今天就来分享一下如何建立良好的职业网络。 为什么人际关系重要 职业发展 良好的人际关系有助于职业发…...
意识的“调谐客观还原”理论
“调谐客观还原”理论,通常称为 Orch-OR,是诺贝尔物理学奖得主罗杰彭罗斯与麻醉学家斯图尔特哈梅罗夫于20世纪90年代初提出的一种极具争议的意识假说。该理论的核心观点是:意识并非产生于神经元之间的经典电化学连接,而是源于神经…...
Java 程序员第 24 阶段:多 Agent 高阶实战,复杂业务场景完整落地实现
在多 Agent 基础篇中,我们探讨了角色协同、任务拆分的基本模式。本文进一步深入,聚焦高阶架构设计、跨服务协作与复杂场景完整落地,帮助读者构建生产级别的多 Agent 系统。一、高阶架构:从简单协同到生产级系统1.1 三层架构模型成…...
