IOS开发UI篇—手势识别器(拖拽+旋转+缩放)

IOS开发UI篇—手势识别器(拖拽+旋转+缩放)

一、拖拽

示例代码:

 1 //
 2 //  YYViewController.m
 3 //  06-拖拽事件
 4 //
 5 //  Created by apple on 14-6-19.
 6 //  Copyright (c) 2014年 itcase. All rights reserved.
 7 //
 8 
 9 #import "YYViewController.h"
10 
11 @interface YYViewController ()
12 @property (strong, nonatomic) IBOutlet UIView *iconView;
13 
14 @end
15 
16 @implementation YYViewController
17 
18 - (void)viewDidLoad
19 {
20     [super viewDidLoad];
21 
22     //拖拽事件
23     UIPanGestureRecognizer *pan=[[UIPanGestureRecognizer alloc]init];
24     [self.iconView addGestureRecognizer:pan];
25     [pan addTarget:self action:@selector(panView:)];
26 }
27 
28 -(void)panView:(UIPanGestureRecognizer*)pan
29 {
30     //以控制器上的view的左上角为坐标原点
31     CGPoint point=[pan locationInView:pan.view];
32     NSLog(@"拖拽事件");
33     NSLog(@"获取到的触摸点的位置为:%@",NSStringFromCGPoint(point));
34     
35     CGPoint point1=[pan translationInView:pan.view];
36     NSLog(@"拖拽事件1");
37     NSLog(@"获取到的触摸点的位置为:%@",NSStringFromCGPoint(point1));
38     
39     //手指拖动,让自定义的view也跟着手指移动
40     CGPoint temp=self.iconView.center;
41     temp.x+=point1.x;
42     temp.y+=point1.y;
43     self.iconView.center=temp;
44     
45     //清空
46     [pan setTranslation:CGPointZero inView:pan.view];
47 }
48 @end

 注意点:1.注意拖拽事件的位移叠加。

注意数学递增性,需要在每次调用完之后进行清空处理。

2.注意获取的点是以手指按下的点为原点的。CGPoint point1=[pan translationInView:pan.view];

    //以控制器上的view的左上角为坐标原点 CGPoint point=[pan locationInView:pan.view];

 

二、旋转

示例代码:

 1 //
 2 //  YYViewController.m
 3 //  07-旋转
 4 //
 5 //  Created by apple on 14-6-19.
 6 //  Copyright (c) 2014年 itcase. All rights reserved.
 7 //
 8 
 9 #import "YYViewController.h"
10 
11 @interface YYViewController ()
12 @property (weak, nonatomic) IBOutlet UIImageView *iconView;
13 
14 @end
15 
16 @implementation YYViewController
17 
18 - (void)viewDidLoad
19 {
20     [super viewDidLoad];
21     
22     //旋转
23     //创建手势识别器(旋转)
24     UIRotationGestureRecognizer *gesture=[[UIRotationGestureRecognizer alloc]init];
25     //添加手势识别器
26     [self.iconView addGestureRecognizer:gesture];
27     //监听
28     [gesture addTarget:self action:@selector(gestureView:)];
29 }
30 
31 -(void)gestureView:(UIRotationGestureRecognizer*)gesture
32 {
33     
34     //旋转的弧度:gesture.rotation
35     NSLog(@"旋转事件,旋转的弧度为:%1f",gesture.rotation);
36     
37     //让图片跟随手指一起旋转
38     //每次从最初的位置开始
39 //    self.iconView.transform=CGAffineTransformMakeRotation(gesture.rotation);
40     
41     //在传入的transform的基础上旋转
42     //在之前的基础上,让图片跟随一起旋转(去掉自动布局)
43     //注意问题:以风火轮的速度旋转
44     self.iconView.transform=CGAffineTransformRotate(self.iconView.transform, gesture.rotation);
45     //将旋转的弧度清零
46     //(注意不是将图片旋转的弧度清零,而是将当前手指旋转的弧度清零)
47     gesture.rotation=0;
48 }
49 @end

 注意点:

1.imageview默认为不可交互的,且不支持多点触控,需要在storyboard中勾选这两项。

2.旋转的度数叠加

3.旋转

将旋转弧度清零之后,每次调用又从零开始。

 

三、缩放

 1 //
 2 //  YYViewController.m
 3 //  07-旋转
 4 //
 5 //  Created by apple on 14-6-19.
 6 //  Copyright (c) 2014年 itcase. All rights reserved.
 7 //
 8 
 9 #import "YYViewController.h"
10 
11 @interface YYViewController ()<UIGestureRecognizerDelegate>
12 @property (weak, nonatomic) IBOutlet UIImageView *iconView;
13 
14 @end
15 
16 @implementation YYViewController
17 
18 - (void)viewDidLoad
19 {
20     [super viewDidLoad];
21     [self pinchTest];
22     [self gestureTest];
23 }
24 
25 -(void)pinchTest
26 {
27         //缩放
28     UIPinchGestureRecognizer *pinch=[[UIPinchGestureRecognizer alloc]init];
29     [self.iconView addGestureRecognizer:pinch];
30     [pinch addTarget:self action:@selector(pinchView:)];
31     
32     //设置代理
33     pinch.delegate=self;
34 }
35 
36 -(void)pinchView:( UIPinchGestureRecognizer* )pinch
37 {
38     //缩放的比例    pinch.scale;
39     NSLog(@"缩放:%f",pinch.scale);
40     //对图片进行缩放
41 //    self.iconView.transform=CGAffineTransformMakeScale(pinch.scale,pinch.scale);
42     //在已有的基础上对图片进行缩放
43     self.iconView.transform=CGAffineTransformScale(self.iconView.transform, pinch.scale, pinch.scale);
44     //清零
45     pinch.scale=1.0;
46 }
47 -(void)gestureTest
48 {
49     //旋转
50     //创建手势识别器(旋转)
51     UIRotationGestureRecognizer *gesture=[[UIRotationGestureRecognizer alloc]init];
52     //添加手势识别器
53     [self.iconView addGestureRecognizer:gesture];
54     //监听
55     [gesture addTarget:self action:@selector(gestureView:)];
56     
57     //设置代理
58     gesture.delegate=self;
59 }
60 -(void)gestureView:(UIRotationGestureRecognizer*)gesture
61 {
62     
63     //旋转的弧度:gesture.rotation
64     NSLog(@"旋转事件,旋转的弧度为:%1f",gesture.rotation);
65     
66     //让图片跟随手指一起旋转
67     //每次从最初的位置开始
68 //    self.iconView.transform=CGAffineTransformMakeRotation(gesture.rotation);
69     
70     //在传入的transform的基础上旋转
71     //在之前的基础上,让图片跟随一起旋转(去掉自动布局)
72     //注意问题:以风火轮的速度旋转
73     self.iconView.transform=CGAffineTransformRotate(self.iconView.transform, gesture.rotation);
74     //将旋转的弧度清零
75     //(注意不是将图片旋转的弧度清零,而是将当前手指旋转的弧度清零)
76     gesture.rotation=0;
77 }
78 
79 //实现代理方法
80 -(BOOL)gestureRecognizer:(UIGestureRecognizer *)gestureRecognizer shouldRecognizeSimultaneouslyWithGestureRecognizer:(UIGestureRecognizer *)otherGestureRecognizer
81 {
82     //默认为NO,这里设置为YES
83     return YES;
84 }
85 @end

 提示:设置手势识别器的代理,使用代理让代理方法返回一个YES的布尔值,能够响应多个手势。

 说明:手指按下的时候为1.如果不进行清零,那么缩放也是叠加的(1.0*0.9*0.8)。

 

IOS开发UI篇—手势识别器(拖拽+旋转+缩放),,5-wow.com

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。