news 2026/4/18 10:01:41

Flutter---右滑显示删除按钮

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Flutter---右滑显示删除按钮

效果图

关键控件

Transform.translate - 平移变换组件

基本语法

Transform.translate( offset: Offset(dx, dy), // 必需参数 child: Widget, // 要平移的子组件 transformHitTests: true, // 可选 )

核心参数:offset- 平移偏移量

dx: 水平方向偏移量(正数向右,负数向左) dy: 垂直方向偏移量(正数向下,负数向上)

滑动中监听

onHorizontalDragStart: // 滑动开始时触发 onHorizontalDragUpdate: // 滑动过程中连续触发 onHorizontalDragEnd: // 滑动结束时触发 onHorizontalDragCancel: // 滑动被取消时触发
关键知识点

1.为什么向右滑动details.delta.dx为正数,向左滑动details.delta.dx为负数,

坐标系理解: 在Flutter的滑动事件中: 屏幕坐标系:原点(0,0)在屏幕左上角 X轴:从左到右是正方向 Y轴:从上到下是正方向 delta.dx 的含义: delta.dx 表示水平方向的位移变化量 正值 = 向右滑动(手指从左边移动到右边) 负值 = 向左滑动(手指从右边移动到左边) (0,0) 左上角 ┌─────────────┐ │ │ │ +------│----> X轴 (正方向向右) │ | │ │ ↓ │ │ Y轴 │ │ (正方向向下) │ └─────────────┘
实现步骤

1.定义变量

double _slideOffset = 0.0; //当前滑动偏移量 final double _maxSlideDistance = 60.0; // 最大滑动距离,删除按钮的宽度也设置了这个值 bool _showDeleteButton = false;//是否显示删除按钮提示

2.圆角矩形叠在删除按钮上面,所以要用stack组件,先构建删除按钮

// 删除按钮(在内容下面) Positioned.fill( child: Align( alignment: Alignment.centerRight, child: GestureDetector( onTap: (){ //删除按钮的点击时间 print("点击删除按钮"); }, child: Container( width: 60, height: 40, decoration: BoxDecoration( color: Colors.red, borderRadius: BorderRadius.circular(20), ), child: Center( child: Icon( Icons.delete, color: Colors.white, size: 20, ), ), ), ) ), ),

3.定义可滑动的内容

// 可滑动的内容 GestureDetector( //处理滑动更新 onHorizontalDragUpdate: (details) { setState(() { //a -= b;表达式表示:a = a - b //details.delta.dx表示用户手指在X轴移动的距离,向右滑动details.delta.dx为正数,向左滑动details.delta.dx为负数,(补充说明) //从 _slideOffset 中减去 details.delta.dx 的值。 _slideOffset -= details.delta.dx; //限制滑动范围 if (_slideOffset < 0) _slideOffset = 0; //不能向右移 if (_slideOffset > _maxSlideDistance) _slideOffset = _maxSlideDistance; //移动距离不能超过设置的最大滑动距离 //显示/隐藏删除按钮的逻辑 if (_slideOffset > 20 && !_showDeleteButton) {//左移大于20且删除按钮没有显示的时候 _showDeleteButton = true; //显示 } else if (_slideOffset < 20 && _showDeleteButton) { _showDeleteButton = false; } }); }, //处理滑动结束 onHorizontalDragEnd: (details) { if (_slideOffset > 30) { //用户左滑的距离大于30,则显示删除按钮 _slideOffset = _maxSlideDistance; } else { //否则就不显示删除按钮 _slideOffset = 0; _showDeleteButton = false; } setState(() {}); }, child: Transform.translate( //平移变换组件 //offset(dx,dy) //dx表示X轴偏移,dy表示Y轴偏移 //Offset(正数, 0) → 向右移动 ; Offset(负数, 0) → 向左移动 //Offset(10, 0)表示向右移动10像素 ; Offset(-10, 0)表示向左移动10像素 ;Offset(0, 0)表示不移动 offset: Offset(-_slideOffset, 0),//注意这里这里有个负号,所以这个小于零变成右移,大于零变成左移 child: Container( width: 320, height: 40, decoration: BoxDecoration( color: Color(0xFF1E2134), borderRadius: BorderRadius.circular(20), ), child: Center( child: Text( //通过是否显示删除按钮,来更新文本 _showDeleteButton ? "松手删除" : "向右滑动显示删除", style: TextStyle( color: Colors.white, fontSize: 16, ), ), ), ), ), ),

代码实例

import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; class HomePage extends StatefulWidget { const HomePage({super.key}); @override State<StatefulWidget> createState() => _MeditationPageState(); } class _MeditationPageState extends State<HomePage> with SingleTickerProviderStateMixin { double _slideOffset = 0.0; //当前滑动偏移量 final double _maxSlideDistance = 60.0; // 最大滑动距离,删除按钮的宽度也设置了这个值 bool _showDeleteButton = false;//是否显示删除按钮提示 @override Widget build(BuildContext context) { return Scaffold( backgroundColor: Colors.transparent, body: Container( width: double.infinity, height: double.infinity, child: Center( child: Container( width: 320, margin: EdgeInsets.symmetric(horizontal: 20), child: Stack( children: [ // 删除按钮(在内容下面) Positioned.fill( child: Align( alignment: Alignment.centerRight, child: GestureDetector( onTap: (){ //删除按钮的点击时间 print("点击删除按钮"); }, child: Container( width: 60, height: 40, decoration: BoxDecoration( color: Colors.red, borderRadius: BorderRadius.circular(20), ), child: Center( child: Icon( Icons.delete, color: Colors.white, size: 20, ), ), ), ) ), ), // 可滑动的内容 GestureDetector( //处理滑动更新 onHorizontalDragUpdate: (details) { setState(() { //a -= b;表达式表示:a = a - b //details.delta.dx表示用户手指在X轴移动的距离,向右滑动details.delta.dx为正数,向左滑动details.delta.dx为负数,(补充说明) //从 _slideOffset 中减去 details.delta.dx 的值。 _slideOffset -= details.delta.dx; //限制滑动范围 if (_slideOffset < 0) _slideOffset = 0; //不能向右移 if (_slideOffset > _maxSlideDistance) _slideOffset = _maxSlideDistance; //移动距离不能超过设置的最大滑动距离 //显示/隐藏删除按钮的逻辑 if (_slideOffset > 20 && !_showDeleteButton) {//左移大于20且删除按钮没有显示的时候 _showDeleteButton = true; //显示 } else if (_slideOffset < 20 && _showDeleteButton) { _showDeleteButton = false; } }); }, //处理滑动结束 onHorizontalDragEnd: (details) { if (_slideOffset > 30) { //用户左滑的距离大于30,则显示删除按钮 _slideOffset = _maxSlideDistance; } else { //否则就不显示删除按钮 _slideOffset = 0; _showDeleteButton = false; } setState(() {}); }, child: Transform.translate( //平移变换组件 //offset(dx,dy) //dx表示X轴偏移,dy表示Y轴偏移 //Offset(正数, 0) → 向右移动 ; Offset(负数, 0) → 向左移动 //Offset(10, 0)表示向右移动10像素 ; Offset(-10, 0)表示向左移动10像素 ;Offset(0, 0)表示不移动 offset: Offset(-_slideOffset, 0),//注意这里这里有个负号,所以这个小于零变成右移,大于零变成左移 child: Container( width: 320, height: 40, decoration: BoxDecoration( color: Color(0xFF1E2134), borderRadius: BorderRadius.circular(20), ), child: Center( child: Text( //通过是否显示删除按钮,来更新文本 _showDeleteButton ? "松手删除" : "向右滑动显示删除", style: TextStyle( color: Colors.white, fontSize: 16, ), ), ), ), ), ), ], ), ), ), ), ); } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 1:36:09

【高可用架构必备技能】:掌握云原生Agent的Docker资源动态调度术

第一章&#xff1a;云原生Agent与Docker资源调度概述在现代分布式系统架构中&#xff0c;云原生Agent作为运行于容器环境中的核心组件&#xff0c;承担着监控、调度、服务发现和自愈等关键职责。这类Agent通常以轻量级进程形式部署在Docker容器中&#xff0c;依托容器化技术实现…

作者头像 李华
网站建设 2026/4/18 1:32:23

多人语音聊天室APP开发全解析:从技术架构到运营策略

一、技术架构设计1. 核心功能模块音频处理层&#xff1a;采用WebRTC技术实现实时音频采集与编码&#xff0c;支持OPUS/AAC等编码标准网络传输层&#xff1a;基于WebSocket/TCP-IP协议搭建通信框架&#xff0c;支持服务器中转和P2P混合模式业务逻辑层&#xff1a;用户角色体系&a…

作者头像 李华
网站建设 2026/4/18 1:31:07

人工智能大模型技术突破:引领智能时代新纪元

人工智能大模型技术突破&#xff1a;引领智能时代新纪元 【免费下载链接】Qwen3-30B-A3B-MLX-6bit 项目地址: https://ai.gitcode.com/hf_mirrors/Qwen/Qwen3-30B-A3B-MLX-6bit 在当今数字化浪潮席卷全球的背景下&#xff0c;人工智能大模型技术正以惊人的速度重塑着我…

作者头像 李华
网站建设 2026/4/18 1:31:08

力扣hot100:路径总和III

题目描述&#xff1a;思路&#xff1a;本题和“和为k的子数组 有异曲同工之妙”&#xff0c;思路也相似。可以用一个哈希表去存储每条路径的和&#xff0c;两条路径和只差即为中间路径的和。可以用递归的方式向下遍历这颗树&#xff0c;定义一个s&#xff0c;表示目前路径的和&…

作者头像 李华
网站建设 2026/4/18 1:36:41

Blender 3MF插件:5个高效解决3D打印工作流痛点的技术方案

Blender 3MF插件&#xff1a;5个高效解决3D打印工作流痛点的技术方案 【免费下载链接】Blender3mfFormat Blender add-on to import/export 3MF files 项目地址: https://gitcode.com/gh_mirrors/bl/Blender3mfFormat 作为连接创意设计与3D制造的关键桥梁&#xff0c;Bl…

作者头像 李华
网站建设 2026/4/18 1:35:53

48、Linux系统网络配置、故障排查与安全管理全解析

Linux系统网络配置、故障排查与安全管理全解析 1. 网络基础配置与操作 在Linux系统中,有多个工具和配置文件可用于网络配置和操作。 - IP地址获取与接口配置 : dhclient 程序可通过DHCP协议向本地网络查询IP地址信息,并使用这些信息配置接口。例如,当你需要自动获取…

作者头像 李华