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

2016-02-19 10:56 9 1 收藏

今天图老师小编要向大家分享个举例讲解iOS开发中拖动视图的实现教程,过程简单易学,相信聪明的你一定能轻松get!

【 tulaoshi.com - 编程语言 】

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

代码如下:

touchesBegan:withEvent:          //触摸屏幕的最开始被调用
touchesMoved:withEvent:         //移动过程中被调用
touchesEnded:withEvent:         //动作结束时被调用
touchesCancelled:WithEvent:


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

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

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

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

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

1.注册拖动动画

代码如下:

UIPanGestureRecognizer * panGestureRecognizer = [[UIPanGestureRecognizer alloc] initWithTarget:self
                                                                                            action:@selector(doHandlePanAction:)];
    [self.vLight addGestureRecognizer:panGestureRecognizer];

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

注: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 

来源:https://www.tulaoshi.com/n/20160219/1596159.html

延伸阅读
把"秘密"的Cell效果整体视图都放到scrollView中,基本是和secret app 一模一样的效果了. 代码如下:(模糊效果的类就不写了,大家可以搜"UIImage+ImageEffects",还要导入Accelerate.framework) 1.MTSecretAppEffect.h 代码如下: #import Foundation/Foundation.h    @interface MTSecretAppEffect : NSObject    /** ...
在iOS7之前,View Controller的切换主要有4种: Push/Pop,NavigationViewController Present and dismis Modal UITabBarController addChildViewController(一般用于自定义的继承于 UIViewController 的容器子类) iOS5,调用- (void)transitionFromViewController:(UIViewController *)fromViewController toViewController:(UIViewContro...
发送邮件 1.导入库文件:MessageUI.framework 2.引入头文件 3.实现代理MFMailComposeViewControllerDelegate 和 UINavigationControllerDelegate 代码示例:代码如下: - (void)didClickSendEmailButtonAction{        if ([MFMailComposeViewController canSendMail] == YES) {      &...
无限轮播(新闻数据展示) 一、实现效果 二、实现步骤 1.前期准备 (1)导入数据转模型的第三方框架MJExtension (2)向项目中添加保存有“新闻”数据的plist文件 (3)导入用到的图片素材 2.步骤和代码 (1)新建一个数据模型 该模型的代码设计如下: YYnews.h文件 代码如下: // //  YY...
一、简单说明 1.说明 在开发应用的时候,数据的安全性至关重要,而仅仅用POST请求提交用户的隐私数据,还是不能完全解决安全问题。 如:可以利用软件(比如Charles)设置代理服务器,拦截查看手机的请求数据 “青花瓷”软件 因此:提交用户的隐私数据时,一定不要明文提交,要加密处理后再提交 2.常见的加密算法 MD5 \ SHA \ DES ...

经验教程

387

收藏

79
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部