iOS界面-页面和动画切换

来源:互联网 发布:pdf转图片软件 编辑:程序博客网 时间:2024/04/29 07:03

  从事iOS开发也有将近一年,以前出了问题都是网上去别人的博客里找资料,现在自己记录下来,权作当是巩固一下,也方便以后查阅。

  今天在开发的时候需要自己做一个欢迎界面,要求有界面切换,网上找了些资料,自己试了一下,效果实现了。

  UIView有一个_layer(CALayer)的属性,通过该属性来实现绘画界面。动画效果由类CATransition来实现。

/* The name of the transition. Current legal transition types include

 * `fade', `moveIn', `push' and `reveal'. Defaults to `fade'. */


@property(copy) NSString *type;


/* An optional subtype for the transition. E.g. used to specify the

 * transition direction for motion-based transitions, in which case

 * the legal values are `fromLeft', `fromRight', `fromTop' and

 * `fromBottom'. */


@property(copy) NSString *subtype;

CATransition的两个主要属性,type是切换的样式,例如渐隐,覆盖;subtype是切换方向,从左或是右

type

{

kCATransitionFade,//淡入淡出

kCATransitionMoveIn,//覆盖

kCATransitionPush,//推挤

kCATransitionReveal,//揭开

//以上4种我在类库里面能找到,下面的几种是在网上看来的,需要注意的是字符串大小写不能搞错,否则会不生效

   cube,                       //立方体

   suckEffect,                 //吮吸

   oglFlip,                    //翻转

   rippleEffect,               //波纹

   pageCurl,                   //翻页

   pageUnCurl,                 //反翻页

   cameraIrisHollowOpen,       //开镜头

   cameraIrisHollowClose,      //关镜头

}


subtype

{

       kCATransitionFromLeft;

       kCATransitionFromBottom;

       kCATransitionFromRight;

       kCATransitionFromTop;

设置完加载方式后,还有两个重要属性:切换的时间和运动效果

/* The basic duration of the object. Defaults to 0. */


@property CFTimeInterval duration;

/* A timing function defining the pacing of the animation. Defaults to

 * nil indicating linear pacing. */


@property(strong)CAMediaTimingFunction *timingFunction;


duration是设置切换效果的持续时间,长短自己设置


timingFunction

{

CA_EXTERNNSString * const kCAMediaTimingFunctionLinear

CA_EXTERNNSString * const kCAMediaTimingFunctionEaseIn

CA_EXTERNNSString * const kCAMediaTimingFunctionEaseOut

CA_EXTERNNSString * const kCAMediaTimingFunctionEaseInEaseOut

CA_EXTERNNSString * const kCAMediaTimingFunctionDefault

}

animation.timingFunction = [CAMediaTimingFunctionfunctionWithName:kCAMediaTimingFunctionEaseIn];


这四个属性设置完成之后,就可以调用CALayer::addAnimation:(CAAnimation *)forKey:(NSString *)来实现效果了。

[self.view.layer addAnimation:transition forKey@"animation"]


调用该函数之后,当前界面就会显示相应的效果。如果这个时候要替换背景图片,就能实现页面以特定的方式切换。


接下来实现动画切换,动画切换主要是调用UIView的block动画来完成。

+ (void)animateWithDuration:(NSTimeInterval)duration animations:(void (^)(void))animationsNS_AVAILABLE_IOS(4_0);// delay = 0.0, options = 0, completion = NULL


UIViewAnimationTransitionNone 正常
UIViewAnimationTransitionFlipFromLeft 从左向右翻
UIViewAnimationTransitionFlipFromRight 从右向左翻
UIViewAnimationTransitionCurlUp 从下向上卷
UIViewAnimationTransitionCurlDown 从上向下卷 


    [UIViewanimateWithDuration:1.0 animations:^{

        [UIViewsetAnimationCurve:UIViewAnimationCurveEaseInOut];

        [UIViewsetAnimationTransition:UIViewAnimationTransitionFlipFromLeft forView:self.viewcache:YES];

    }];

或是其他加入延时、结束切换等操作的函数

    [UIViewanimateWithDuration:2.0animations:^{

        [UIViewsetAnimationCurve:UIViewAnimationCurveEaseInOut];

        [UIViewsetAnimationTransition:UIViewAnimationTransitionFlipFromLeftforView:self.viewcache:YES];}

           completion:^(BOOL Finish){

               NSLog(@"Finish");

            }

     ];










0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 拔完智齿神经疼怎么办 22岁腿关节疼痛怎么办 耳洞里面有硬块怎么办 耳洞发炎有硬块怎么办 小孩慢性扁桃体发炎怎么办大全 侧切伤口化脓了怎么办 狗狗伤口不愈合怎么办 狗后腿烂了化脓怎么办 乳腺增生腋下淋巴结肿大怎么办 手术刀口冒脓了怎么办 脚伤口感染肿了怎么办 皮外伤口不愈合怎么办 烫伤新皮红红的怎么办 脸上痘痘化脓了怎么办 痘痘引起的红肿怎么办 痘痘引起的硬块怎么办 痘痘化脓感染了怎么办 烫伤有脓了烂掉怎么办 烫伤起泡破皮了怎么办 一出汗就有狐臭怎么办 耳朵后面臭臭的怎么办 赤黑abo意外怀孕怎么办 qq忘记密保了怎么办 三星s8耗电太快怎么办 360云盘关闭照片怎么办 360云盘停止服务怎么办 房间湿度90%太高怎么办 天刀掠夺进错了怎么办 狗耳朵臭怎么办黄垢 狗耳朵里有味道怎么办 电视没了泰捷怎么办 配资公司跑路怎么办 口袋忍者倒闭了怎么办 小樱死了,佐助怎么办 别人诬陷我我该怎么办 亲戚诬陷我偷钱怎么办 被别人怀疑偷钱怎么办 有人诬陷我偷鱼怎么办, 寝室里有人偷钱怎么办 6s被偷一直关机怎么办 苹果6被偷了关机怎么办