Flutter怎么实现滑动块验证码功能
发表于:2025-01-17 作者:千家信息网编辑
千家信息网最后更新 2025年01月17日,这篇文章主要介绍"Flutter怎么实现滑动块验证码功能"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"Flutter怎么实现滑动块验证码功能"文章能帮助大家解
千家信息网最后更新 2025年01月17日Flutter怎么实现滑动块验证码功能
这篇文章主要介绍"Flutter怎么实现滑动块验证码功能"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"Flutter怎么实现滑动块验证码功能"文章能帮助大家解决问题。
本文实现的是一个用于登录时,向右滑动滑动块到最右边完成验证的一个功能。当滑动未到最右边时,滑动块回弹回左边起始位置。
import 'package:flutter/material.dart'; class SlideVerifyWidget extends StatefulWidget{ /// 背景色 final Color backgroundColor; /// 滑动过的颜色 final Color slideColor; /// 边框颜色 final Color borderColor; final double height; final double width; final VoidCallback verifySuccessListener; const SlideVerifyWidget({ Key key, this.backgroundColor = Colors.blueGrey, this.slideColor = Colors.green, this.borderColor = Colors.grey, this.height = 44, this.width = 240, this.verifySuccessListener }) : super(key: key); @override StatecreateState() { return SlideVerifyState(); } } class SlideVerifyState extends State with TickerProviderStateMixin{ double height; double width ; double sliderDistance = 0; double initial = 0.0; /// 滑动块宽度 double sliderWidth = 64; /// 验证是否通过,滑动到最右方为通过 bool verifySuccess = false; /// 是否允许拖动 bool enableSlide = true; AnimationController _animationController; Animation _curve; @override void initState() { super.initState(); this.width = widget.width; this.height = widget.height; _initAnimation(); } @override void dispose() { _animationController?.dispose(); super.dispose(); } @override Widget build(BuildContext context) { return GestureDetector( onHorizontalDragStart: (DragStartDetails details){ if(!enableSlide){ return; } initial = details.globalPosition.dx; }, onHorizontalDragUpdate: (DragUpdateDetails details){ if(!enableSlide){ return; } sliderDistance = details.globalPosition.dx - initial; if(sliderDistance < 0){ sliderDistance = 0; } /// 当滑动到最右边时,通知验证成功,并禁止滑动 if(sliderDistance > width - sliderWidth){ sliderDistance = width - sliderWidth; enableSlide = false; verifySuccess = true; if(widget.verifySuccessListener != null){ widget.verifySuccessListener(); } } setState(() { }); }, onHorizontalDragEnd: (DragEndDetails details){ /// 滑动松开时,如果未达到最右边,启动回弹动画 if(enableSlide){ enableSlide = false; _animationController.forward(); } }, child: Container( height: height, width: width, decoration: BoxDecoration( color: widget.backgroundColor, border: Border.all(color: widget.borderColor), /// 圆角实现 borderRadius: BorderRadius.all(new Radius.circular(height)) ), child: Stack( children: [ Positioned( top: 0, left: 0, child: Container( height: height - 2, /// 当slider滑动到距左边只有两三像素距离时,已滑动背景会有一点点渲染出边框范围, /// 因此当滑动距离小于1时,直接将宽度设置为0,解决滑动块返回左边时导致的绿色闪动,但如果是缓慢滑动到左边该问题仍没解决 width: sliderDistance < 1? 0 : sliderDistance + sliderWidth / 2, decoration: BoxDecoration( color: widget.slideColor, /// 圆角实现 borderRadius: BorderRadius.all(new Radius.circular(height / 2)) ), ), ), Center( child: Text(verifySuccess?"验证成功":"请按住滑块,拖动到最右边", style: TextStyle(color: verifySuccess?Colors.white:Colors.black54, fontSize: 14),), ), Positioned( top: 0, /// 此处将sliderDistance距离往左偏2是解决当滑动块滑动到最右边时遮挡外部边框 left: sliderDistance > sliderWidth ? sliderDistance - 2 : sliderDistance, child: Container( width: sliderWidth, height: height - 2 , alignment: Alignment.center, decoration: BoxDecoration( color: Colors.white, border: Border.all(color: widget.borderColor), /// 圆角实现 borderRadius: BorderRadius.all(new Radius.circular(height)) ), child: Row( mainAxisAlignment: MainAxisAlignment.center, children: [ SizedBox(width: 6,), Image.asset("assets/images/ic_safety.png", height: 24, width: 24,), Image.asset("assets/images/ic_next_primary.png", height: 16, width: 16,), /// 因为向右箭头有透明边距导致两个箭头间隔过大,因此将第二个箭头向左偏移,如果切图无边距则不用偏移 Transform( transform: Matrix4.translationValues(-8, 0, 0), child: Image.asset("assets/images/ic_next_primary.png", height: 16, width: 16,), ), ], ), ), ) ], ), ), ); } /// 回弹动画 void _initAnimation(){ _animationController = AnimationController( duration: const Duration(milliseconds: 300), vsync: this); _curve = CurvedAnimation(parent: _animationController, curve: Curves.easeOut); _curve.addListener(() { setState(() { sliderDistance = sliderDistance - sliderDistance * _curve.value; if(sliderDistance <= 0){ sliderDistance = 0; } }); }); _animationController.addStatusListener((status) { if(status == AnimationStatus.completed){ enableSlide = true; _animationController.reset(); } }); } }
关于"Flutter怎么实现滑动块验证码功能"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注行业资讯频道,小编每天都会为大家更新不同的知识点。
验证
功能
右边
知识
箭头
动画
圆角
宽度
背景
行业
边框
问题
颜色
偏移
不同
实用
缓慢
不用
两个
位置
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
联想服务器保修官网查询
青年网络安全倡议书
十大机器视觉软件开发
网络安全设备哪家最便宜
数据库安全域 等保三级
上海异步网络技术有限公司
东易日盛互联网科技家装怎么样
摩尔庄园qq服务器编号
服务器ip安全规定
数据库中可以有几个主文件组
潮州分布式服务器行情
软件开发包括哪方面
百来联网络技术百脑汇店
轻量应用服务器登录后怎么用
数据库中的什么是指
数据库应用和数据库管理
10级数据库
数据库分析带代码
南邮无线网络技术试卷
数据库in关键字
php数据库跳转教程
软件开发与云平台云应用差别
数据库的视图在图形界面进行操作
岳阳软件开发服务商
网络安全大家谈快板内容
服务器电脑上的加密管理器
php的数据库中如何添加修改
肇庆考试软件开发联系方式
下载快车软件开发
飞控软件开发工程师培训