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…...
反向工程与模型迁移:打造未来商品详情API的可持续创新体系
在电商行业蓬勃发展的当下,商品详情API作为连接电商平台与开发者、商家及用户的关键纽带,其重要性日益凸显。传统商品详情API主要聚焦于商品基本信息(如名称、价格、库存等)的获取与展示,已难以满足市场对个性化、智能…...

从WWDC看苹果产品发展的规律
WWDC 是苹果公司一年一度面向全球开发者的盛会,其主题演讲展现了苹果在产品设计、技术路线、用户体验和生态系统构建上的核心理念与演进脉络。我们借助 ChatGPT Deep Research 工具,对过去十年 WWDC 主题演讲内容进行了系统化分析,形成了这份…...

基于ASP.NET+ SQL Server实现(Web)医院信息管理系统
医院信息管理系统 1. 课程设计内容 在 visual studio 2017 平台上,开发一个“医院信息管理系统”Web 程序。 2. 课程设计目的 综合运用 c#.net 知识,在 vs 2017 平台上,进行 ASP.NET 应用程序和简易网站的开发;初步熟悉开发一…...
基于服务器使用 apt 安装、配置 Nginx
🧾 一、查看可安装的 Nginx 版本 首先,你可以运行以下命令查看可用版本: apt-cache madison nginx-core输出示例: nginx-core | 1.18.0-6ubuntu14.6 | http://archive.ubuntu.com/ubuntu focal-updates/main amd64 Packages ng…...

STM32F4基本定时器使用和原理详解
STM32F4基本定时器使用和原理详解 前言如何确定定时器挂载在哪条时钟线上配置及使用方法参数配置PrescalerCounter ModeCounter Periodauto-reload preloadTrigger Event Selection 中断配置生成的代码及使用方法初始化代码基本定时器触发DCA或者ADC的代码讲解中断代码定时启动…...

NFT模式:数字资产确权与链游经济系统构建
NFT模式:数字资产确权与链游经济系统构建 ——从技术架构到可持续生态的范式革命 一、确权技术革新:构建可信数字资产基石 1. 区块链底层架构的进化 跨链互操作协议:基于LayerZero协议实现以太坊、Solana等公链资产互通,通过零知…...

让AI看见世界:MCP协议与服务器的工作原理
让AI看见世界:MCP协议与服务器的工作原理 MCP(Model Context Protocol)是一种创新的通信协议,旨在让大型语言模型能够安全、高效地与外部资源进行交互。在AI技术快速发展的今天,MCP正成为连接AI与现实世界的重要桥梁。…...

【JavaWeb】Docker项目部署
引言 之前学习了Linux操作系统的常见命令,在Linux上安装软件,以及如何在Linux上部署一个单体项目,大多数同学都会有相同的感受,那就是麻烦。 核心体现在三点: 命令太多了,记不住 软件安装包名字复杂&…...

使用 SymPy 进行向量和矩阵的高级操作
在科学计算和工程领域,向量和矩阵操作是解决问题的核心技能之一。Python 的 SymPy 库提供了强大的符号计算功能,能够高效地处理向量和矩阵的各种操作。本文将深入探讨如何使用 SymPy 进行向量和矩阵的创建、合并以及维度拓展等操作,并通过具体…...

如何更改默认 Crontab 编辑器 ?
在 Linux 领域中,crontab 是您可能经常遇到的一个术语。这个实用程序在类 unix 操作系统上可用,用于调度在预定义时间和间隔自动执行的任务。这对管理员和高级用户非常有益,允许他们自动执行各种系统任务。 编辑 Crontab 文件通常使用文本编…...