Flutter实现可拖拽操作Draggable
文章目录
- 1. `Draggable` 控件的构造函数
- 主要参数:
- 2. `Draggable` 的工作原理
- 3. 常见用法
- 示例 1:基本的拖拽控件
- 解释:
- 示例 2:与 `DragTarget` 配合使用
- 解释:
- 4. `Draggable` 的回调详解
- 5. 总结
Draggable
是 Flutter 中一个用来实现拖拽功能的控件。它允许用户将一个控件拖动到屏幕的不同位置,并且可以与
DragTarget
控件一起工作来完成拖拽交互。
Draggable
控件不仅可以在应用内拖动控件,还可以处理拖拽反馈、拖拽过程中控件的状态变更等操作。
1. Draggable
控件的构造函数
Draggable<T>({Key? key,required T data, // 传递的拖拽数据required Widget child, // 拖拽控件本身的显示Widget? feedback, // 拖拽过程中展示的控件(通常是透明的)Widget? childWhenDragging, // 拖拽时原控件的替代显示Axis? axis, // 指定拖拽方向(水平或垂直)bool? ignorePointer, // 是否忽略手势bool? dragAnchorStrategy, // 自定义拖拽时锚点位置bool? onDragStarted, // 拖拽开始时的回调bool? onDragEnd, // 拖拽结束时的回调bool? onDraggableCanceled, // 拖拽取消时的回调
})
主要参数:
data
:拖拽的核心数据,当用户拖拽控件时会携带此数据(可以是任意类型)。child
:正常显示的控件。它是拖拽对象的原始显示(例如,可以是一个文本或图像)。feedback
:拖拽时展示的控件,通常是半透明的,这个控件在拖拽期间会悬浮在用户的手指上方。childWhenDragging
:当控件被拖拽时,原控件的替代显示(通常是空白或一个灰色的占位符)。axis
:控制拖拽的方向,值可以是Axis.horizontal
(水平)或Axis.vertical
(垂直),也可以为Axis.none
(没有方向限制)。ignorePointer
:是否忽略手势。如果为true
,该控件在拖拽时将无法响应任何手势。onDragStarted
:拖拽开始时的回调,通常用来更新状态或做一些准备工作。onDragEnd
:拖拽结束时的回调,通常用来处理拖拽结束后的逻辑。onDraggableCanceled
:当拖拽被取消时的回调,通常是当控件离开了任何DragTarget
区域。
2. Draggable
的工作原理
Draggable
控件主要通过 data
属性将需要拖拽的数据传递给其他控件,特别是 DragTarget
,在用户拖拽控件时,Draggable
控件会自动执行以下操作:
- 拖拽开始:当用户开始拖拽时,
Draggable
控件会展示指定的feedback
,并且显示出原始控件的占位符(childWhenDragging
)。 - 拖拽过程:拖拽过程中,用户可以将控件在屏幕上拖动,通常会通过
onDragStarted
和onDragEnd
回调来触发相应的逻辑。 - 拖拽结束或取消:当拖拽对象被放置到
DragTarget
中,或者当用户取消拖拽时,Draggable
会触发onDragEnd
或onDraggableCanceled
回调。
3. 常见用法
示例 1:基本的拖拽控件
import 'package:flutter/material.dart';void main() {runApp(MyApp());
}class MyApp extends StatelessWidget {Widget build(BuildContext context) {return MaterialApp(home: Scaffold(appBar: AppBar(title: Text('Draggable Example')),body: Center(child: Draggable<int>(data: 100, // 拖拽的数据child: Container(padding: EdgeInsets.all(16),color: Colors.blue,child: Text('Drag me'),),feedback: Material(color: Colors.transparent,child: Container(padding: EdgeInsets.all(16),color: Colors.blue.withOpacity(0.5),child: Text('Dragging'),),),childWhenDragging: Container(padding: EdgeInsets.all(16),color: Colors.grey,child: Text('Gone'),),),),),);}
}
解释:
- 在此例中,
Draggable<int>
创建了一个可以拖拽的蓝色矩形,其内容是文本“Drag me”。 - 当用户开始拖拽时,
feedback
使矩形变成一个半透明的版本(显示文本“Dragging”),同时,原始控件会被替换为一个灰色的占位符(childWhenDragging
)。
示例 2:与 DragTarget
配合使用
import 'package:flutter/material.dart';void main() {runApp(MyApp());
}class MyApp extends StatelessWidget {Widget build(BuildContext context) {return MaterialApp(home: Scaffold(appBar: AppBar(title: Text('Draggable with DragTarget')),body: Center(child: Column(mainAxisAlignment: MainAxisAlignment.center,children: [Draggable<String>(data: "Hello, Flutter!", // 拖拽的数据child: Container(color: Colors.blue,padding: EdgeInsets.all(20),child: Text('Drag me'),),feedback: Material(color: Colors.transparent,child: Container(color: Colors.blue.withOpacity(0.5),padding: EdgeInsets.all(20),child: Text('Dragging'),),),childWhenDragging: Container(padding: EdgeInsets.all(20),color: Colors.grey,child: Text('Gone'),),),SizedBox(height: 50),DragTarget<String>(onAccept: (data) {ScaffoldMessenger.of(context).showSnackBar(SnackBar(content: Text('Dropped: $data')),);},builder: (context, candidateData, rejectedData) {return Container(width: 300,height: 200,color: Colors.orange,child: Center(child: Text('Drop Here')),);},),],),),),);}
}
解释:
- 在这个例子中,
Draggable<String>
允许用户拖拽一个带有文本“Drag me”的蓝色矩形。 - 拖拽过程中,
feedback
显示一个半透明的矩形,childWhenDragging
在原位置展示一个灰色占位符。 DragTarget<String>
用来接收拖拽的字符串数据,当用户将拖拽对象放入目标区域时,显示一个 SnackBar,告知接收到的内容。
4. Draggable
的回调详解
onDragStarted
:在拖拽开始时调用。通常用来执行一些初始操作,例如更新 UI 状态,或者记录拖拽开始时的时间等。onDragEnd
:在拖拽结束时调用。可以根据拖拽结束的位置来执行不同的操作,比如更新模型数据、界面重绘等。onDraggableCanceled
:当拖拽操作被取消时调用,例如当拖拽控件未被放置到DragTarget
中。你可以使用这个回调恢复控件的状态,或者清除一些临时的数据。
5. 总结
Draggable
是 Flutter 中实现拖拽功能的核心控件,可以创建可拖拽的控件并将其与DragTarget
配合使用,实现丰富的拖拽交互。- 它支持拖拽过程中控件状态的变化,如显示拖拽的反馈内容、替代显示、拖拽过程中展示的内容等。
- 通过回调函数如
onDragStarted
、onDragEnd
和onDraggableCanceled
,你可以在不同的拖拽阶段进行更多定制化的操作。
结束语
Flutter是一个由Google开发的开源UI工具包,它可以让您在不同平台上创建高质量、美观的应用程序,而无需编写大量平台特定的代码。我将学习和深入研究Flutter的方方面面。从基础知识到高级技巧,从UI设计到性能优化,欢饮关注一起讨论学习,共同进入Flutter的精彩世界!
相关文章:

Flutter实现可拖拽操作Draggable
文章目录 1. Draggable 控件的构造函数主要参数: 2. Draggable 的工作原理3. 常见用法示例 1:基本的拖拽控件解释:示例 2:与 DragTarget 配合使用解释: 4. Draggable 的回调详解5. 总结 Draggable 是 Flutter 中一个用…...

Vue BPMN Modeler流程图
1、参考地址 git clone https://github.com/evanyangg/vue-bpmn-modeler.git 2、安装bpmn.js npm install bpmn-js --save 3、使用bpmn.js <template><div class"containers"><div class"canvas" ref"canvas"></div&g…...
写在公司40周年前夕
日子太快了,来这里工作六年多了。现在才知道原来入职的公司只是母公司的一小点。刚来一年就碰到疫情,三年疫情之后就迎来亏损,而后就是变了董事长,换了总经理。 这圣诞前,所有的子分又换了一把手。动作之大,…...
Python调用Elasticsearch更新数据库
文章目录 Elasticsearch介绍Python调用Elasticsearch更新数据库 Elasticsearch介绍 Elasticsearch是一个基于Lucene的搜索引擎,它提供了一个分布式、多租户能力的全文搜索引擎,具有HTTP web接口和无模式的JSON文档。Elasticsearch是用Java开发的&#x…...

测试基础之测试分类
软件测试是确保软件产品满足预期功能、性能和用户体验要求的关键环节。它的主要目的是通过系统化的方法发现并修复软件中的缺陷,从而提高软件的质量和可靠性。在软件开发生命周期的不同阶段执行测试,以尽早发现潜在的错误或类型,早期发现缺陷…...

太阳能LED路灯智能控制系统(论文+源码)
1系统的功能及方案设计 本次课题为太阳能LED路灯智能控制系统,其系统整体架构如图2.1所示,太阳能板通过TP4056充电模块给锂电池进行充电,电池通过HX3001升压模块进行升压到5V给整个控制系统进行供电,控制系统由AT89C52单片机作为…...
文本数据处理
文本数据处理 一、数据转换与错误处理 (一)运维中的数据转换问题 在计算机审计及各类数据处理场景中,数据转换是关键步骤,涉及将被审计单位或其他来源的数据有效装载到目标数据库,并明确标示各表及字段含义与关系。…...

Liunx环境下安装人大金仓数据库V8R6版本
Liunx环境下安装人大金仓数据库V8R6版本 一:硬件环境要求二:软件环境要求三:安装包准备四:检测和配置环境4.1:检查操作系统信息4.2 检查系统内存与存储空间 五:配置内核参数六:预安装工作6.1 创…...
Android使用PorterDuffXfermode模式PorterDuff.Mode.SRC_OUT橡皮擦实现马赛克效果,Kotlin(3)
Android使用PorterDuffXfermode模式PorterDuff.Mode.SRC_OUT橡皮擦实现马赛克效果,Kotlin(3) import android.content.Context import android.graphics.Bitmap import android.graphics.BitmapFactory import android.graphics.Canvas impor…...

python 怎么引入类
一、导入单个类 from fun import Dog dogDog(husike) dog.bark() 二、导入多个类 多个类之间用逗号分隔 from fun import Dog,Cat dogDog(husike) dog.bark() catCat(maomi) cat.catch_mouse() 三、导入整个模块 import fun dogfun.Dog(husike) dog.bark() catfun.Cat(maomi) …...

Day35汉明距离
两个整数之间的 汉明距离 指的是这两个数字对应二进制位不同的位置的数目。 给你两个整数 x 和 y,计算并返回它们之间的汉明距离。 class Solution {public int hammingDistance(int x, int y) {int cnt 0;while (Math.max(x, y) ! 0) {if ((x & 1) ! (y &…...

中文学习系统:客户服务与学习支持
3.1 系统可行性分析 开发一款程序软件不仅需要时间,也需要人力,物力资源。而进行可行性分析这个环节就是解决用户这方面的疑问,看看程序在当前的条件下是否可以进行开发。 3.1.1 技术可行性分析 此程序选用的开发语言是Java,这种编…...

华为麦芒5(安卓6)termux记录 使用ddns-go,alist
下载0.119bate1版,不能换源,其他源似乎都用不了,如果root可以直接用面具模块 https://github.com/termux/termux-app/releases/download/v0.119.0-beta.1/termux-app_v0.119.0-beta.1apt-android-5-github-debug_arm64-v8a.apk 安装ssh(非必要) pkg install openssh开启ssh …...

餐厅下单助手系统(Java+MySQL)
项目概览 餐厅下单助手系统是一个采用 Java 实现的小型食品订单管理系统,并且以 SwingUI 打造视觉界面,数据库提供。本系统分为商家和顾客两类体验,有效地给予简洁性能。可用做课程设计,参考学习。 技术栈 Java: 核心开发语言S…...
Go操作MySQL
连接 Go语言中的database/sql包提供了保证SQL或类SQL数据库的泛用接口,并不提供具体的数据库驱动。使用database/sql包时必须注入(至少)一个数据库驱动。 我们常用的数据库基本上都有完整的第三方实现。例如:MySQL驱动 下载依赖…...
Linux(Ubuntu/CentOS)配置开机自启动服务
systemd和systemctl的区别和联系 systemd:是现代Linux系统中的初始化系统和服务管理器。它主要负责系统引导和进程管理,支持并行化启动服务,并提供高级的服务管理和依赖控制。 systemctl:是systemd的命令行工具,用于与…...

springboot3版本结合knife4j生成接口文档
1.概述 knife4j官网为:介绍 | Knife4j (xiaominfo.com)https://doc.xiaominfo.com/docs/introduction 初步了解的码友可以初步了解一下官网的如下几个模块: 其中在快速开始模块中,不同的springboot版本都有一个使用的案例demo如下图位置&am…...

谈谈 Wi-Fi 的 RTS/CTS 设计
我不是专业的 Wi-Fi 技术工作者。但我可以谈谈作为统计复用网络的 Wi-Fi,通用的网络分布式协调功能在底层是相通的。 从一个图展开: 基于这底层逻辑,共享以太网可以用 CSMA/CD,而 Wi-Fi 只能用 CSMA/CA,区别在 CD(冲…...

JVM 详解
一. JVM 内存区域的划分 1. 程序计数器 程序计数器是JVM中一块比较小的空间, 它保存下一条要执行的指令的地址. [注]: 与CPU的程序计数器不同, 这里的下一条指令不是二进制的机器语言, 而是Java字节码. 2. 栈 保存方法中的局部变量, 方法的形参, 方法之间的调用关系. 栈又…...
【debug】
error info: Error response Error response Error code 401. Message: Unauthorized. requests.exceptions.ConnectionError: HTTPConnectionPool(host‘127.0.0.1’, port9000): Max retries exceeded with url: /test/ (Caused by NewConnectionError(‘&l…...

Lombok 的 @Data 注解失效,未生成 getter/setter 方法引发的HTTP 406 错误
HTTP 状态码 406 (Not Acceptable) 和 500 (Internal Server Error) 是两类完全不同的错误,它们的含义、原因和解决方法都有显著区别。以下是详细对比: 1. HTTP 406 (Not Acceptable) 含义: 客户端请求的内容类型与服务器支持的内容类型不匹…...

CTF show Web 红包题第六弹
提示 1.不是SQL注入 2.需要找关键源码 思路 进入页面发现是一个登录框,很难让人不联想到SQL注入,但提示都说了不是SQL注入,所以就不往这方面想了 先查看一下网页源码,发现一段JavaScript代码,有一个关键类ctfs…...
<6>-MySQL表的增删查改
目录 一,create(创建表) 二,retrieve(查询表) 1,select列 2,where条件 三,update(更新表) 四,delete(删除表…...

【人工智能】神经网络的优化器optimizer(二):Adagrad自适应学习率优化器
一.自适应梯度算法Adagrad概述 Adagrad(Adaptive Gradient Algorithm)是一种自适应学习率的优化算法,由Duchi等人在2011年提出。其核心思想是针对不同参数自动调整学习率,适合处理稀疏数据和不同参数梯度差异较大的场景。Adagrad通…...
SciencePlots——绘制论文中的图片
文章目录 安装一、风格二、1 资源 安装 # 安装最新版 pip install githttps://github.com/garrettj403/SciencePlots.git# 安装稳定版 pip install SciencePlots一、风格 简单好用的深度学习论文绘图专用工具包–Science Plot 二、 1 资源 论文绘图神器来了:一行…...

蓝牙 BLE 扫描面试题大全(2):进阶面试题与实战演练
前文覆盖了 BLE 扫描的基础概念与经典问题蓝牙 BLE 扫描面试题大全(1):从基础到实战的深度解析-CSDN博客,但实际面试中,企业更关注候选人对复杂场景的应对能力(如多设备并发扫描、低功耗与高发现率的平衡)和前沿技术的…...

dify打造数据可视化图表
一、概述 在日常工作和学习中,我们经常需要和数据打交道。无论是分析报告、项目展示,还是简单的数据洞察,一个清晰直观的图表,往往能胜过千言万语。 一款能让数据可视化变得超级简单的 MCP Server,由蚂蚁集团 AntV 团队…...
Linux离线(zip方式)安装docker
目录 基础信息操作系统信息docker信息 安装实例安装步骤示例 遇到的问题问题1:修改默认工作路径启动失败问题2 找不到对应组 基础信息 操作系统信息 OS版本:CentOS 7 64位 内核版本:3.10.0 相关命令: uname -rcat /etc/os-rele…...

LLMs 系列实操科普(1)
写在前面: 本期内容我们继续 Andrej Karpathy 的《How I use LLMs》讲座内容,原视频时长 ~130 分钟,以实操演示主流的一些 LLMs 的使用,由于涉及到实操,实际上并不适合以文字整理,但还是决定尽量整理一份笔…...
Vite中定义@软链接
在webpack中可以直接通过符号表示src路径,但是vite中默认不可以。 如何实现: vite中提供了resolve.alias:通过别名在指向一个具体的路径 在vite.config.js中 import { join } from pathexport default defineConfig({plugins: [vue()],//…...