在 Flutter 中创建可按压缩小视图

在 Flutter 应用程序中,经常会遇到需要在用户点击时进行缩放的情况,比如图片预览或者按钮点击效果。为了方便地实现这一功能,我们可以创建一个名为 TapDownZoomOutView 的可重用小部件,它能够根据用户的点击情况实现缩放效果。

介绍

TapDownZoomOutView 是一个继承自 StatefulWidget 的 Flutter 小部件,它接受以下参数:

  • needAnimation:一个布尔值,指示是否需要缩放动画,默认为 true
  • duration:动画时长,默认为 100 毫秒。
  • alignment:对齐方式,默认为 Alignment.center
  • child:要显示的子组件。

实现

下面是 TapDownZoomOutView 的实现代码:

import 'package:flutter/material.dart';class TapDownZoomOutView extends StatefulWidget {final bool needAnimation;final Duration duration;final Alignment alignment;final Widget child;const TapDownZoomOutView({required this.child,this.duration = const Duration(milliseconds: 100),this.needAnimation = true,this.alignment = Alignment.center,});State<TapDownZoomOutView> createState() => _TapDownZoomOutViewState();
}class _TapDownZoomOutViewState extends State<TapDownZoomOutView> {double scale = 1.0;Offset downOffset = Offset.zero;void _updateScale(double newScale) {setState(() {scale = newScale;});}Widget build(BuildContext context) {return Listener(onPointerUp: (_) => _updateScale(1.0),onPointerDown: (details) {setState(() {scale = 0.95;downOffset = details.localPosition;});},onPointerMove: (details) {final rangeRect = Rect.fromCenter(center: downOffset,width: 16,height: 16,);if (!rangeRect.contains(details.localPosition)) {_updateScale(1.0);downOffset = Offset.zero;}},onPointerCancel: (_) => _updateScale(1.0),child: widget.needAnimation? AnimatedScale(scale: scale,duration: widget.duration,alignment: widget.alignment,child: widget.child,): Transform.scale(scale: scale,alignment: widget.alignment,child: widget.child,),);}
}

使用方法

要使用 TapDownZoomOutView,只需将其包装在需要缩放的小部件外部即可。例如:

TapDownZoomOutView(child: Image.asset('assets/image.png'),
),

这将创建一个能够在用户点击时进行缩放的图像。可以根据需要调整 needAnimationdurationalignment 参数来满足具体的需求。

这样,我们就可以轻松地在 Flutter 应用程序中实现可缩放的点击效果了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/9339.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何通过wifi网络将串口数据发送到多个设备

摘要&#xff1a;当lora电台的速率无法满足高速传输时&#xff0c;可以考虑用“串口服务器”。本文介绍一下如何使用TP-LINK的TL-CPE300D实现一对多的数据发送。 当前也有使用lora电台的&#xff0c;但是lora电台支持的速率有限&#xff0c;可能最大支持到9600&#xff0c;甚至…

数据库课程设计《基于Spring Boot + MyBatis + MySQL 实现Java医院药品管理系统》+源代码

文章目录 源代码下载地址项目介绍项目功能 项目备注源代码下载地址 源代码下载地址 点击这里下载源码 项目介绍 项目功能 库存管理 登记入库的药品。 登记出库的药品。 每日检查库存下限&#xff0c;报警。 每日检查过期的药品&#xff0c;报警并做退回销毁处理。 对有问题…

TC3xx MTU概述(1)

目录 1.MTU基本功能 2.MBIST 3.小结 1.MTU基本功能 在TC3xx中&#xff0c;MTU(Memory Unit Test)被用来管理控制芯片内部各种RAM的测试、初始化和数据完整性检查。 既然MTU主要是管理和控制&#xff0c;那干活的想必另有他人。所以在该平台中&#xff0c;我们可以看到SRAM…

2.扩散模型的正向过程

很早之前就新建了一个专栏从0开始弃坑扩散模型,但发了一篇文章就没有继续这一系列&#xff0c;在这个AIGC的时代&#xff0c;于是我准备重启这个专栏。 整个专栏的学习顺序可以见这篇汇总文章 很多时候我们看到一篇文章很长&#xff0c;难免会心生胆怯&#xff0c;所以我将这些…

Electron-Vue 脚手架避坑实录,兼容Win11,升级electron22,清理控制台错误

去年的还是有用的&#xff0c;大家继续看&#xff0c;今年再补充一些Electron-Vue 异常处理方案 M1 和 Window10_electron异常处理-CSDN博客 代码gitee.com地址 electron-demo: electron 22 初始代码开发和讲解 升级electron为22版本&#xff08;这个版本承上启下&#xff0c…

怎么用git在暂存区(stage)中移除不需要提交(commit)的文件?

2024年5月9日&#xff0c;周四上午 非常简单&#xff0c;用下面这条命令就可以了 git rm --cached <file>注&#xff1a;这条命令不会把文件从文件夹中删除&#xff0c;只会把文件从暂存区中移除出去 实战

《Python编程从入门到实践》day23

# 昨日知识点回顾 操控飞船移动发射子弹&#xff0c;删除屏幕之外的子弹 #今日知识点学习 第13章 外星人 13.1 项目回顾 项目添加新功能前审核既有代码&#xff0c;对混乱或低效的代码进行清理 13.2 创建第一个外星人 13.2.1 创建Alien类 # alien.py imp…

