码迷,mamicode.com
首页 > 其他好文 > 详细

Core Animation详解(三)-UIDynamic Animation

时间:2015-02-07 11:47:53      阅读:130      评论:0      收藏:0      [点我收藏+]

标签:ios   animation   uidynamic   

原创Blog,转载请注明出处
blog.csdn.net/hello_hwc

前言:本文主要包括以下几部分

  • UIDynamic Animation是什么
  • 如何创建UIDynamic Animation
  • 每一种UIDynamic Animation讲解然后举例
  • 附上Demo链接
    由于都是动画,我就把这部分放在了Core Animation中了,严格意义上来说,它是Core Animation上层的封装。

一 什么是UIDynamic Animation
UIDynamic Animation是IOS 7引入的一个动态库,用来模拟现实世界的物理模型。隶属于UIKit,这里我仍然把它归到Core Animation的讲解之一。
主要模拟以下几种物理行为:

  1. UIGravityBehavior
  2. UIAttachmentBehavior
  3. UISnapBehavior
  4. UIPushBehavior
  5. UICollisionBehavior
  6. UIDynamicItemBehavior

二 如何创建一个UIDynamic Animation

(1)创建一个UIDynamicAnimator,大部分情况下只需要一个Animator
(2)创建一个或者多个UIDynamic Behavior,并添加到Animator
(3)为Dynamic Behavior添加Dynamic Item。
这里简单介绍下,什么是Dynamic Item。Dynamic Item是遵循UIDynamicItem Protocol的对象。UIView和UICollectionViewLayoutAttributes在IOS 7.0以后遵循了这个协议。所以可以直接使用。


三 UIGravityBehavior -重力
几个要配置的属性

magnitude - 重力加速度值 默认情况下1000points/second^2
angle - 重力的方向(由弧度指定)
gravityDirection - 重力的方向(由vector指定,默认(0.01.0))

举例
技术分享

 UIAttachmentBehavior * attachBeahavior =  [[UIAttachmentBehavior alloc] initWithItem:self.imageview attachedToAnchor:CGPointMake(CGRectGetMidX(self.view.frame), 114)];
    UIGravityBehavior * gravityBehavior = [[UIGravityBehavior alloc] initWithItems:@[self.imageview]];
    [self.animator addBehavior:attachBeahavior];
    [self.animator addBehavior:gravityBehavior];

四 UIDynamicItemBehavior
配置一些公用的属性,与其他的Dynamic Behavior共同配合

addAngularVelocity:forItem: - 添加角速度
addLinearVelocity:forItem: - 添加线速度
allowsRotation - 是否允许旋转
angularResistance - 角速度方向的阻力
density- 相对密度
elasticity - 碰撞的弹性
friction - 摩擦
resistance-线性阻力 

五 UICollisionBehavior - 碰撞
为Item与边界以及Item之间添加碰撞效果。

addBoundaryWithIdentifier:forPath: - 添加Path边界
addBoundaryWithIdentifier:fromPoint:toPoint: - 添加线边界
collisionMode - 碰撞模式(三种:只有Item之间;只有边界;边界以及Item之间都存在碰撞效果)
translatesReferenceBoundsIntoBoundary - 把参考Viewbounds转换为边界

举例
技术分享

 UIGravityBehavior * gravityBehavior = [[UIGravityBehavior alloc] init];
//    gravityBehavior.angle = M_PI/2;
    gravityBehavior.gravityDirection = CGVectorMake(0,1);
    gravityBehavior.magnitude = 0.5;
    [gravityBehavior addItem:self.imageview];
    [self.animator addBehavior:gravityBehavior];

六 UISnapBehavior 这个不好翻译,附上文档描述

A snap behavior defines a dynamic item’s movement to a specified point; the movement proceeds with a spring-like effect, ending with an oscillation whose amount you can set.

配置属性:

damping - 动画结束的时候的震荡值 0.0-1.0;其中0.0最小,1.0最大。默认0.5

举例
技术分享

UISnapBehavior * snapbehavior = [[UISnapBehavior alloc] initWithItem:self.imageview snapToPoint:self.view.center];
    snapbehavior.damping = 0.65;
    [self.animator addBehavior:snapbehavior];

七 UIAttachmentBehavior - 吸附
为Items之间或者Item和锚点来创建吸附行为,如果是Item,默认吸附Item的中心,当然可以配置。

initWithItem:attachedToAnchor: - 初始化吸附到锚点
initWithItem:attachedToItem: - 初始化吸附到item
anchorPoint - 锚点
damping - 阻尼(阻力大小)
frequency - 震荡频率
length - 吸附的两个点之间的距离(锚点和Item或者Item之间)

举例
技术分享

  UIAttachmentBehavior * attachBeahavior =  [[UIAttachmentBehavior alloc] initWithItem:self.imageview attachedToAnchor:CGPointMake(CGRectGetMidX(self.view.frame), 114)];
    UIGravityBehavior * gravityBehavior = [[UIGravityBehavior alloc] initWithItems:@[self.imageview]];
    [self.animator addBehavior:attachBeahavior];
    [self.animator addBehavior:gravityBehavior];

八 UIPushBehavior - 推动
给一个Item持续或者瞬间的推力
技术分享
initWithItems:mode: - 初始化并且指明是瞬间还是持续的推力
angle - 力的角度
magnitude - 推力大小
pushDirection - 推力方向
举例

 UIPushBehavior * push = [[UIPushBehavior alloc] initWithItems:@[self.imageview] mode:UIPushBehaviorModeInstantaneous];
    push.pushDirection = CGVectorMake(45, 0);
    push.magnitude = 1.0;
    UIDynamicItemBehavior * itemBehavior = [[UIDynamicItemBehavior alloc] initWithItems:@[self.imageview]];
    itemBehavior.resistance = 0.8;
    [self.animator addBehavior:itemBehavior];
    [self.animator addBehavior:push];

附上Demo 工程完整代码下载
http://download.csdn.net/detail/hello_hwc/8430701
BTY:对CSDN 的这个新的文本编辑器点赞

Core Animation详解(三)-UIDynamic Animation

标签:ios   animation   uidynamic   

原文地址:http://blog.csdn.net/hello_hwc/article/details/43601565

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!