首页 > 其他分享 >在Flutter中使用PhotoViewGallery指南

在Flutter中使用PhotoViewGallery指南

时间:2023-12-23 23:37:31浏览次数:40  
标签:指南 缩放 photo PhotoViewComputedScale PhotoViewGallery 图片 Flutter view


介绍

Flutter中的PhotoViewGallery是一个功能强大的插件,用于在应用中展示可缩放的图片。无论是构建图像浏览器、相册应用,还是需要在应用中查看大图的场景,PhotoViewGallery都是一个不错的选择。

添加依赖

首先,需要在pubspec.yaml文件中添加photo_view插件的依赖。打开该文件,然后在dependencies部分添加:

dependencies:
  #https://pub.dev/packages/photo_view
  photo_view: ^0.13.0

保存文件后,在终端运行flutter packages get以获取依赖。

导入库

在你的Dart文件中导入photo_view库:

import 'package:photo_view/photo_view.dart';
import 'package:photo_view/photo_view_gallery.dart';

创建数据源

准备一个包含图片信息的数据源。一个包含图片链接的列表,例如:

List<String> imageUrls = [
      "https://images.pexels.com/photos/1054218/pexels-photo-1054218.jpeg?auto=compress&cs=tinysrgb&w=600",
      "https://ts3.cn.mm.bing.net/th?id=OIP-C.bVb769JBdzVZYuksxZ2Y-AHaEo&w=316&h=197&c=8&rs=1&qlt=90&o=6&dpr=1.2&pid=3.1&rm=2",
      "https://ts3.cn.mm.bing.net/th?id=OIP-C.Md86Wi2EYiKHNPldRZiD4gHaEo&w=316&h=197&c=8&rs=1&qlt=90&o=6&dpr=1.2&pid=3.1&rm=2",
    ];

创建PhotoViewGallery

使用PhotoViewGallery封装数据源,指定一些配置选项:

class MyGallery extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: PhotoViewGallery.builder(
        itemCount: imageList.length,
        builder: (context, index) {
          return PhotoViewGalleryPageOptions(
            imageProvider: NetworkImage(imageList[index]),
            minScale: PhotoViewComputedScale.contained * 0.8,
            maxScale: PhotoViewComputedScale.covered * 2,
          );
        },
        scrollPhysics: BouncingScrollPhysics(),
        backgroundDecoration: BoxDecoration(
          color: Colors.black,
        ),
        pageController: PageController(),
        onPageChanged: (index) {
          // 处理页面切换
        },
      ),
    );
  }
}
PhotoViewGallery属性介绍

在PhotoViewGallery中,可以设置许多属性来自定义其行为和外观。以下是一些常见的属性:

  • itemCount: 数据源的长度,即图片数量。
  • builder: 构建每一页的回调函数,返回一个PhotoViewGalleryPageOptions对象。
  • scrollPhysics: 滑动的物理效果。
  • backgroundDecoration: 背景的装饰,可以设置颜色、图片等。
  • pageController: 控制页码的控制器。
  • onPageChanged: 页码改变时的回调函数。
  • loadingBuilder:用于自定义加载时的小部件。
PhotoViewGalleryPageOptions介绍

PhotoViewGalleryPageOptions是photo_view库中的一个类,用于配置PhotoViewGallery中每一页的属性。通过使用这个类,你可以对每张图片进行个性化的设置,包括图片提供者、最小缩放比例、最大缩放比例等。

主要属性:

  • imageProvider: 这是一个必需的属性,用于指定图片的提供者。它可以是各种图片提供者,如NetworkImage、AssetImage等。你需要将具体的图片提供者实例传递给这个属性。
imageProvider: NetworkImage("https://images.pexels.com/photos/1054218/pexels-photo-1054218.jpeg?auto=compress&cs=tinysrgb&w=600"),
  • minScale: 用于设置图片的最小缩放比例。默认值是PhotoViewComputedScale.contained * 0.8。你可以根据需要调整这个值,以确保在查看图片时可以缩小到合适的尺寸。
minScale: PhotoViewComputedScale.contained * 0.5,
  • maxScale: 用于设置图片的最大缩放比例。默认值是PhotoViewComputedScale.covered * 2。这决定了可以将图片放大到的最大尺寸。
maxScale: PhotoViewComputedScale.covered * 3,
  • heroTag: 一个可选的属性,用于在页面切换时支持共享元素转换(Hero Animation)。通过为不同页面的PhotoViewGallery设置相同的heroTag,你可以创建一个平滑的过渡效果。
heroTag: "heroTagForImage1",
  • backgroundDecoration: 用于设置每一页的背景装饰,可以是颜色、渐变色、图片等。默认为透明。
backgroundDecoration: BoxDecoration(
  color: Colors.black,
),
  • basePosition: 一个PhotoViewPosition对象,用于设置页面初始位置。这允许你在初始加载时将页面定位到指定的位置。
