码迷,mamicode.com
首页 > 微信 > 详细

利用uitouch简单的实现了微信cell效果

时间:2016-04-24 19:01:19      阅读:376      评论:0      收藏:0      [点我收藏+]

标签:ios   cell   uitouch   

#import <UIKit/UIKit.h>


@interface weixinControl : UIControl

-(weixinControl *)initWithFram:(CGRect)rect;

@end


#import "weixinControl.h"


@implementation weixinControl

{

    CGRect _rect; //记录self.frame的大小

    UIView *_frontView; //用来显示主要内容

    CGPoint _originPoint; //记录开始touch时的position

    CGPoint _currentPoint;//记录当前位置

    CGRect _frontViewOriginRect;//记录frontVie的初始fram

    CGFloat _offsetXPosition; //记录x的位移量

    UIButton *_delBtn; //删除按钮

}

-(weixinControl *)initWithFram:(CGRect)rect

{

    if (self = [super initWithFrame:rect]) {

        self.backgroundColor = [UIColor cyanColor];

        _rect = rect;

        _offsetXPosition = 0.0f;

        [self makeDeletButton];

        [self makeFrontView];

    }

    return self;

}


-(void)makeDeletButton

{

    _delBtn = [UIButton buttonWithType:UIButtonTypeRoundedRect];

    _delBtn.frame = CGRectMake(_rect.size.width - 50, 0, 50, _rect.size.height);

    [_delBtn setTitle:@"删除" forState:UIControlStateNormal];

    _delBtn.backgroundColor = [UIColor redColor];

    [self addSubview:_delBtn];

}


-(void)makeFrontView

{

    _frontView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, _rect.size.width, _rect.size.height)];

    _frontViewOriginRect = _frontView.frame;

    _frontView.backgroundColor = [UIColor blueColor];

    [self addSubview:_frontView];

}


-(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event

{

    UITouch *beganTouch = [touches anyObject];

    _originPoint = [beganTouch locationInView:self];

}


-(void)touchesEnded:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event

{

    if (_offsetXPosition < (0 - _delBtn.frame.size.width)) {

        _frontView.frame = CGRectMake((0 -_delBtn.frame.size.width), _frontViewOriginRect.origin.y, _frontViewOriginRect.size.width, _frontViewOriginRect.size.height);

    }

    else

    {

        _frontView.frame = _frontViewOriginRect;

    }

}


-(void)touchesMoved:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event

{

    UITouch *moveTouch = [touches anyObject];

    _currentPoint = [moveTouch locationInView:self];

    _offsetXPosition = _currentPoint.x - _originPoint.x;

    if (_offsetXPosition >= 0) {

        return;

    }

    _frontView.frame = CGRectMake(_offsetXPosition, _frontViewOriginRect.origin.y, _frontViewOriginRect.size.width, _frontViewOriginRect.size.height);

}

@end


利用uitouch简单的实现了微信cell效果

标签:ios   cell   uitouch   

原文地址:http://dearleo.blog.51cto.com/6718690/1767255

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!