UIAttachmentBehavior-动画效果:依附,关联

1。关联动画项,使其中一个运动后,相关联的对象也随之一起运动

2。初始化

            - (instancetype)initWithItem:(id<UIDynamicItem>)item attachedToAnchor:(CGPoint)point

     - (instancetype)initWithItem:(id<UIDynamicItem>)item offsetFromCenter:(UIOffset)p1 attachedToAnchor:(CGPoint)point


e.g.


- (void)viewDidAppear:(BOOL)animated{
    [super viewDidAppear:animated];
    
    [self createGestureRecognizer]; //创建拖动
    [self createSmallSquareView];
    [self createAnchorView];  //创建锚点,基准视图,
    [self createAnimatorAndBehaviors];  //创建关联动画    
}

- (void) createSmallSquareView{
    self.squareView = [[UIView alloc] initWithFrame:  CGRectMake(0.0f, 0.0f, 80.0f, 80.0f)];   
    self.squareView.backgroundColor = [UIColor greenColor];
    self.squareView.center = self.view.center;
    
    self.squareViewAnchorView = [[UIView alloc] initWithFrame: CGRectMake(60.0f, 0.0f, 20.0f, 20.0f)];
    self.squareViewAnchorView.backgroundColor = [UIColor brownColor];
    [self.squareView addSubview:self.squareViewAnchorView];
    
    [self.view addSubview:self.squareView];
}
- (void) createAnchorView{
    
    self.anchorView = [[UIView alloc] initWithFrame: CGRectMake(120.0f, 120.0f, 20.0f, 20.0f)];
    self.anchorView.backgroundColor = [UIColor redColor];
    [self.view addSubview:self.anchorView]; 
}
- (void) createGestureRecognizer{
    UIPanGestureRecognizer *panGestureRecognizer =
    [[UIPanGestureRecognizer alloc] initWithTarget:self
                                            action:@selector(handlePan:)];
    [self.view addGestureRecognizer:panGestureRecognizer];
}

- (void) handlePan:(UIPanGestureRecognizer *)paramPan{   //拖动的点作为锚点
    CGPoint tapPoint = [paramPan locationInView:self.view];
    [self.attachmentBehavior setAnchorPoint:tapPoint];
    self.anchorView.center = tapPoint;   
}
- (void) createAnimatorAndBehaviors{
    
    self.animator = [[UIDynamicAnimator alloc] initWithReferenceView:self.view];
    
    /* Create collision detection */
    UICollisionBehavior *collision = [[UICollisionBehavior alloc]
                                      initWithItems:@[self.squareView]];
    collision.translatesReferenceBoundsIntoBoundary = YES;
//    self.attachmentBehavior = [ [UIAttachmentBehavior alloc] initWithItem:self.squareView
//                               attachedToAnchor:self.anchorView.center];
 

//    self.attachmentBehavior = [ [UIAttachmentBehavior alloc] initWithItem:self.squareViewAnchorView
//                               attachedToAnchor:self.anchorView.center];

   

    //squareView视图右上方的点会跟着锚点一起动,带动了squareView整个视图跟着锚点一起动
    UIOffset offset = UIOffsetMake(self.squareViewAnchorView.center.x, self.squareViewAnchorView.center.y);
    self.attachmentBehavior = [[UIAttachmentBehavior alloc] initWithItem:self.squareView
                                                        offsetFromCenter:offset    //偏移
                                                        attachedToAnchor:self.anchorView.center];

    [self.animator addBehavior:collision];
    [self.animator addBehavior:self.attachmentBehavior];
}

    

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值