basePosition: PhotoViewPosition(1.0, Offset(0.5, 0.5)),
  • onTapUp: 一个回调函数,当用户在图片上执行轻击时触发。你可以在这里处理点击事件,例如关闭图片浏览器。
onTapUp: (context, details, controllerValue) {
  Navigator.pop(context);
},

更多信息可参考:
Flutter可缩放图像组件photo_view预览大图并支持保存相册


标签:指南,缩放,photo,PhotoViewComputedScale,PhotoViewGallery,图片,Flutter,view
From: https://blog.51cto.com/xaye/8947860

相关文章

  • 后端 API 接口文档 Swagger 使用指南
    后端API接口文档Swagger使用指南转载自:https://zhuanlan.zhihu.com/p/98560871前言一:swagger是什么?二:为什么要使用swaager?2.1:对于后端开发人员来说2.2:对于前端开发来说2.3:对于测试三:如何搭一个swagger3.1:引入swagger的依赖3.2:springBoot整合swagg......
  • Flutter 显式动画
    创建AnimationController的同时,也赋予了一个vsync参数。vsync的存在防止后台动画消耗不必要的资源。您可以通过添加SingleTickerProviderStateMixin到类定义,将有状态的对象用作vsync因为addListener()函数调用setState(),所以每次Animation生成一个新的数字,当前帧......
  • WGCLOUD使用指南 - agent进程停止运行,如何处理
    有时候agent在运行过程中,会莫名其妙的出现进程停止的情况,有可能是人工误操作导致的,也有可能是被系统或程序kill掉,这种情况可以使用agent-backup来避免agent-backup不是必须部署的,只有您出现以上情况时候,再考虑部署agent-backupagent-backup是一个agent的备份程序,主要用来监听agen......
  • Flutter-Dart中(){}和()=>{}的细微区别
    ()=>{}在Dart语言中,=>符号是箭头语法的一部分,它用于创建单行函数或表达式的缩写。在你的两个例子中,使用()=>和(){}都是合法的,但有细微的区别。()=>箭头函数(Arrowfunction):这是一种简写形式,适用于只有一条语句的函数体。在这种情况下,函数体的结果就是函数的返回值。示例:on......
  • Flutter子工程编译,Ruby升级及Cocoapods安装问题集
    背景:工程为iOS原生与Flutter混合开发的工程,在编译Flutter子工程的过程中报了一个错,一度让我以为是ruby与pod的版本不兼容导致了一些奇奇怪怪的问题,随即来回折腾了Ruby环境升级与pod的升级安装。问题1:flutter子工程执行了flutterpubget,执行flutterbuildios--no-codesign时,报......
  • Flutter 隐式动画
    通过几行代码就可以实现隐式动画,由于隐式动画背后的实现原理和繁琐的操作细节都被隐去了,所以叫隐式动画,FLutter中提供的[AnimatedContainer]、[AnimatedPadding]、[AnimatedPositioned.AnimatedOpacity]、[AnimatedDefaultTextStyle]、[AnimatedSwitcher]都属于隐式动画隐式动画......
  • Android应用开发长按拖拽-Flutter的LongPressDraggable控件回调函数onDraggableCancel
    onDraggableCanceled介绍LongPressDraggable的onDraggableCanceled回调在拖动被取消时触发。拖动可能会被取消,例如用户在拖动开始后移动了太快或在放置之前取消了拖动。onDraggableCanceled的使用以下是如何使用onDraggableCanceled的示例:LongPressDraggable<int>(//......
  • 路由策略入门指南
    对于网络工程师来说,路由策略的部署随处可见,无论在运营商IP网络还是在企业网中,路由策略的应用都是非常普遍的。同时,在网络规划中,路由策略的规划也是一个核心的内容。今天,我们来认识一下路由策略的庐山真面目。什么是路由策略?路由策略是通过一系列工具或方法对路由进行各种控制的......
  • 我们不可能永远都在救火 ——Scrum中技术债务“偿还”指南
    技术债务是指开发人员为了加速软件开发,在应该采用最佳方案时进行了妥协,改用了短期内能加速软件开发的方案,以至于未来给自己带来额外的开发负担。软件工程师 WardCunningham首次将技术的复杂比作为负债。 简单来说,技术债务类似于金融债务,软件开发就像是去银行 “贷款”,而技术债......
  • 我们不可能永远都在救火 ——Scrum中技术债务“偿还”指南
    技术债务是指开发人员为了加速软件开发,在应该采用最佳方案时进行了妥协,改用了短期内能加速软件开发的方案,以至于未来给自己带来额外的开发负担。软件工程师 WardCunningham首次将技术的复杂比作为负债。 简单来说,技术债务类似于金融债务,软件开发就像是去银行 “贷款”,而技术......