gpt4 book ai didi

Swift语言实现地图坐标弹跳动画

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 25 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章Swift语言实现地图坐标弹跳动画由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

下面应用Swift语言做地图坐标实现弹簧跳动的效果,具体实现方法如下所示:

iOS动画大概分这几种:

CoreAnimation动画(基础)UIView动画(animateWithDuration开头的函数,带弹簧特效)UIDynamic动画(有物理引擎) 。

上次写弹跳动画,由于刚开始学,就用了最基础的CA动画,但是因为自己不会写KeyFrame,所以还引用了一个开源库来实现下坠的弹跳效果,这样固然是实现了需求,但是一点都不优雅——从iOS7开始,有了2、3两种动画,就不再需要用老的CA动画去一点一点拔了。做这个动画的正确姿势,应该是下面这样~ 。

我们的需求仍然是这个弹跳的marker:

Swift语言实现地图坐标弹跳动画

这次我用了2、3两种方式实现,效果如下:

Swift语言实现地图坐标弹跳动画

1、UIView动画 。

之前使用CABasicAnimation实现,不仅代码多,还要用CATransaction控制回来的一趟callback。其实直接用iOS7的UIView动画就搞定了:

?
1
2
3
4
5
6
7
8
9
10
UIView.animateWithDuration(0.2,
animations:
{ self.marker.layer.position.y -= 30 },
completion: {(finished) in UIView.animateWithDuration(0.5, delay: 0,
usingSpringWithDamping: 0.2,
initialSpringVelocity: 5.0,
options: UIViewAnimationOptions.CurveEaseOut,
animations: { //弹性参数的调教,可以参见本文的“参考”部分
self.marker.layer.position.y += 30 },
completion: nil)})

  。

  。

在上升过程中,直接在0.2s的时间中,向上移动30px;向下过程中,为了表示弹跳的效果,使用了Spring系列参数,做了一下调整之后,感觉效果还是挺有意思的。但是单纯使用这个有一个缺点:我们要的是类似于重力下坠,而非像一根弹簧一样弹到那个位置。注意那跟蓝色的比较线,我们实现的是左边的效果,在动画过程中,它会超过那根蓝色线条,所以其实是不符合需求的.

2、UIDynamic动画 。

UIDynamic动画是有物理引擎的动画,我们只需要设定这个“物体”的物理特性,iOS就会自动帮我们进行物理世界的动画运算。首先我们创建它的物理特性:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
var animator : UIDynamicAnimator? override func viewDidLoad() {
super.viewDidLoad()
animator = UIDynamicAnimator(referenceView: view)}
override func viewDidAppear(animated: Bool) {
let gravity = UIGravityBehavior(items: [marker2]) //重力
let elastic = UIDynamicItemBehavior(items: [marker2]) //弹性
elastic.elasticity = 0.6 let collision = UICollisionBehavior(items: [marker2]) //边缘
let endY = marker2.frame.origin.y + marker2.frame.height //
记录marker2的底部坐标
collision.addBoundaryWithIdentifier( "floor" , fromPoint: CGPoint(x: 0, y: endY),
toPoint: CGPoint(x: UIScreen.mainScreen().bounds.width, y: endY)) //在marker2的底部画一条线,从屏幕左边到屏幕右边
animator!.addBehavior(collision)
animator!.addBehavior(gravity)
animator!.addBehavior(elastic)}

  。

  。

首先我们创建一个animator,然后创建关于marker2的重力、弹性、边缘三个属性,附加在animator上。于是这个marker2便有了物理特性。然后我们和以前一样把它抬高:

?
1
2
3
4
5
UIView.animateWithDuration(0.2,
animations: {
self.marker2.layer.position.y -= 30 },
completion: {(finished : Bool) in
self.animator!.updateItemUsingCurrentState(self.marker2)//如果不update,则animator不知道它的位置被移动过了})

  。

在动画完成后,让animator重新对它进行活动,就达到了文章开始的gif图中,第二个marker的弹跳效果.

文章到此为止,希望对大家有所帮助,谢谢.

最后此篇关于Swift语言实现地图坐标弹跳动画的文章就讲到这里了,如果你想了解更多关于Swift语言实现地图坐标弹跳动画的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com