当前位置: 首页 > 编程笔记 >

举例讲解iOS开发中拖动视图的实现

邹桐
2023-03-14
本文向大家介绍举例讲解iOS开发中拖动视图的实现,包括了举例讲解iOS开发中拖动视图的实现的使用技巧和注意事项,需要的朋友参考一下

预备知识
iOS处理屏幕上的触摸动作,主要涉及到以下几个方法:


touchesBegan:withEvent:          //触摸屏幕的最开始被调用

touchesMoved:withEvent:         //移动过程中被调用

touchesEnded:withEvent:         //动作结束时被调用

touchesCancelled:WithEvent:


从方法的命名可以清晰的看出该方法何时被调用,最后一个比较特殊。touchesCancelled:WithEvent:在Cocoa Touch必须响应持续触摸事件的系统中断时调用。
我们只要重写这些方法,来作我们想要作的事情就可以了。

如何实现拖动视图?
1.设置userInteractionEnabled属性为YES,允许用户交互。
2.在触摸动作开始时记录起始点。
3.在移动过程中,计算当前位置坐标与起始点的差值,即偏移量,并且移动视图中心点至偏移量大小的地方。
4.分别限制x坐标、与y坐标,保证用户不可将视图托出屏幕

备注:分别限制x坐标与y坐标的原因是,即使向右拖动不了了,仍需保证可以向下拖动。

其实,功能比较简单,就是iOS手势动画中的拖动。来看一下基本的写法:

1.注册拖动动画


UIPanGestureRecognizer * panGestureRecognizer = [[UIPanGestureRecognizer alloc] initWithTarget:self

                                                                                            action:@selector(doHandlePanAction:)];

    [self.vLight addGestureRecognizer:panGestureRecognizer];


注:vLight就是要加入拖动的View子类。

2.拖动处理函数


- (void) doHandlePanAction:(UIPanGestureRecognizer *)paramSender{

    

    CGPoint point = [paramSender translationInView:self.view];

    NSLog(@"X:%f;Y:%f",point.x,point.y);

    

    paramSender.view.center = CGPointMake(paramSender.view.center.x + point.x, paramSender.view.center.y + point.y);

    [paramSender setTranslation:CGPointMake(0, 0) inView:self.view];

   

}


实现代码
以子类化UIImageView为例


#import <UIKit/UIKit.h>    @interface GragView : UIImageView  {      CGPoint startPoint;  }  @end 

#import "GragView.h"    @implementation GragView    - (id)initWithFrame:(CGRect)frame  {      self = [super initWithFrame:frame];      if (self) {          // Initialization code          //允许用户交互          self.userInteractionEnabled = YES;      }      return self;  }    - (id)initWithImage:(UIImage *)image  {      self = [super initWithImage:image];      if (self) {          //允许用户交互          self.userInteractionEnabled = YES;      }      return self;  }    - (void) touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event  {      //保存触摸起始点位置      CGPoint point = [[touches anyObject] locationInView:self];      startPoint = point;            //该view置于最前      [[self superview] bringSubviewToFront:self];  }    -(void) touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event  {      //计算位移=当前位置-起始位置      CGPoint point = [[touches anyObject] locationInView:self];      float dx = point.x - startPoint.x;      float dy = point.y - startPoint.y;            //计算移动后的view中心点      CGPoint newcenter = CGPointMake(self.center.x + dx, self.center.y + dy);                  /* 限制用户不可将视图托出屏幕 */      float halfx = CGRectGetMidX(self.bounds);      //x坐标左边界      newcenter.x = MAX(halfx, newcenter.x);      //x坐标右边界      newcenter.x = MIN(self.superview.bounds.size.width - halfx, newcenter.x);            //y坐标同理      float halfy = CGRectGetMidY(self.bounds);      newcenter.y = MAX(halfy, newcenter.y);      newcenter.y = MIN(self.superview.bounds.size.height - halfy, newcenter.y);            //移动view      self.center = newcenter;  }    /*  // Only override drawRect: if you perform custom drawing.  // An empty implementation adversely affects performance during animation.  - (void)drawRect:(CGRect)rect  {      // Drawing code  }  */    @end 


 类似资料:
  • 本文向大家介绍实例讲解iOS应用UI开发之基础动画的创建,包括了实例讲解iOS应用UI开发之基础动画的创建的使用技巧和注意事项,需要的朋友参考一下 一、简单介绍 CAPropertyAnimation的子类 属性解析: fromValue:keyPath相应属性的初始值 toValue:keyPath相应属性的结束值 随着动画的进行,在长度为duration的持续时间内,keyPath相应属性的值

  • 本文向大家介绍深入讲解iOS开发中的UIViewController,包括了深入讲解iOS开发中的UIViewController的使用技巧和注意事项,需要的朋友参考一下 UIViewController顾名思义:视图控制器。应该在MVC设计模式中扮演控制层的角色。一些初学者在最开始的时候一直不理解为何有了UIView还要UIViewController做什么用,不都是向视图中增加view。在此我

  • 本文向大家介绍ios可拖动按钮实例,包括了ios可拖动按钮实例的使用技巧和注意事项,需要的朋友参考一下 最近产品抽风,想做许鲜网的那个小客服按钮,虽然没啥难度,但是我懒啊,哈哈,上度娘搞了一个,但是点击事件和拖动重复了,擦。干脆写一个吧,仅供参考。 话不多说,上代码: 以上这篇ios可拖动按钮实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持呐喊教程。

  • 本文向大家介绍举例讲解设计模式中的原型模式在iOS应用开发中的作用,包括了举例讲解设计模式中的原型模式在iOS应用开发中的作用的使用技巧和注意事项,需要的朋友参考一下 1 前言 在许多面向对象的应用程序中,有些对象的创建代价过于大或者过于复杂。要是可以重建相同的对象并作轻微的改动,事情会容易许多。我们可以通过轻微的改动重用已有的对象,以适应程序中的特定情况。今天我们就来学习一下该模式。 2 详述

  • 本文向大家介绍举例讲解AngularJS中的模块,包括了举例讲解AngularJS中的模块的使用技巧和注意事项,需要的朋友参考一下  AngularJS支持模块化的方法。模块用于单独的逻辑表示服务,控制器,应用程序等,并保持代码的整洁。我们在单独的js文件中定义的模块,并将其命名为按照module.js文件形式。在这个例子中,我们要创建两个模块。     Application Module -

  • 本文向大家介绍实例详解IOS开发之UIWebView,包括了实例详解IOS开发之UIWebView的使用技巧和注意事项,需要的朋友参考一下 iOS开发之UIWebView 是本文要介绍的内容,UIWebView是iOS sdk中一个最常用的控件。是内置的浏览器控件,我们可以用它来浏览网页、打开文档等等。这篇文章我将使用这个控件,做一个简易的浏览器。如下图: 我们创建一个Window-based A