自定義啟動界面--帶動畫的

最近做項目,設計做出了一個很好看的動畫..開始用的是加載gif圖片來實現(xiàn)的...后來測試下來發(fā)現(xiàn)內(nèi)存有點兒高,而且在部分機型上gif圖片不能完全加載..作為一個技術屌絲..不能忍..就想著自己寫.

先看下效果圖

啟動頁動畫.gif
思路
分兩步..第一步是通過代碼獲取到啟動頁的圖片
- (UIImage *)getLaunchImage
{
    UIImage *lauchImage = nil;
    NSString *viewOrientation = nil;
    CGSize viewSize = [UIScreen mainScreen].bounds.size;
    UIInterfaceOrientation orientation = [[UIApplication sharedApplication] statusBarOrientation];
    
    if (orientation == UIInterfaceOrientationLandscapeLeft || orientation == UIInterfaceOrientationLandscapeRight) {
        
        viewOrientation = @"Landscape";
        
    } else {
        
        viewOrientation = @"Portrait";
    }
    
    NSArray *imagesDictionary = [[[NSBundle mainBundle] infoDictionary] valueForKey:@"UILaunchImages"];
    for (NSDictionary *dict in imagesDictionary) {
        
        CGSize imageSize = CGSizeFromString(dict[@"UILaunchImageSize"]);
        if (CGSizeEqualToSize(imageSize, viewSize) && [viewOrientation isEqualToString:dict[@"UILaunchImageOrientation"]]) {
            
            lauchImage = [UIImage imageNamed:dict[@"UILaunchImageName"]];
        }
    }
    return lauchImage;
}

第二步..獲取到圖片之后,新建一個imageview..在imageview上寫動畫

- (void)customLaunchImageView
{
    UIImageView *launchImageView = [[UIImageView alloc] initWithFrame:self.window.bounds];
    launchImageView.image = [self getLaunchImage];;
    
    [self.window addSubview:launchImageView];
    [self.window bringSubviewToFront:launchImageView];
    
    myTest1 = [[UILabel alloc]initWithFrame:CGRectMake(5,kHeight-250, 50, 50)];
    myTest1.backgroundColor = [UIColor whiteColor];
    myTest1.textAlignment = NSTextAlignmentCenter;
    myTest1.text = @"程昆侖";
    myTest1.layer.masksToBounds = YES;
    myTest1.layer.cornerRadius = 25;
    myTest1.textColor = [UIColor whiteColor];
    [launchImageView addSubview:myTest1];
    
    logoimageV = [[UIImageView alloc]initWithFrame:CGRectMake((kWidth-300)/2, (kHeight-150)/2, 300, 150)];
    logoimageV.image = [UIImage imageNamed:@"splash_logo"];
    logoimageV.alpha  = 0;
    [launchImageView addSubview:logoimageV];
    
    //路徑動畫。
    CGMutablePathRef myPah = CGPathCreateMutable();
    //CGPathGetCurrentPoint(myPah);
    // CGPathMoveToPoint(myPah, nil,kWidth/2, kHeight/2);
    CGPathMoveToPoint(myPah, nil,30, kHeight-250);//最后的點的位置
    CGPathAddLineToPoint(myPah, nil, kWidth/6, kHeight-100);
    CGPathAddLineToPoint(myPah, nil, kWidth/3, kHeight-200);
    CGPathAddLineToPoint(myPah, nil, kWidth/2, kHeight-100);
    CGPathAddLineToPoint(myPah, nil, kWidth/2, kHeight/2);
    // CGPathRelease(myPah);
    //CGPathCloseSubpath(myPah);

    [myTest1.layer addAnimation:[self keyframeAnimation:myPah durTimes:1.4f Rep:MAXFLOAT] forKey:nil];
    
    dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.f * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
        myTest1.alpha = 0;
        [UIView animateWithDuration:0.3 animations:^{
            logoimageV.alpha = 1;

        } completion:^(BOOL finished) {
            
        }];
        
        [UIView animateWithDuration:0.8 animations:^{
            launchImageView.alpha = 0.0;
            logoimageV.alpha = 1;
            launchImageView.transform = CGAffineTransformMakeScale(1.2, 1.2);
        } completion:^(BOOL finished) {
            [launchImageView removeFromSuperview];
        }];
    });
}

動畫又分成兩種--路徑動畫和擴散動畫
一.路勁動畫..先找?guī)讉€關鍵點...然后把點連成線..讓小球沿著線運動

#pragma mark =====路徑動畫-=============
-(CAKeyframeAnimation *)keyframeAnimation:(CGMutablePathRef)path durTimes:(float)time Rep:(float)repeatTimes
{
    CAKeyframeAnimation *animation = [CAKeyframeAnimation animationWithKeyPath:@"position"];
    animation.path = path;
    animation.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseIn];
    ///animation.autoreverses = NO;//是否原路返回
    animation.duration = time;
    animation.delegate = self;
    animation.removedOnCompletion = NO;
    animation.fillMode = kCAFillModeForwards;
    animation.repeatCount = 1;
    //CGPathCloseSubpath(path);
    // CGPathRelease(path);
    //CGPathCloseSubpath(path);
    return animation;
}