影响视频视觉质量的因素——各类视觉伪影

模糊效应&#xff08;Blurring Artifact&#xff09; 图像模糊&#xff08;blurring&#xff09;&#xff1a;平滑图像的细节和边缘产生的现象&#xff0c;模糊对于图像来说&#xff0c;是一个低通滤波器&#xff08;low-pass filter&#xff09;。一般而言&#xff0c;用户更…

预积分的推导2

预积分的推导2 6.零偏的更新7.预积分更新 6.零偏的更新 IMU噪声的推导是假定零偏固定不变&#xff0c;在面对实际过程中&#xff0c;对于零偏的处理有一个技巧&#xff1a;假定零偏的变化是线性的&#xff0c;保留其一阶项。在原先的基础上进行修正。 数学模型并不一定是和真…

商品上新业务状态机接入实践

一、商品上新业务介绍 商品上新即为在得物平台上架一个新的商品&#xff0c;一个完整的商品上新流程从各种不同的来源渠道提交新品申请开始&#xff0c;需要历经多轮不同角色的审核&#xff0c;主要包括&#xff1a; 选品审核&#xff1a;根据新品申请提交的资料信息判定是否符…

Docker 怎么将映射出的路径设置为非root用户权限

在Docker中&#xff0c;容器的根文件系统默认是由root用户拥有的。如果想要在映射到宿主机的路径时设置为非root用户权限&#xff0c;可以通过以下几种方式来实现&#xff1a; 1. 使用具有特定UID和GID的非root用户运行容器&#xff1a; 在运行容器时&#xff0c;你可以使用-u…

设计模式——享元模式(Flyweight)

享元模式&#xff08;Flyweight Pattern&#xff09;是一种软件设计模式&#xff0c;它运用共享技术来有效地支持大量细粒度对象的复用。以下是关于享元模式的详细解释&#xff1a; 定义 享元模式使用共享物件&#xff0c;以尽可能减少内存使用量以及分享信息给尽可能多的相似…

17 空闲空间管理

目录 假设 底层机制 分割与合并 追踪已分配空间的大小 嵌入空闲列表 让堆增长 基本策略 最优匹配 首次匹配 下次匹配 其他方式 分离空闲列表 伙伴系统 小结 分页是将内存成大小相等的内存块&#xff0c;这样的机制下面&#xff0c;很容易去管理这些内存&#xff0c…

巩固学习2

如何寻找bug class Distance:def __init__(self,ntxt):self.x1eval(ntxt[0])self.x2eval(ntxt[1])self.y1eval(ntxt[2])self.y2eval(ntxt[3])print(self.y2,self.y1)def getdistance(self):distancepow(pow(self.x2-self.x1, 2) pow(self.y2-self.y1, 2),0.5)return distance…

Word表格标题间距大修改环绕为无仍无法解决

1.选中表格&#xff0c;右键选择【表格属性】 2.选择【环绕】&#xff0c;此时【定位】可以被启用&#xff08;如下&#xff09;&#xff0c;点击进入窗口 3.修改参数和下面一模一样 注意&#xff1a;【垂直】那里的修改方式是先选段落&#xff0c;后在位置输入0

C语言中栈数据结构的基本实现

概述 栈的特点 使用只能在一端进行插入和删除操作的特殊线性表。 按照后进先出的原则存储数据&#xff1a; 先进入的数据被压入栈底&#xff0c;最后的数据在栈顶需要读取数据的时候&#xff0c;从栈顶开始读取数据 基本实现 栈的创建和初始化 stack.h #ifndef C01_HEL…

python:鸭子类型使用场景

python&#xff1a;鸭子类型使用场景 1 前言 “一只鸟走起来像鸭子、游泳起来像鸭子、叫起来也像鸭子&#xff0c;那么这只鸟可以被称为鸭子。“----鸭子模型 鸭子模型是Python中的一种编程哲学&#xff0c;也被称为“鸭子类型”。它来源于一句话&#xff1a;“如果它走起路…

qt 5.15.x 安装android过程记录

1.经过好几天的qt for android 安装&#xff0c;发现存在很多坑 参考其他文章可以编译出APK文件。但是我发现(我的机器上)无法调试apk程序&#xff0c;不能调试那怎么行呢&#xff0c;看了很多文章都是运行出结果了就结束了。没有展示怎么调试程序。 很多文章都是建议安装JDK8…

CTF数据安全大赛crypto题目解题过程

CTF-Crypto加密题目内容 下面是一个Base64加密的密文 bXNobnszODdoajM3MzM1NzExMzQxMmo4MGg0bDVoMDYzNDQzNH0原文链接&#xff1a; 数据安全大赛CTF-Crypto题目 - 红客网-网络安全与渗透技术 我们用Python写一个解密脚本&#xff1a; import base64 import time #base64加密…

韩顺平0基础学Java——第7天

p110-p154 控制结构&#xff08;第四章&#xff09; 多分支 if-elseif-else import java.util.Scanner; public class day7{public static void main(String[] args) {Scanner myscanner new Scanner(System.in);System.out.println("input your score?");int s…