iOS日常基础记录12

这里这么做的目的,就是对tableVC做一个强引用,还有种做法就是自己写一个属性,强引用这个tableVC,让它不会被释放
readonly的实质是不让调set方法,在当前类能访问下划线的成员变量,在子类中下划线成员变量也是不能访问的
#import <UIKit/UIKit.h>

@interface DragerViewController : UIViewController

@property (nonatomic, weak, readonly)  UIView *mainV;
@property (nonatomic, weak, readonly)  UIView *leftV;

//打开抽屉
- (void)open;
//关闭抽屉
- (void)close;

@end
#import "DragerViewController.h"

@interface DragerViewController ()

@end

@implementation DragerViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    //初始化工作
    [self addChildView];
    
    //添加手势
    UIPanGestureRecognizer *panGes = [[UIPanGestureRecognizer alloc] initWithTarget:self action:@selector(pan:)];
    [self.mainV addGestureRecognizer:panGes];
    
    
    UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(close)];
    [self.leftV addGestureRecognizer:tap];    
    
}

#define screenW [UIScreen mainScreen].bounds.size.width

#define target screenW * 0.8

- (void)pan:(UIPanGestureRecognizer *)pan {
    //让中间红色View平移
    //获取偏移量
    CGPoint transP = [pan translationInView:self.mainV];
    //根据偏移量,计算当前的位置大小
    [self positionWithOffset:transP.x];
    
    //判断手势的状态
    if (pan.state == UIGestureRecognizerStateEnded) {
        //如果当前x值大于屏幕宽度一半时,自动定位到右侧
        if (self.mainV.frame.origin.x > screenW * 0.5) {
            //计算偏移
            [UIView animateWithDuration:0.25 animations:^{
                CGFloat offset = target - self.mainV.frame.origin.x;
                [self positionWithOffset:offset];
            }];
        }else {
             //否则,关闭抽屉(复位)
            [self close];
        }
    }
    
    //清0
    [pan setTranslation:CGPointZero inView:self.mainV];
}


//打开抽屉
- (void)open {
    [UIView animateWithDuration:0.25 animations:^{
        [self positionWithOffset:target];
        CGRect frame = self.mainV.frame;
        frame.origin.x = target;
        self.mainV.frame = frame;
    }];
}


//关闭抽屉
- (void)close {
    [UIView animateWithDuration:0.25 animations:^{
        //清空形变
        self.mainV.transform = CGAffineTransformIdentity;
        //位置复位
        self.mainV.frame = self.view.bounds;
    }];
}


//根据偏移量,计算当前的位置大小
- (void)positionWithOffset:(CGFloat)offset {
    //平移
    CGRect frame = self.mainV.frame;
    frame.origin.x += offset;
    self.mainV.frame = frame;
    
    if (self.mainV.frame.origin.x <= 0) {
        self.mainV.frame = self.view.bounds;
    }
    
    if (self.mainV.frame.origin.x >= target) {
        CGRect frame = self.mainV.frame;
        frame.origin.x = target;
        self.mainV.frame = frame;
    }
    
    
    //原始比例:1
    //0.9 0.8 0.7
    
    //1 - 0.1 = 0.9
    //1 - 0.2 = 0.8
    //1 - 0.3 = 0.7
    //缩放
    //找最大值,最大值0.3
    //当x值等于屏幕宽度时,变化的值是0.3
    CGFloat scale = self.mainV.frame.origin.x *  0.3 / screenW;
    scale = 1 - scale;
    NSLog(@"%f",scale);
    
    //形变
    self.mainV.transform = CGAffineTransformMakeScale(scale, scale);
}

- (void)addChildView {
    //添加子控件
    UIView *leftV = [[UIView alloc] init];
    leftV.backgroundColor = [UIColor blueColor];
    leftV.frame = self.view.bounds;
    [self.view addSubview:leftV];
    _leftV = leftV;
    
    UIView *mainV = [[UIView alloc] init];
    mainV.backgroundColor = [UIColor redColor];
    mainV.frame = self.view.bounds;
    [self.view addSubview:mainV];
    _mainV = mainV;
}

@end
#import "DragerViewController.h"

@interface XMGViewController : DragerViewController

@end
#import "XMGViewController.h"
#import "TableViewController.h"

@interface XMGViewController ()

@end

@implementation XMGViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    
    //如果想要在原始封装通用当中添加一些属性自己的业务逻辑,继承原来的类.自己的业务逻辑写到子类当中.
    TableViewController *tableVC = [[TableViewController alloc] init];
    tableVC.view.frame = self.mainV.bounds;
    /** 如果说一个控制器的View成为另一个控制器View的子控件.
    //那么当前控制器也要成为另一个控制器的子控制器.
    //这里这么做的目的,就是对tableVC做一个强引用,还有种做法就是自己写一个属性,
     强引用这个tableVC,让它不会被释放 */
    [self.mainV addSubview:tableVC.view];
    [self addChildViewController:tableVC];
    
    [self open];
}

@end
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,716评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,558评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,431评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,127评论 0 209
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,511评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,692评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,915评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,664评论 0 202
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,412评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,616评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,105评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,424评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,098评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,096评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,869评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,748评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,641评论 2 271

推荐阅读更多精彩内容