摩拜贴纸的仿真动画以及传感器

先看看摩拜贴纸的动画:

知识点归纳:

  • 使用重力行为
  • 使用碰撞行为
  • 使用弹力行为
  • 使用屏幕旋转的传感器

代码实现:

  1. 创建若干个小球(UIImageView)
    NSMutableArray *ballViewArr = [NSMutableArray array];
    for(int i=0;i<imageArr.count;i++)
    {
        UIImageView * imgView = [[UIImageView alloc]initWithFrame:CGRectMake(arc4random()%((int)(self.view.bounds.size.width-diameter)), 0, diameter, diameter)];
        imgView.image = [UIImage imageNamed:imageArr[i]];
        imgView.layer.masksToBounds = YES;
        imgView.layer.cornerRadius = diameter/2;
        [self.view addSubview:imgView];
        
        [ballViewArr addObject:imgView];
    }

2.创建动画的播放者

    //_animator为全局定义的,否则不会生效,self.view为力学参考系,动力效果才能生效
    _animator = [[UIDynamicAnimator alloc]initWithReferenceView:self.view];

3.创建动力行为,并赋给小球

    //添加重力
    _gravity = [[UIGravityBehavior alloc]initWithItems:ballViewArr];
    [_animator addBehavior:_gravity];
    
    //添加碰撞
    UICollisionBehavior *collision = [[UICollisionBehavior alloc]initWithItems:ballViewArr];
    collision.translatesReferenceBoundsIntoBoundary = YES;
    [_animator addBehavior:collision];
    
    //添加弹性
    UIDynamicItemBehavior *dyItem = [[UIDynamicItemBehavior alloc]initWithItems:ballViewArr];
    dyItem.allowsRotation = YES;
    dyItem.elasticity = 0.8;        //弹性系数
    [_animator addBehavior:dyItem];
    
    //还有很多behavior:UIAttachmentBehavior(附着行为)、UISnapBehavior(捕捉行为)、UIPushBehavior(推动行为)、UIDynamicItemBehavior(动力元素行为)

4.创建检测屏幕旋转的传感器,并计算新的弧度给重力行为属性赋值

-(void)initGyroManager
{
    self.motionManager = [[CMMotionManager alloc]init];
    self.motionManager.deviceMotionUpdateInterval = 0.01;
    
    [self.motionManager startDeviceMotionUpdatesToQueue:[NSOperationQueue mainQueue] withHandler:^(CMDeviceMotion * _Nullable motion, NSError * _Nullable error) {
        //返回至原点的方位角
        double rotation = atan2(motion.attitude.pitch, motion.attitude.roll);
        NSLog(@"rotation:%f",motion.attitude.pitch);
        self.gravity.angle = rotation;
    }];
}
-(void)dealloc
{
    [self.motionManager stopDeviceMotionUpdates];
}

这样,代码就搞定咯。另外可以参考:iOS进阶 - UIDynamic以及iOS的一些传感器

此篇博客的Demo地址

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 15,490评论 4 61
  • 有点犹豫要不要分享这个地方。我为了写游记回头做行程表的时候(去年出游的时候说走就走,什么功课都没做),这个地方因为...
    飘荡的小白阅读 1,488评论 2 3
  • 《匆匆一聚》 久别重逢须百杯, 相见苦短难醉欢。 共赴机场又相送, 君飞虹桥我美兰。 白云山人 20170927
    赛德传播阅读 587评论 0 0
  • 我喜欢过一个boy 那是在高二,我们是前后桌,我比较贪玩,叛逆。他是乖乖boy? no 乖戾 ( •́ .̫ ...
    风格_168阅读 550评论 0 0
  • 朋友圈中看到陆明光的《金泽少年的画很有韵味》,转发一篇文章,介绍金泽青少年画的桥,画得确实好。 有感而发,写了首小...
    黄叶村人阅读 181评论 2 2

友情链接更多精彩内容