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

 更新时间:2015年10月23日 10:53:36   作者:念茜的博客  
这篇文章主要介绍了举例讲解iOS开发中的拖动视图实现,代码基于传统的Objective-C,需要的朋友可以参考下

预备知识
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 


20151023105257759.gif (698×354)

相关文章

  • ios开发navigationController pushViewController 方式多次跳转返回到最上层返回到指定的某一层的实现方法

    ios开发navigationController pushViewController 方式多次跳转返回到最上层返回到

    这篇文章主要介绍了ios开发navigationController pushViewController 方式多次跳转返回到最上层返回到指定的某一层的实现方法的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-09-09
  • iOS使用核心动画和粒子发射器实现点赞按钮的方法

    iOS使用核心动画和粒子发射器实现点赞按钮的方法

    这篇文章主要给大家介绍了iOS如何使用核心动画和粒子发射器实现点赞按钮的方法,文中给出了详细的示例代码,相信对大家的理解和学习具有一定的参考借鉴,有需要的朋友们下面跟着小编一起来学习学习吧。
    2016-12-12
  • IOS-MVC层读取服务器接口JSON数据

    IOS-MVC层读取服务器接口JSON数据

    这篇文章主要为大家详细介绍了IOS-MVC层读取服务器接口JSON数据,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-12-12
  • iOS实现调用QQ客户端发起临时会话

    iOS实现调用QQ客户端发起临时会话

    本篇文章主要给大家详细分析了用IOS实现调用QQ客户端发起临时会话的功能,对此有需要的朋友收藏分享下。
    2018-02-02
  • 详解iOS中集成ijkplayer视频直播框架

    详解iOS中集成ijkplayer视频直播框架

    ijkplayer 是一款做视频直播的框架, 基于ffmpeg, 支持Android和iOS,本文将详细的讲一下在iOS中如何集成ijkplayer, 即便以前从没有接触过,按着下面做也可以集成成功!下面跟着小编一起来看下吧
    2016-12-12
  • iOS开发中Swift3 监听UITextView文字改变的方法(三种方法)

    iOS开发中Swift3 监听UITextView文字改变的方法(三种方法)

    在项目中使用文本输入框出UITextField之外还会经常使用 UITextView ,难免会有需求监听UITextView文本框内文本数量.下面介绍在swift3中两种常用方式,需要的朋友参考下吧
    2016-11-11
  • iOS中常用设置返回按钮

    iOS中常用设置返回按钮

    本文给大家分享一段代码关于iOS中常用设置返回按钮的实现方法,代码简单易懂,非常不错,具有参考借鉴价值,需要的朋友参考下
    2016-12-12
  • iOS实现自动循环播放的banner实例详解

    iOS实现自动循环播放的banner实例详解

    轮播视图通常也叫Banner,90%以上App都会用到的一个控件,网上有很多开源代码,下面这篇文章主要给大家介绍了关于利用iOS如何实现自动循环播放的banner的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下。
    2017-12-12
  • 详解Xcode 9 设置 iOS无线真机调试

    详解Xcode 9 设置 iOS无线真机调试

    本篇文章主要介绍了详解Xcode 9 设置 iOS无线真机调试,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-12-12
  • iOS保存App中的照片到系统相册或自建相册的方法

    iOS保存App中的照片到系统相册或自建相册的方法

    这篇文章主要介绍了iOS保存App中的照片到系统相册或自建相册的方法,示例代码为传统的Objective-C语言写成,需要的朋友可以参考下
    2016-04-04

最新评论