设计模式之-代理模式(Proxy)

1,简介

定义:为其他对象提供一种代理,以控制对这个对象的访问。

     代理模式中的角色:

抽象角色:声明真实对象和代理对象的共同接口; 
代理角色:代理对象角色内部含有对真实对象的引用,从而可以操作真实对象,同时代理对象提供与真实对象相同的接口以便在任何时刻都能代替真实对象。同时,代理对象可以在执行真实对象操作时,附加其他的操作,相当于对真实对象进行封装。 
真实角色:代理角色所代表的真实对象,是我们最终要引用的对象。
代理模式结构图如下:


2,代理模式的优点

(1).职责清晰
真实的角色就是实现实际的业务逻辑,不用关心其他非本职责的事务,通过后期的代理完成一件完成事务,附带的结果就是编程简洁清晰。
(2).代理对象可以在客户端和目标对象之间起到中介的作用,这样起到了中介的作用和保护了目标对象的作用。
(3).高扩展性

3,OC代理模式Demo

1)协议类  抽象角色


2)代理角色  MyView (代理类)

MyView.h


MyView.m

#import "MyView.h"
#import "MyViewDelegate.h"

@implementation MyView

//子控件的初始化方法
//子控件view上 添加了三个手势,一个点击,一个左划,一个右划,  还有一个label,label上有两个手势,上划,下划
- (id)initWithFrame:(CGRect)frame
{
    self = [super initWithFrame:frame];
    if (self) {
        self.backgroundColor = [UIColor lightGrayColor];
        
        _messageLabel = [[UILabel alloc] initWithFrame:CGRectMake(25, 25, 120, 120)];
        _messageLabel.text = @"No Message";
        _messageLabel.backgroundColor = [UIColor grayColor];
        _messageLabel.font = [UIFont systemFontOfSize:14];
        _messageLabel.textAlignment = UITextAlignmentCenter;
        _messageLabel.textColor = [UIColor whiteColor];
        _messageLabel.userInteractionEnabled = YES;
        
        //定义一个滑动的手势, initWithTarget:self, 这里一定是self,而不能是_messageLabel
        UISwipeGestureRecognizer *swipUp = [[UISwipeGestureRecognizer alloc]initWithTarget:self action:@selector(swipUpGestureUp:)];
        //设置手势的滑动方向
        swipUp.direction = UISwipeGestureRecognizerDirectionUp;
        
        UISwipeGestureRecognizer *swipDown = [[UISwipeGestureRecognizer alloc]initWithTarget:self action:@selector(swipDownGestureDown:)];
        swipDown.direction = UISwipeGestureRecognizerDirectionDown;
        //将手势添加到label上
        [_messageLabel addGestureRecognizer:swipUp];
        [_messageLabel addGestureRecognizer:swipDown];
        
        [self addSubview:_messageLabel];
        
        
        UITapGestureRecognizer *tapGesture = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tapGestureEvent:)];
        tapGesture.numberOfTapsRequired = 1;
        tapGesture.numberOfTouchesRequired = 1;
        [self addGestureRecognizer:tapGesture];
        
        UISwipeGestureRecognizer *swipGesture1 = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(swipGestureEvent1:)];
        
        swipGesture1.direction = UISwipeGestureRecognizerDirectionLeft;
        [self addGestureRecognizer:swipGesture1];
        
        UISwipeGestureRecognizer *swipGesture2 = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(swipGestureEvent2:)];
        swipGesture2.direction = UISwipeGestureRecognizerDirectionRight;
        [self addGestureRecognizer:swipGesture2];
        
    }
    return self;
}
//点击手势
- (void)tapGestureEvent:(UIGestureRecognizer *)tapGesture
{
    // 先判断自己的代理中是否实现了协议中的方法,如果实现了就去执行,如果没有实现,自己做处理。
    if ([self.delegate respondsToSelector:@selector(tapTouchEvent:)]) {
        [self.delegate tapTouchEvent:self];
    }else{
        NSLog(@"tapTouchEvent Not Found");
    }
}
//左划手势
- (void)swipGestureEvent1:(UIGestureRecognizer *)swipGesture1
{
    if ([self.delegate respondsToSelector:@selector(swipTouchEventLeft:)]) {
        [self.delegate swipTouchEventLeft:self];
    }else{
        NSLog(@"swipTouchEventLeft Not Found");
    }
}
//右划手势
- (void)swipGestureEvent2:(UIGestureRecognizer *)swipGesture2
{
    if ([self.delegate respondsToSelector:@selector(swipTouchEventRight:)]) {
        [self.delegate swipTouchEventRight:self];
    }else{
        NSLog(@"swipTouchEventRight Not Found");
    }
}
//上划手势
- (void)swipUpGestureUp:(UISwipeGestureRecognizer *)swipUpGesture
{
    NSLog(@"messageLabel swipUpGesture");
}
//下划手势
- (void)swipDownGestureDown:(UISwipeGestureRecognizer *)swipDownGesture
{
    NSLog(@"messageLabel swipDownGesture");
}

3)真实角色 (实现类)




Demo:

http://download.csdn.net/detail/walden00/9081615 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值