CATransform3D

近期公司UI美女给我看了一个她做的界面,然后当做到一个类似淘宝购物车购买的界面的动画时候,说有些不懂其原理。叫我给她讲解一下。我看了一看,有以下两个思路:

  • 转场动画实现。
  • 直接使用CATransform3D + UIVIew动画来实现。
    于是乎,复习了一下CATransform3D。

首先网上查了查关于CATransform3D的资料,理清了一些思绪后,开始了实现。
当作者翻阅几篇博客的时候,发现有段代码:

//首先初始化一个trans
        var trans = CATransform3DIdentity
//对其进行角度运算
        let angel = CGFloat(M_PI/4)
//利用3D转换
        trans = CATransform3DMakeRotation(angel, 1, 0, 0)
//赋值
        transformView.layer.transform = trans

然后会发现翻转的视图变小了。

图片.png

打开视图查看器,你会发现视图确实是翻转了,视图变小的原因原来是因为投影的问题。于是乎,网上的说法是直接加上以下的代码:

trans.m34 = -1/2000

表示可以让视图成透视投影(远小近大)而不是正交投影,具体可以参见此博客GoTo---------->
然而,作者写了这段代码,发现效果并没有变。Zzzzz..


于是又翻阅了十几篇博客,更去了解了高中投影和矩阵的一些知识。
终于,翻到了以下关键性的代码,作者是这样理解的:
Objective-C:

- (CATransform3D)CATransform3DMakePerspective:(CGPoint)center with:(CGFloat)idz{
//中心点
    CATransform3D transformToCenter = CATransform3DMakeTranslation(-center.x, -center.y, 0);
//从后边看
    CATransform3D tansformback = CATransform3DMakeTranslation(center.x, center.y, 0);
//初始化一个transform
    CATransform3D trans = CATransform3DIdentity;
//根据m34(透视效果,要操作的这个对象要有旋转的角度,否则没有效果。正直/负值都有意义)的效果来观察。
    trans.m34 = -1/idz;
//首先从中心点=>初始状态=>改变后面 //Concat就是将视图连接起来观察
    return CATransform3DConcat(CATransform3DConcat(transformToCenter, trans), tansformback);
}

//根据当前即将改变视图的角度来观察。
- (CATransform3D)CATransform3DPerspect:(CATransform3D)t withCenter:(CGPoint)center withIDz:(CGFloat)idz{
    return CATransform3DConcat(t, [self CATransform3DMakePerspective:center with:idz]);
}

Swift:

 func CATransform3DMakePerspective(center:CGPoint, idz:CGFloat) -> CATransform3D {
        let transToCenter = CATransform3DMakeTranslation(-center.x, -center.y, 0)
        let transback = CATransform3DMakeTranslation(center.x, center.y, 0)
        var scale = CATransform3DIdentity
        scale.m34 = -1.0/idz
        return CATransform3DConcat(CATransform3DConcat(transToCenter, scale), transback)
    }

    func CATransform3DPerspect(t:CATransform3D, center:CGPoint, idz:CGFloat) -> CATransform3D {
        return CATransform3DConcat(t, CATransform3DMakePerspective(center: center, idz: idz))
    }

那么说到底就是构建透视矩阵。
利用这些就可以实现我们需要的购物车效果了。


注意坑:
若直接写以下代码

CATransform3D transform = CATransform3DIdentity;
transform = CATransform3DMakeRotation(M_PI/8, 1, 0, 0);
//上述代码的调用
self.view.layer.transform = [self CATransform3DPerspect:transform withCenter:CGPointMake(0, 0) withIDz:4000];
1.jpg

2.jpg

你会发现里面'1.jpg'里面的视图映射到了遮罩层maskview上面而且高亮了,但是在DebugView观察的时候确实是翻转了。作者现在还没有明白是什么原因,如有知道的道友可以给作者留言。

解决方式:
作者运用m24这一属性,沿着x轴翻转,来对视图进行改变,并且在视图中使用缩放的方式来对此进行操作,结果是一样的。

    CATransform3D transform = CATransform3DIdentity;
   transform = CATransform3DScale(transform, 0.9, 0.9, 1);
   self.view.layer.transform = [self CATransform3DPerspect:transform withCenter:CGPointMake(0, 0) withIDz:5000];

作者发现:
此方式在视图中是发生变化,但是在DebugView中却没有发生变化

另外注意,在vc中加window的时候,放在viewDidAppear而不要放在viewDidLoad,因为如果放在viewDidLoad中会先将当前的视图加载window层,然后通过视图加载完后将当前vc的view加载其上面。

- (void)viewDidAppear:(BOOL)animated{
    [super viewDidAppear:animated];
    UIWindow *rootWindow = [[UIApplication sharedApplication].windows lastObject];
    self.maskView = [[UIView alloc]initWithFrame:self.view.bounds];
    self.maskView.backgroundColor = [UIColor blackColor];
    self.maskView.alpha = 0;
    [rootWindow addSubview:self.maskView];
    
    self.taobaoView = [[TaoBaoView alloc]initWithFrame:CGRectMake(0, self.view.frame.size.height, self.view.frame.size.width, self.view.frame.size.height/2)];
    [rootWindow addSubview:self.taobaoView];
    
}

最后附上Goto=====================>github

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

推荐阅读更多精彩内容