沿Y轴的空间旋转动画

项目更新,要做旋转动画,找到几种方法来实现,在此做下记录,以便日后使用方便!

1、 实现图片的自动旋转

如果你门项目要求很简单,就是想让它旋转一下,那么下面这个就很适合你!

根据设定的时间,设定的弧度自动旋转

CABasicAnimation* rotationAnimation;

//此处可根据需要设置x/y/z轴

rotationAnimation = [CABasicAnimationanimationWithKeyPath:@"transform.rotation.y"];

//fromValue 和 toValue 这两个参数控制着方向

rotationAnimation.fromValue =[NSNumbernumberWithFloat:M_PI/2];

rotationAnimation.toValue= [NSNumbernumberWithFloat:M_PI/2];

rotationAnimation.duration=0.3;

rotationAnimation.cumulative=NO;

rotationAnimation.repeatCount=0;

rotationAnimation.autoreverses=YES; //自动回放

[imageView.layeraddAnimation:rotationAnimationforKey:@"rotationAnimation"];

通过以上代码就可以设置一张图片的自动旋转啦!

但是,如果你要是旋转了180°,那么图片是反的,无解!!!图片对称没问题

2、 切换图片的旋转

在我们的项目中,要求了旋转后要更换图片,甚至界面,所以旋转升级了

1.构建两个视图,利用系统封装好的转换动画进行切换

核心代码 :

[UIViewtransitionFromView:fromView toView:toView duration:1 options:UIViewAnimationOptionTransitionFlipFromLeft  completion:^(BOOLfinished) {

}];

//UIViewAnimationOptionTransitionFlipFromLeft这个属于转场形式,所以你可以自己选

代码示例:

使用:

_switchView= [[SwitchAnimaViewalloc]initWithFrame:CGRectMake(self.view.frame.size.width-60,0,40,40*ONEHIGHT_VIEW)];

_switchView.backgroundColor= [UIColorcolorWithWhite:0.0alpha:1];

[commentMaskViewaddSubview:self.switchView];

UIView*backView=[[UIViewalloc]initWithFrame:_switchView.bounds];

UIView*frontView=[[UIViewalloc]initWithFrame:_switchView.bounds];

UIButton*shopB = [UIButtonnew];

[shopBsetImage:[UIImageimageNamed:@"img"]forState:UIControlStateNormal];

[shopBaddTarget:selfaction:@selector(btnClick:)forControlEvents:UIControlEventTouchUpInside];

shopB.frame=CGRectMake(0,0,40,40);

[backViewaddSubview:shopB];

_switchView.backView= backView;

UIButton*interactionB = [UIButtonnew];

[interactionBsetImage:[UIImageimageNamed:@"img2"]forState:UIControlStateNormal];

[interactionBaddTarget:selfaction:@selector(btnClick:)forControlEvents:UIControlEventTouchUpInside];

interactionB.frame=CGRectMake(0,0,40,40);

[frontViewaddSubview:interactionB];

_switchView.frontView= frontView;



- (void)btnClick:(UIButton*)sender{

            _switchView.isBeginFlip=YES;

}

//封装

#import"SwitchAnimaView.h"

@implementationSwitchAnimaView

- (instancetype)initWithFrame:(CGRect)frame {

        if(self=[superinitWithFrame:frame]) {

                self.backView.backgroundColor= [UIColorcolorWithWhite:0.0alpha:0];

                self.frontView.backgroundColor= [UIColorcolorWithWhite:0.0alpha:0];

                self.goingToFrontView=NO;

            }

           returnself;

}

- (void)setFrontView:(UIView*)frontView {

        if(!_frontView) {

            _frontView=frontView;

            [selfaddSubview:frontView];

            [selfbringSubviewToFront:self.frontView];

        }

}

- (void)setBackView:(UIView*)backView {

        if (!_backView) {

            _backView=backView;

          }

}

