UIKit力学(Dynamics)

UIKit力学是基于Box2D开源物理引擎

  • UIGravityBehavior 重力
  • UICollisionBehavior 碰撞,可以碰撞检测
  • UIAttachmentBehavior 吸附,互相吸附。两个物体之间的距离是刚性的
  • UIPushBehavior 推,向某个方向运动
  • UISnapBehavior 甩,朝某个目标点甩出
  • UIDynamicItemBehavior 行为限制。它含有的设置行为力学的参数:
    • density:密度:如果是一个100 * 100的物体,密度为1.0,作用力是1.0,加速度是100点/s²
    • elasticity:弹力系数,取值范围是0-1,0表示没有反弹,1.0表示完全弹性碰撞
  • friction:摩擦系数, 0表示没有摩擦力,1.0表示摩擦力很强,需要摩擦力很大可以大于1.0
  • resistance:阻力,物体运动的时候,在线性方向的阻力,0.0没有阻力,CGFLOAT_MAX表示最大阻力
  • allowsRotation:是否允许旋转
  • angularResistance:角阻力:物体旋转的时候,旋转方向的阻力

用代码说话

重力、碰撞、吸附、推

先看效果:


在SB中创建一个盒子、一个小圆球、一根木棍


Paste_Image.png
/**
 *  盒子重力加速度下降
 *  盒子在碰到棍子后弹起翻转
 *  盒子碰到球吸附
 */

@interface ViewController () <UICollisionBehaviorDelegate>{
    BOOL _firstContact; // 记录方块是否是第一次碰撞
}
@property (weak, nonatomic) IBOutlet UIView *box; // 盒子
@property (weak, nonatomic) IBOutlet UIImageView *line; // 木棍
@property (weak, nonatomic) IBOutlet UIImageView *ball; // 球


@property (nonatomic, retain) UIDynamicAnimator * animator;
@property (nonatomic, retain) UIGravityBehavior * gravity; // 重力
@property (nonatomic, retain) UICollisionBehavior * collision; // 碰撞
@property (nonatomic, retain) UIAttachmentBehavior * attachment; // 吸附

@end

@implementation
ViewController

- (void)viewDidLoad {
    _ball.layer.masksToBounds = YES;
    _ball.layer.cornerRadius = _ball.frame.size.width / 2;

    self.animator= [[UIDynamicAnimator alloc] initWithReferenceView:self.view];

    // 重力
     self.gravity= [[UIGravityBehavior alloc] initWithItems:@[_box]];

    // 设置重力的方向
//    CGVector gravityDirection = {0.0, 5}; // 如果y为负向上运动,值越大速度越大
//    _gravity.gravityDirection = gravityDirection;
    [_animator addBehavior:_gravity]; // 添加到animator中

    // 碰撞
    self.collision= [[UICollisionBehavior alloc] initWithItems:@[_box]];
    _collision.translatesReferenceBoundsIntoBoundary= YES; // 检测发生碰撞
    [_animator addBehavior:_collision];

    // 检测是否与其他视图边界进行碰撞
    [_collision addBoundaryWithIdentifier:@"collision"fromPoint:_line.frame.origin toPoint:CGPointMake(_line.frame.origin.x+ _line.frame.size.width, _line.frame.origin.y)];

    _collision.collisionDelegate = self; // 设置代理

    // 参数
    UIDynamicItemBehavior* item = [[UIDynamicItemBehavior alloc] initWithItems:@[_box]];
    item.elasticity= 0.5;
    [_animator addBehavior:item];
}

// 检测到碰撞后进行的处理
- (void)collisionBehavior:(UICollisionBehavior*)behavior beganContactForItem:(id<UIDynamicItem>)item
withBoundaryIdentifier:(id<NSCopying>)identifier atPoint:(CGPoint)p{

    if( !_firstContact) {
        _firstContact = YES;

        // 吸附,小球吸附在盒子里
        self.attachment = [[UIAttachmentBehavior alloc] initWithItem:_ball attachedToItem:_box];
        [self.animator addBehavior:_attachment];

        // 推
        UIPushBehavior * push
= [[UIPushBehavior alloc] initWithItems:@[_box]mode:UIPushBehaviorModeInstantaneous];
        CGVector pushDir = {0.5, -0.5};
        push.pushDirection =
pushDir;
        push.magnitude = 5.0;
        [_animator addBehavior:push];
    }
}
@end

Demo在这里

效果:


在SB为view添加一个点击手势


/**
 *  盒子停在界面中,当触摸屏幕,盒子会先加速后减速到触摸点
 */
@interface ViewController ()
@property (weak, nonatomic) IBOutlet UIView *box; // 盒子

@property (nonatomic, retain) UIDynamicAnimator * animator;
@property (nonatomic, retain) UISnapBehavior * snap; // 甩
@end

@implementation ViewController

- (void)viewDidLoad {
    self.animator = [[UIDynamicAnimator alloc] initWithReferenceView:self.view];
}
- (IBAction)handleSnapGesture:(UITapGestureRecognizer *)sender {
    // 移除甩行为
    [_animator removeBehavior:_snap];
    
    // 添加甩行为
    CGPoint point = [sender locationInView:self.view]; // 得到触摸的点
    self.snap = [[UISnapBehavior alloc] initWithItem:_box snapToPoint:point];
    [_animator addBehavior:_snap];
}

Demo在这里

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,402评论 6 499
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,377评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,483评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,165评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,176评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,146评论 1 297
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,032评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,896评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,311评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,536评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,696评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,413评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,008评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,659评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,815评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,698评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,592评论 2 353

推荐阅读更多精彩内容

  • UIKit动力学最大的特点是将现实世界动力驱动的动画引入了UIKit,比如重力,铰链连接,碰撞,悬挂等效果,即将2...
    BarleyZ阅读 1,282评论 0 49
  • iOS 7增加了UIKit Dynamics库,其集成于UIKit框架中,将2D物理引擎引入了UIKit,提供了以...
    pro648阅读 2,800评论 2 14
  • 《围城》里比较意外的是方鸿渐与孙柔嘉的婚姻。 孙柔嘉爱方鸿渐吗?方是她改变命运最便捷的棋子,却未必是她掏心掏肺死去...
    江南玉笛阅读 562评论 5 5
  • 经过几日舟车劳顿,他们终于到了药王谷,此时的古月北看上去消瘦了很多,也许只有仇恨才足以支撑他快悲伤过度的躯体。 微...
    想最烈的酒阅读 295评论 0 2
  • 于涛和路梅十年没见了,他们是网恋的五年前。路梅深爱着于涛,于涛总是找理由不见路梅。最后路梅忍不住来到北京,在一个寒...
    臭余阅读 188评论 0 1