iOS_捏合及旋转手势的使用

给他图片等视图加上一个或多个手势,这样可以使程序效果更炫酷一点,下面就提供了两种手势的使用方法,建议真机测试,这样比较好直观的感受下手势的使用。

-(void)loadImage {
    UIImageView *imageView = [[UIImageView alloc] initWithFrame:CGRectMake(0, 100, self.view.frame.size.width, 300)];
    imageView.image = [UIImage imageNamed:@"1.jpeg"];
    //用户交互的属性一定要设置为YES
    imageView.userInteractionEnabled = YES;
    
    //捏合手势
    UIPinchGestureRecognizer *pinchGes= [[UIPinchGestureRecognizer alloc] initWithTarget:self action:@selector(pinchAction:)];
    //旋转手势
    UIRotationGestureRecognizer *rotation = [[UIRotationGestureRecognizer alloc] initWithTarget:self action:@selector(rotationAction:)];
    
    [imageView addGestureRecognizer:pinchGes];
    [imageView addGestureRecognizer:rotation];
    
    [self.view addSubview:imageView];
}
-(void)pinchAction:(UIPinchGestureRecognizer *)pinch {
    //获取手势的当前视图
    UIImageView *imageView = (UIImageView *)pinch.view;
    //缩放视图
    imageView.transform = CGAffineTransformScale(imageView.transform, pinch.scale, pinch.scale);
    //将缩放值归为单位值
    pinch.scale = 1;
}

-(void)rotationAction:(UIRotationGestureRecognizer *)rotation {
    //获取手势的当前视图
    UIImageView *imageView = (UIImageView *)rotation.view;
    //旋转视图
    imageView.transform = CGAffineTransformRotate(imageView.transform, rotation.rotation);
    //将旋转量归为单位值
    rotation.rotation = 0;
}

如果想让视图可以同时响应两种或多种手势(一边旋转一边缩放),只要实现一个delegate方法就可以了:

<UIGestureRecognizerDelegate>
    //视图满足两种或多种手势可以一起响应
    pinchGes.delegate = self;
    rotation.delegate = self;
- (BOOL)gestureRecognizer:(UIGestureRecognizer *)gestureRecognizer shouldRecognizeSimultaneouslyWithGestureRecognizer:(UIGestureRecognizer *)otherGestureRecognizer {
    return YES;
}






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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值