- (void)setIsBeginFlip:(BOOL)isBeginFlip {

            self.goingToFrontView= !self.goingToFrontView;

            UIView*fromView =self.goingToFrontView?self.frontView:self.backView;

            UIView*toView =self.goingToFrontView?self.backView:self.frontView;

            [UIViewtransitionFromView:fromView toView:toView duration:1 options:UIViewAnimationOptionTransitionFlipFromLeft  completion:^(BOOLfinished) {

            }];

}

分析/注意:1.如果你要转这个布局中的某个视图,那么最好把封装到,因为弄不好你会把根视图旋转的

2.如果你的图片背景是透明的,那么效果不是很好

NO.3 可控制的旋转,切换图片

这种我是看到京东app中,商品图片右下角的1/4字样,旋转180°,变成2/4,图片仍然是正的, 并且它会跟着上面商品轮播的偏移值的大小改变图片的旋转角度。这让我绞尽脑汁,查了很多方法,但是后来仔细观察才知道,他正旋转了90°,逆向旋转90°

很简单就是利用了一句核心代码 :

imgView.layer.transform=CATransform3DMakeRotation(angle/2,0,1,0);

实现代码:

- (void)viewDidLoad {

        [superviewDidLoad];

        // Do any additional setup after loading the view.

        self.view.backgroundColor= [UIColorwhiteColor];

        UIImage*imag = [UIImageimageNamed:@"image1"];

        UIImageView*parentView = [[UIImageViewalloc]initWithFrame:CGRectMake(100,150, imag.size.width+3, imag.size.height)];

        parentView.image=imag;

        parentView.tag=1000;

        [self.viewaddSubview:parentView];

        UIButton*button=[UIButtonbuttonWithType:(UIButtonTypeSystem)];

        button.frame=CGRectMake(0,0,100,80);

        [buttonsetImage:imagforState:UIControlStateNormal];

        [buttonaddTarget:selfaction:@selector(buttonClick)forControlEvents:(UIControlEventTouchUpInside)];

        [self.viewaddSubview:button];

}

- (void)buttonClick{

        b= !b;

        if(!_timer) {

        _timer= [NSTimertimerWithTimeInterval:0.05target:selfselector:@selector(timerAction)userInfo:nilrepeats:YES];

        [[NSRunLoopmainRunLoop]addTimer:self.timerforMode:NSDefaultRunLoopMode];

    }

}

- (void)timerAction{

        UIImageView*parentView = [self.viewviewWithTag:1000];

        if(angleM_PI-0.05) {

        parentView.image=b?[UIImageimageNamed:@"image2"]:[UIImageimageNamed:@"image1"];

        a=YES;

}

//a 用来控制旋转角度的

if(a==NO) {

    angle+=0.1;

}

if(a==YES) {

    angle-=0.1;

}

//CATransform3DMakeRotation(角度,x,y,z);

parentView.layer.transform=CATransform3DMakeRotation(angle/2,0,1,0);

if(angle<0.01) {

    // 完成动画,重置

    [_timerinvalidate];

    _timer=nil;

    angle=0;    

    a=NO;

    }

}

搞定!!!

简单的旋转动画基本已经实现,Demo什么的就不放了!

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

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,019评论 4 62
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,442评论 25 707
  • 爱,当恨如潮水般涌来,爱会慢慢生根发芽,当潮水退去,茁壮成长之后,它便能遮天蔽日,予人以清凉
    姑苏蓝儿阅读 106评论 0 0
  • 你知道为什么乌鸦长得像写字台吗? ——《爱丽丝梦游仙境》 为什么爱丽丝每次都是在现实中受挫才进入梦境世界的呢? 在...
    苦桃1阅读 680评论 0 2
  • 当美西战争爆发后,美国必须立即跟西班牙的反抗军首领加西亚取得联系。加西亚在古巴丛林的山里,没有人知道确切的地点,无...
    HRPARK阅读 635评论 0 3