iOS 彈出界面抖動(dòng)動(dòng)畫

QQ20190215-161612-HD.gif

思路:


image.png

其中D點(diǎn)是可動(dòng)的, 其他點(diǎn)都是固定不變的, 哎. 其他思路感覺看代碼就可以了, 還是得增強(qiáng)語言溝通能力, 說不出來, 看代碼吧~??????, 應(yīng)該很好理解的

//
//  JC_DrawerController.m
//  JUNCHUANG
//
//  Created by WYC on 2019/2/14.
//  Copyright ? 2019年 WYC. All rights reserved.
//彈出的抽屜菜單

#import "JC_DrawerController.h"

@interface JC_DrawerController()

@property (nonatomic, strong) UITableView *tableView;

@property (nonatomic, assign) CGPoint pointD;

@property (nonatomic, strong) CADisplayLink *displayLink;

@property (nonatomic, strong) CAShapeLayer *shapeLayer;

@property (nonatomic, strong) UIView *view2;

@end

@implementation JC_DrawerController

-(void)viewDidLoad{
[super viewDidLoad];

self.view.backgroundColor = [UIColor clearColor];


UIBlurEffect *blurEffect =[UIBlurEffect effectWithStyle:UIBlurEffectStyleLight];
UIVisualEffectView *effectView =[[UIVisualEffectView alloc]initWithEffect:blurEffect];
effectView.frame = CGRectMake(0,
                             0, 170,JC_SCREENHEIGHT);

[self.view addSubview:effectView];
UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tapAction)];
effectView.userInteractionEnabled = YES;

[effectView addGestureRecognizer:tap];

}

-(void)tapAction{
[self dismissViewControllerAnimated:YES completion:nil];
}

-(void)viewWillAppear:(BOOL)animated{
[super viewWillAppear:animated];
 [self setAnimation];
}

-(UITableView *)tableView{
if (!_tableView) {
    _tableView = [[UITableView alloc] initWithFrame:CGRectMake(150, 0, JC_SCREENWIDTH - 150, JC_SCREENHEIGHT) style:(UITableViewStylePlain)];
//        _tableView.backgroundColor = [UIColor orangeColor];
    }
return _tableView;
}


-(void)setAnimation{

self.pointD = CGPointMake(70, JC_SCREENHEIGHT * 0.5);
UIView *view1 = [[UIView alloc] init];
view1.center = self.pointD;
view1.bounds= CGRectMake(0, 0, 10, 10);
view1.backgroundColor = [UIColor clearColor];
[self.view addSubview:view1];
self.view2 = view1;
[UIView animateWithDuration:3.0 delay:0.0 usingSpringWithDamping:0.2 initialSpringVelocity:0.1 options:(UIViewAnimationOptionCurveEaseInOut) animations:^{
    self.pointD = CGPointMake(150, JC_SCREENHEIGHT * 0.5);
    view1.center = self.pointD;
    CADisplayLink *displayLink = [CADisplayLink displayLinkWithTarget:self selector:@selector(displayLinkAction)];
    [displayLink addToRunLoop:[NSRunLoop currentRunLoop] forMode:NSDefaultRunLoopMode];
    self.displayLink = displayLink;
} completion:^(BOOL finished) {
    [self.displayLink setPaused:YES];
    self.displayLink = nil;
    [self.view addSubview:self.tableView];
}];

}

-(void)displayLinkAction{

  //重要:只在動(dòng)畫運(yùn)行時(shí)訪問呈現(xiàn)樹中的對(duì)象停士。當(dāng)動(dòng)畫在進(jìn)行中,呈現(xiàn)樹就包含了圖層顯示在屏幕上的那一刻的值利凑。該行為與圖層樹不同卸勺,圖層樹永遠(yuǎn)只表示最終的目標(biāo)值砂沛。
//訪問圖層樹中對(duì)象的presentationLayer屬性將返回一個(gè)在呈現(xiàn)樹中相對(duì)應(yīng)的對(duì)象。你可能會(huì)通過該對(duì)象獲取在動(dòng)畫執(zhí)行過程中的某一時(shí)刻的屬性值曙求。
CALayer *presentLayer = self.view2.layer.presentationLayer;
NSLog(@"%@",NSStringFromCGPoint(presentLayer.position));

UIBezierPath *path = [UIBezierPath bezierPath];
[path moveToPoint:CGPointMake(150, 0)];
[path addLineToPoint:CGPointMake(JC_SCREENWIDTH, 0)];
[path addLineToPoint:CGPointMake(JC_SCREENWIDTH, JC_SCREENHEIGHT)];
[path addLineToPoint:CGPointMake(150, JC_SCREENHEIGHT)];

[path addQuadCurveToPoint:CGPointMake(150, 0)
             controlPoint:presentLayer.position];

[path closePath];
self.shapeLayer.path = path.CGPath;

}