說一下遇到的坑...
1.這兩個屬性連用可以讓動畫結(jié)束后停留在最后的位置..


圖片.png

但是我設置了,小球在第一個動畫結(jié)束后一直會返回到起始點..很詭異..后來我發(fā)現(xiàn),在路徑動畫結(jié)束時,手欠多加了一個屬性..
圖片.png

二.擴散動畫.
在第一個動畫結(jié)束的代理方法里面添加擴散動畫

-(void)addlat {
    
    CABasicAnimation *opacityAnimation = [CABasicAnimation animationWithKeyPath:@"opacity"];
    opacityAnimation.fromValue = [NSNumber numberWithFloat:1.0];
    opacityAnimation.toValue = [NSNumber numberWithFloat:0.0];
    opacityAnimation.duration = 1.5f;
    opacityAnimation.autoreverses= NO;
    // opacityAnimation.delegate = self;
    opacityAnimation.repeatCount = 1;
    //    opacityAnimation.speed = 1.0f;
    
    CABasicAnimation * animation2 = [CABasicAnimation animationWithKeyPath:@"transform.scale"];
    animation2.fromValue = [NSNumber numberWithDouble:0.9];
    animation2.toValue = [NSNumber numberWithDouble:10];
    animation2.duration= 1.5;
    animation2.autoreverses= NO;
    animation2.repeatCount= 1;  //"forever"
    //    animation2.removedOnCompletion= YES;
    [myTest1.layer addAnimation:animation2 forKey:@"scale"];
    [myTest1.layer addAnimation:animation2 forKey:@"scale"];
    [myTest1.layer addAnimation:opacityAnimation forKey:nil];
    [myTest1.layer addAnimation:opacityAnimation forKey:nil];
    
}

這樣就搞定了!

代碼已上傳到github,有需要的小伙伴可以下載下來瞅瞅!


demo地址 :https://github.com/chengkunlun/LunchImageTest

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市袋倔,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌刊侯,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,542評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件锉走,死亡現(xiàn)場離奇詭異滨彻,居然都是意外死亡藕届,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,822評論 3 394
  • 文/潘曉璐 我一進店門亭饵,熙熙樓的掌柜王于貴愁眉苦臉地迎上來休偶,“玉大人,你說我怎么就攤上這事辜羊√ざ担” “怎么了?”我有些...
    開封第一講書人閱讀 163,912評論 0 354
  • 文/不壞的土叔 我叫張陵八秃,是天一觀的道長碱妆。 經(jīng)常有香客問我,道長昔驱,這世上最難降的妖魔是什么疹尾? 我笑而不...
    開封第一講書人閱讀 58,449評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮骤肛,結(jié)果婚禮上纳本,老公的妹妹穿的比我還像新娘。我一直安慰自己腋颠,他們只是感情好繁成,可當我...
    茶點故事閱讀 67,500評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著淑玫,像睡著了一般朴艰。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上混移,一...
    開封第一講書人閱讀 51,370評論 1 302
  • 那天,我揣著相機與錄音侮穿,去河邊找鬼歌径。 笑死,一個胖子當著我的面吹牛亲茅,可吹牛的內(nèi)容都是我干的回铛。 我是一名探鬼主播,決...
    沈念sama閱讀 40,193評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼克锣,長吁一口氣:“原來是場噩夢啊……” “哼茵肃!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起袭祟,我...
    開封第一講書人閱讀 39,074評論 0 276
  • 序言:老撾萬榮一對情侶失蹤验残,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后巾乳,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體您没,經(jīng)...
    沈念sama閱讀 45,505評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡鸟召,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,722評論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了氨鹏。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片欧募。...
    茶點故事閱讀 39,841評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖仆抵,靈堂內(nèi)的尸體忽然破棺而出跟继,到底是詐尸還是另有隱情,我是刑警寧澤镣丑,帶...
    沈念sama閱讀 35,569評論 5 345
  • 正文 年R本政府宣布舔糖,位于F島的核電站,受9級特大地震影響传轰,放射性物質(zhì)發(fā)生泄漏剩盒。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,168評論 3 328
  • 文/蒙蒙 一慨蛙、第九天 我趴在偏房一處隱蔽的房頂上張望辽聊。 院中可真熱鬧,春花似錦期贫、人聲如沸跟匆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,783評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽玛臂。三九已至,卻和暖如春封孙,著一層夾襖步出監(jiān)牢的瞬間迹冤,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,918評論 1 269
  • 我被黑心中介騙來泰國打工虎忌, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留泡徙,地道東北人。 一個月前我還...
    沈念sama閱讀 47,962評論 2 370
  • 正文 我出身青樓膜蠢,卻偏偏與公主長得像堪藐,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子挑围,可洞房花燭夜當晚...
    茶點故事閱讀 44,781評論 2 354