DragGesture/拖动手势 的使用

1. DragGesture 拖动手势操作

  1.1 实现

/// 拖动手势
struct DragGestureBootcamp: View {@State var offset: CGSize = .zerovar body: some View {//dragGesture1dragGesture2}/// 方式二var dragGesture2: some View{ZStack {VStack {Text("\(offset.width)")Spacer()}RoundedRectangle(cornerRadius: 20).frame(width: 300, height: 500).offset(offset).scaleEffect(getScaleAmount()).rotationEffect(Angle(degrees: getRotationAmount())).gesture(DragGesture().onChanged{ value inwithAnimation(.spring()){offset = value.translation}}.onEnded{ value inwithAnimation(.spring()){offset = .zero}})}}/// 获取缩放因子func getScaleAmount() -> CGFloat{// 最大值let max = UIScreen.main.bounds.width / 2// 当前数值let currentAmount = abs(offset.width)// 百分比let percentage = currentAmount / maxreturn 1.0 - min(percentage, 0.5) * 0.5}/// 获取旋转因子func getRotationAmount() -> Double{// 最大值let max = UIScreen.main.bounds.width / 2// 当前数值let currentAmount = offset.width// 百分比let percentage = currentAmount / max// 转换 Doublelet percentageAsDouble = Double(percentage)// 最大角度let maxAngle: Double = 10return percentageAsDouble * maxAngle}/// 方式一var dragGesture1: some View{RoundedRectangle(cornerRadius: 20).frame(width: 100, height: 100).offset(offset).gesture(DragGesture().onChanged{ value inwithAnimation(.spring()){offset = value.translation}}.onEnded{ value inwithAnimation(.spring()){offset = .zero}})}
}

  1.2 效果图:

      

2. DragGesture 拖动手势2操作