-(CAShapeLayer *)shapeLayer{
if (!_shapeLayer) {
    _shapeLayer = ({
        CAShapeLayer *shapLayer = [CAShapeLayer layer];
        shapLayer.fillColor = [UIColor magentaColor].CGColor;
        [self.view.layer addSublayer:shapLayer];
        shapLayer;
    });
}
return _shapeLayer;
}




@end
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末碍庵,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子悟狱,更是在濱河造成了極大的恐慌静浴,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,682評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件挤渐,死亡現(xiàn)場離奇詭異苹享,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)浴麻,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,277評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門得问,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人白胀,你說我怎么就攤上這事椭赋。” “怎么了或杠?”我有些...
    開封第一講書人閱讀 165,083評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長宣蔚。 經(jīng)常有香客問我向抢,道長认境,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,763評(píng)論 1 295
  • 正文 為了忘掉前任挟鸠,我火速辦了婚禮叉信,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘艘希。我一直安慰自己硼身,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,785評(píng)論 6 392
  • 文/花漫 我一把揭開白布覆享。 她就那樣靜靜地躺著佳遂,像睡著了一般。 火紅的嫁衣襯著肌膚如雪撒顿。 梳的紋絲不亂的頭發(fā)上丑罪,一...
    開封第一講書人閱讀 51,624評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音凤壁,去河邊找鬼吩屹。 笑死,一個(gè)胖子當(dāng)著我的面吹牛拧抖,可吹牛的內(nèi)容都是我干的煤搜。 我是一名探鬼主播,決...
    沈念sama閱讀 40,358評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼唧席,長吁一口氣:“原來是場噩夢啊……” “哼宅楞!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起袱吆,我...
    開封第一講書人閱讀 39,261評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤厌衙,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后绞绒,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體婶希,經(jīng)...
    沈念sama閱讀 45,722評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年蓬衡,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了喻杈。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,030評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡狰晚,死狀恐怖筒饰,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情壁晒,我是刑警寧澤瓷们,帶...
    沈念sama閱讀 35,737評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響谬晕,放射性物質(zhì)發(fā)生泄漏碘裕。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,360評(píng)論 3 330
  • 文/蒙蒙 一攒钳、第九天 我趴在偏房一處隱蔽的房頂上張望帮孔。 院中可真熱鬧,春花似錦不撑、人聲如沸文兢。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,941評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽姆坚。三九已至,卻和暖如春揩页,著一層夾襖步出監(jiān)牢的瞬間旷偿,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,057評(píng)論 1 270
  • 我被黑心中介騙來泰國打工爆侣, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留萍程,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,237評(píng)論 3 371
  • 正文 我出身青樓兔仰,卻偏偏與公主長得像茫负,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子乎赴,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,976評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 專業(yè)考題類型管理運(yùn)行工作負(fù)責(zé)人一般作業(yè)考題內(nèi)容選項(xiàng)A選項(xiàng)B選項(xiàng)C選項(xiàng)D選項(xiàng)E選項(xiàng)F正確答案 變電單選GYSZ本規(guī)程...
    小白兔去釣魚閱讀 8,994評(píng)論 0 13
  • Redis 數(shù)據(jù)備份與恢復(fù) RedisSAVE命令用于創(chuàng)建當(dāng)前數(shù)據(jù)庫的備份忍法。 備份數(shù)據(jù) redis Save 命令...
    stakeing閱讀 509評(píng)論 0 0
  • 《增長黑客》這本書有多火?我在簡書上用該書名作為關(guān)鍵字搜了一下還真是有不少關(guān)于這本書的讀書筆記或者是讀后感之類的文...
    小7閱讀 4,899評(píng)論 12 85
  • 一雨秋涼 秋陽綻開笑靨時(shí) 窗外卻懸掛一簾濛濛煙雨 雨帶來了深秋的微涼 落葉簌簌飄落 雨哪知秋的悲傷 我傾聽著雨聲 ...
    筆耕心田閱讀 449評(píng)論 0 0