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

本文介绍如何使用UIKit Dynamics实现iOS应用中的拖动动画效果。通过创建拖动手势识别器、设置锚点视图及关联动画行为,使得一个视图能够跟随用户的拖动而平滑移动。文中详细展示了创建视图、添加手势识别器及配置动态动画系统的具体步骤。

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];
}

    

10-16 17:11:22.870 24736 24736 D AndroidRuntime: Shutting down VM 10-16 17:11:22.871 24736 24736 E AndroidRuntime: FATAL EXCEPTION: main 10-16 17:11:22.871 24736 24736 E AndroidRuntime: Process: com.android.cts.verifier, PID: 24736 10-16 17:11:22.871 24736 24736 E AndroidRuntime: android.view.WindowManager$BadTokenException: Unable to add window -- token null is not valid; is your activity running? 10-16 17:11:22.871 24736 24736 E AndroidRuntime: at android.view.ViewRootImpl.setView(ViewRootImpl.java:1736) 10-16 17:11:22.871 24736 24736 E AndroidRuntime: at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:537) 10-16 17:11:22.871 24736 24736 E AndroidRuntime: at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:161) 10-16 17:11:22.871 24736 24736 E AndroidRuntime: at com.android.cts.verifier.MainActivity.registerTouchInterceptor(MainActivity.java:128) 10-16 17:11:22.871 24736 24736 E AndroidRuntime: at com.android.cts.verifier.MainActivity$1.onClick(MainActivity.java:53) 10-16 17:11:22.871 24736 24736 E AndroidRuntime: at android.view.View.performClick(View.java:8103) 10-16 17:11:22.871 24736 24736 E AndroidRuntime: at android.view.View.performClickInternal(View.java:8080) 10-16 17:11:22.871 24736 24736 E AndroidRuntime: at android.view.View.-$$Nest$mperformClickInternal(Unknown Source:0) 10-16 17:11:22.871 24736 24736 E AndroidRuntime: at android.view.View$PerformClick.run(View.java:31642) 10-16 17:11:22.871 24736 24736 E AndroidRuntime: at android.os.Handler.handleCallback(Handler.java:995) 10-16 17:11:22.871 24736 24736 E AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:103) 10-16 17:11:22.871 24736 24736 E AndroidRuntime: at android.os.Looper.loopOnce(Looper.java:283) 10-16 17:11:22.871 24736 24736 E AndroidRuntime: at android.os.Looper.loop(Looper.java:392) 10-16 17:11:22.871 24736 24736 E AndroidRuntime: at android.app.ActivityThread.main(ActivityThread.java:9236) 10-16 17:11:22.871 24736 24736 E AndroidRuntime: at java.lang.reflect.Method.invoke(Native Method) 10-16 17:11:22.871 24736 24736 E AndroidRuntime: at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:611) 10-16 17:11:22.871 24736 24736 E AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:944)
最新发布
10-17
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值