  2.1 实现

/// 拖动手势2
struct DragGestureBootcamp2: View {@State var startingOffsetY: CGFloat = UIScreen.main.bounds.height * 0.85@State var currentDragOffsetY: CGFloat = 0@State var endingOffsetY: CGFloat = 0var body: some View {ZStack{Color.orange.ignoresSafeArea()MySignUpView().offset(y: startingOffsetY).offset(y: currentDragOffsetY).offset(y: endingOffsetY).gesture(DragGesture().onChanged{ value in// 添加动画withAnimation(.spring()){currentDragOffsetY = value.translation.height}}.onEnded{ value inwithAnimation(.spring()){if currentDragOffsetY < -150{endingOffsetY =  -startingOffsetY} else if endingOffsetY != 0 && currentDragOffsetY > 150{endingOffsetY = 0}currentDragOffsetY = 0}})Text("\(currentDragOffsetY)")}.ignoresSafeArea(edges: .bottom)}
}struct MySignUpView: View {var body: some View {VStack(spacing: 20){Image(systemName: "chevron.up").padding(.top)Text("Sign up").font(.headline).fontWeight(.semibold)Image(systemName: "flame.fill").resizable().scaledToFit().frame(width: 100, height: 100)Text("This is the decription for our app. This is my favorite SwiftUI course and I recommend to all of my friends to subscribe to Swiftful Thinking!").multilineTextAlignment(.center)Text("Create an account").foregroundColor(.white).font(.headline).padding().padding(.horizontal).background(Color.black.cornerRadius(10))Spacer()}.frame(maxWidth: .infinity).background(Color.white).cornerRadius(30)}
}

  2.2 效果图:

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

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

相关文章

【算法练习Day5】有效的字母异位词 两个数组的交集快乐数两数之和

​ ​&#x1f4dd;个人主页&#xff1a;Sherry的成长之路 &#x1f3e0;学习社区&#xff1a;Sherry的成长之路&#xff08;个人社区&#xff09; &#x1f4d6;专栏链接&#xff1a;练题 &#x1f3af;长路漫漫浩浩&#xff0c;万事皆有期待 文章目录 有效的字母异位词两个数…

Java中的匿名内部类(看这篇就够了)

匿名内部类是一种没有名称的局部内部类&#xff0c;它通常用于创建只需使用一次的类的实例。以下是有关Java匿名内部类的一些重要信息&#xff1a; 定义匿名内部类&#xff1a; 匿名内部类通常用于创建实现某个接口或继承某个类的子类的对象。它没有类名&#xff0c;直接继承或…

MySQL数据库入门到精通8--进阶篇( MySQL管理)

7. MySQL管理 7.1 系统数据库 Mysql数据库安装完成后&#xff0c;自带了一下四个数据库&#xff0c;具体作用如下&#xff1a; 7.2 常用工具 7.2.1 mysql 该mysql不是指mysql服务&#xff0c;而是指mysql的客户端工具。 语法 &#xff1a; mysql [options] [database] 选…

【Elasticsearch】简单搜索(三)

简介&#xff1a;Elasticsearch&#xff08;ES&#xff09;是一个开源的分布式搜索和分析引擎&#xff0c;用于快速存储、搜索和分析大量数据。它具有高性能、可扩展性和灵活性的特点&#xff0c;被广泛用于构建实时搜索、日志分析、数据可视化等应用。 这篇文章主要介绍检索相…

「深度学习之优化算法」(十九)蚁狮算法

1. 蚁狮算法简介 (以下描述,均不是学术用语,仅供大家快乐的阅读)    蚁狮是一种昆虫,城里长大的我没有见过这玩意儿,请教了农村长大小的伙伴,依然没见过,这玩意儿可能在我们生活的地方分布较少。 (图片及介绍来自百度百科)    蚁狮算法(Ant Lion Optimization…

Spring Boot中的Binder类

介绍 Spring Boot中的Binder类是一个用于绑定属性的工具类。它可以将配置文件中的属性值绑定到Java对象中&#xff0c;从而方便地进行配置管理。 简单示例 import org.springframework.boot.context.properties.bind.Binder; import org.springframework.core.env.Environmen…

Go - 【字符串,数组,哈希表】常用操作

一. 字符串 字符串长度&#xff1a; s : "hello" l : len(s) fmt.Println(l) // 输出 5遍历字符串&#xff1a; s : "hello" for i, c : range s {fmt.Printf("%d:%c ", i, c) } // 输出&#xff1a;0:h 1:e 2:l 3:l 4:ofor i : 0; i < le…

笔试强训Day3

学了一坤时Linux&#xff0c;赶紧来俩道题目放松放松。 T1&#xff1a;在字符串中找出连续最长的数字串 链接&#xff1a;在字符串中找出连续最长的数字串__牛客网 输入一个字符串&#xff0c;返回其最长的数字子串&#xff0c;以及其长度。若有多个最长的数字子串&#xff0c…

Linux 入门:基本指令

本篇文章来介绍我们在初学Linux时可以会碰倒的一些基本指令&#xff0c;让我们对这些指令有一个基本的了解。 目录 01. ls 指令 02. pwd 命令 03. cd 指令 04. touch 指令 05. mkdir 指令&#xff08;重要&#xff09; 06. rmdir指令 && rm 指令&#xff08;重…

HTML+CSS综合案例二:CSS简介

<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title> CSS简介</title><style>h1{color: #33…

WebGL绘制圆形的点

目录 前言 如何实现圆形的点&#xff1f; 片元着色器内置变量&#xff08;gl_FragCoord、gl_PointCoord&#xff09; gl_PointCoord的含义 示例程序&#xff08;RoundedPoint.js&#xff09; 代码详解 前言 本文将讨论示例程序RoundedPoint&#xff0c;该程序绘制了圆…

openstack自定制cirros镜像

前言 cirros作为openstack常用的测试云镜像&#xff0c;基于busybox打包&#xff0c;体积小巧好用&#xff0c;只有14M&#xff0c;启动速度快&#xff0c;且包含常用的cli工具&#xff0c;比如ping,nc,ip等等。 但我在使用过程种&#xff0c;萌发了cirros定制的一些需求&…

高效记录,事项井然——OmniOutliner 5 Pro for Mac 信息大纲记录工具

OmniOutliner 5 Pro for Mac 是一款强大的信息大纲记录工具&#xff0c;帮助您高效组织和管理各种信息。无论是个人笔记、工作计划、项目管理还是学习资料&#xff0c;这款应用都能满足您的需求&#xff0c;并使您的日常工作更加井然有序。 OmniOutliner 5 Pro 提供了一套丰富…

【我的创作纪念日】使用pix2pixgan实现barts2020数据集的处理(完整版本)

使用pix2pixgan &#xff08;pytorch)实现T1 -> T2的基本代码 使用 https://github.com/eriklindernoren/PyTorch-GAN/ 这里面的pix2pixgan代码进行实现。 进去之后我们需要重新处理数据集&#xff0c;并且源代码里面先训练的生成器&#xff0c;后训练鉴别器。 一般情况下…

UX设计VSUI设计

UX设计在近年来国内蓬勃发展,许多人对其产生了浓厚的兴趣。那么我们应该如何通过自学来系统地学习UX设计呢?话不多说&#xff0c;上干货&#xff01; 1、 深入了解UX设计行业 在开始学习之前,需要深入了解UX设计师的工作内容和行业发展前景。确定这是自己想要从事的职业后,再…

Nginx的反向代理、动静分离、负载均衡

反向代理 反向代理是一种常见的网络技术&#xff0c;它可以将客户端的请求转发到服务器群集中的一个或多个后端服务器上进行处理&#xff0c;并将响应结果返回给客户端。反向代理技术通常用于提高网站的可伸缩性和可用性&#xff0c;并且可以隐藏真实的后端服务器地址。 #user…

Kafka关键点总结-消息的顺序性

Kafka 通过不同的角度&#xff0c;即生产者、消费者和Broker&#xff0c;来保证消息的顺序性&#xff1a; 生产者角度&#xff1a; 消息按顺序发送&#xff1a;生产者可以确保它按照特定的顺序将消息发送到 Kafka 主题中的分区。这可以通过生产者端的顺序写入消息来实现。例如&…

零基础小白学习 Java 要经历的阶段!

Java是一种广泛使用的高级编程语言&#xff0c;具有强大的跨平台性和丰富的类库支持。对于初学者而言&#xff0c;学习Java可以从零基础开始&#xff0c;通过逐步深入的学习&#xff0c;最终掌握Java编程的基本技能和理论知识。本文将从零基础学习Java的角度&#xff0c;探讨学…

Vue模板语法【下】事件处理器,表单、自定义组件、通信组件

目录 一、事件处理器 1.1常用的事件修饰符 1.2常用的按键修饰符 二&#xff0c;vue中的表单 三、自定义组件 四&#xff0c;通信组件 一、事件处理器 1.1常用的事件修饰符 Vue的事件修饰符是用来改变事件的默认行为或者添加额外的功能。以下是一些常用的事件修饰符及其…

如何在Python中实现高效的数据处理与分析

在当今信息爆炸的时代&#xff0c;我们面对的数据量越来越大&#xff0c;如何高效地处理和分析数据成为了一种迫切的需求。Python作为一种强大的编程语言&#xff0c;提供了丰富的数据处理和分析库&#xff0c;帮助我们轻松应对这个挑战。本文将为您介绍如何在Python中实现高效…