美文网首页
UI梳理——手势

UI梳理——手势

作者: 虫yu | 来源:发表于2016-05-07 18:10 被阅读54次

手势分类:

轻拍手势:UITapGestureRecognizer
轻扫手势:UISwipeGestureRecognizer
长按手势:UILongpreesGestureRecongnzier
平移手势:UIPanGestureRecognizer
缩放手势:UIPinchGestureRecognizer
旋转手势:UIRotationGestureRecognizer
屏幕边界手势:UIScreenEdgePanGestureRecognizer
轻拍手势:UITapGestureRecognizer

手势的创建:

    UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tapAction:)];
    //设置手势
    //1、触发手势的手指个数
    tap.numberOfTouchesRequired = 1;
    //2、触发手势的轻拍次数
    tap.numberOfTapsRequired = 2;
    //3、让imageView添加轻拍手势
    [imageView addGestureRecognizer:tap];
  
    [self.view addSubview:imageView];
    [tap release];

方法的实现:

//前三个的方法都是这么实现的
- (void)tapAction:(UITapGestureRecognizer *)tap {
    //获取手势关联的视图
    UIImageView *imageView = (UIImageView *)tap.view; 
    //修改图片
    [imageView setImage:[UIImage imageNamed:@"mao.jpg"]];
}

轻扫手势:UISwipeGestureRecognizer

//设置轻扫方向
swipe.direction = UISwipeGestureRecognizerDirectionDown;

长按手势:

UILongpreesGestureRecongnzier

//长按手势触发的最短时间,默认0.5
longpress.minimumPressDuration = 3.0;

以下三个手势不需要设置属性, 这里只写他们的方法如何实现:

平移手势:UIPanGestureRecognizer




- (void)panAction(UIPanGestureRecognizer *)pan{
    //获取手势关联的视图
    UIImageView *imageView = (UIImageView *)pan.view;
    CGPoint p = [pan translationInView:imageView];
    
    //改变imageView的形变属性
    //1、发生回弹
//    imageView.transform = CGAffineTransformMakeTranslation(p.x, p.y);
    
    //2、不发生回弹
    imageView.transform = CGAffineTransformTranslate(imageView.transform, p.x, p.y);
//    CGPointZero 清零
    [pan setTranslation:CGPointZero inView:imageView];
}

缩放手势:UIPinchGestureRecognizer

- (void)pinchAction:(UIPinchGestureRecognizer *)pinch{
    //获取手势关联的视图
    UIImageView *imageView = (UIImageView *)pinch.view;
    
    //改变imageView的形变属性
    //1、发生回弹,再次改变的时候会回到原来的基础上,然后改变
//    imageView.transform = CGAffineTransformMakeScale(pinch.scale, pinch.scale);
    //仿射变换
    //2、不发生回弹,根据CGAffineTransformScale 中的imageView.transform,进行缩放
    imageView.transform = CGAffineTransformScale(imageView.transform, pinch.scale, pinch.scale);
    
    //如果不设定,会发生累加
    pinch.scale = 1;
}

旋转手势:UIRotationGestureRecognizer

- (void)rotationAction:(UIRotationGestureRecognizer *)rotate{
    //获取手势关联的视图
    UIImageView *imageView = (UIImageView *)rotate.view;
    //改变imageView的形变属性
    //1、发生回弹
//    imageView.transform = CGAffineTransformMakeRotation(rotate.rotation);
    //2、不发生回弹
    imageView.transform = CGAffineTransformRotate(imageView.transform, rotate.rotation);
    rotate.rotation = 0;
}

屏幕边界手势:UIScreenEdgePanGestureRecognizer

相关文章

  • UI梳理——手势

    手势分类: 手势的创建: 方法的实现: 轻扫手势:UISwipeGestureRecognizer 长按手势: 以...

  • UI总结-手势

    UI总结-手势 常用的6种手势: #import "ViewController.h" @...

  • UI手势

    手势识别器有:轻拍 长按 旋转 捏合 拖拽 清扫 屏幕边缘拖拽 在使用这些手势识别器时 先打开用户交互 image...

  • UI手势

    UIGestureRecongnizer:NSObject 1.-(void)addGestureRecogniz...

  • UI - 手势

    UIGestureRecognizer手势识别器 手势:有规律的触摸 UIGestureRecognizer抽象类...

  • UI手势

    手势:有规律的触摸 UIGestureRecognizer抽象类 七种手势:轻拍(tap)长按(longPress...

  • UI手势

    UIGestureRecognizer手势识别器 手势:有规律的触摸 UIGestureRecognizer抽象类...

  • 5.2 GestureRecognizer---UI手势

    GestureRecognizer---UI手势 基础控制器 导航栏视图控制器, 根试图控制器 单击手势 双击手势...

  • UI手势回顾

    UIGestureRecongnizer手势识别器 手势:有规律的触摸 UIGestureRecognizer抽象...

  • UI手势控件

    一、拖拽 示例代码: 复制代码 1 // 2 // YYViewController.m 3 // 06-拖拽事件...

网友评论

      本文标题:UI梳理——手势

      本文链接:https://www.haomeiwen.com/subject/udqsrttx.html