花式实现图片3D翻转效果

闲话

曾经在闲逛时,看到有一个很炫的3D翻转切换图片的效果。地址在这里:https://tympanus.net/Development/Slicebox/index.html
一直想搞一个,最近撸出来一个自定义View,包含多个效果,其中一种与之相近。

正文

1.效果
话不多说,先看效果:
2d平移:

2d

3D翻转:
3D

3D开合:
3D开合

百叶窗:
百叶窗

3D轮转:
3D轮转

是否觉得酷炫呢?
2.核心原理
如果你已经迫不及待的想知道实现的原理,那我先把源码的传送门给你:https://github.com/zhangyuChen1991/Roll3DImageView
不过直接撸代码,效率难免低,如果有介绍的文章,为什么不看呢?接下来我们一步一步来分析各种效果的实现过程。
开门见山,我们直击要点:这一系列的效果实现的基础是对两个类的使用,Camera和Matrix。这也是我们今天的主角。
先来看几个API:
camera.rotateX(float deg);
camera.rotateY(float deg);
camera.rotateZ(float deg);
camera有一个三维坐标系,x轴水平,Y轴竖直,Z轴垂直屏幕指向你。上面三个API意思很明显就是绕着三个轴旋转一定的角度,camera的处理对象是matrix,将处理后的matrix应用在图片上,就会让一个平铺在屏幕上的图片产生绕x轴或者y轴旋转过后的3D效果了。像这样(盗个图):
(图片出自另一篇将camera和matrix讲得很不错的文章:传送门在这里

这里写图片描述
这里写图片描述

知道了camera的这个基础而关键的API,我们再来看下面一段代码:

camera.save();
camera.rotateX(-rotateDegree);
camera.getMatrix(matrix);
camera.restore();

matrix.preTranslate(-currBitmap.getWidth() / 2, 0);
matrix.postTranslate(currBitmap.getWidth() / 2 + i * averageWidth, axisY);
canvas.drawBitmap(currBitmap, matrix, paint);

上面的代码做了一件事:将matrix用camera旋转处理后运用在bitmap上,将bitmap显示出来。这里显示出来的效果就如上面的图片展示,是有3D效果的。
但是这里要讲的关键不是这个,请注意其中的四行代码:

camera.rotateX(-rotateDegree);
camera.getMatrix(matrix);
matrix.preTranslate(-currBitmap.getWidth() / 2, -currBitmap.getHeight());
matrix.postTranslate(currBitmap.getWidth() / 2 , axisY);

这里的preTranslate()和postTranslate()有什么作用?
通常上理解,preTranslate()就是在一个matrix发生变化之前,给它做一个平移,postTranslate()是在一个matrix发生变化之后做平移。通过参数来看,这里的动作是把它先往左上方移动,然后往右下方移动,目的只有一个:在matrix做旋转处理时改变旋转中心的位置。
camera旋转matrix时,中心点在(0,0),这是它的旋转中心,而(0,0)点只是matrix的左上角,如果不处理就旋转的话,旋转轴就是matrix的顶边或者左边,这里竖直方向先向上移动了整个bitmap的高度,让它的旋转轴变成了bitmap的底部,如果不移动,则在bitmap的顶部。
结合一张丑图来看吧:


解释图片

蓝色框的中心就是旋转操作的中心,如果移到绿框位置,则对图片进行以中心为旋转的处理。
所以这里的过程总结为:
1 移动bitmap到旋转轴合适的位置
2 进行旋转处理
3 移回原位,显示处理后的位图效果

还有一点要注意到,上面代码中移过去和移回来,参数是不一样的,也就是说,图片并不是移回原位。这点应该比较好理解,3D翻转的过程,图片的位置其实是变化的,当前图片会逐渐移出显示框,下一张图片会逐渐进来,所以参数不同为了就是造成图片位置移动而已。

上面这段内容其实就是整个所有效果实现的核心了,如果你跟着这个思路理清楚了,再看代码应该要省力得多。

3.3D翻转基本过程
那么我们梳理一下整体3D翻转的过程:
水平向左翻转,第一张图片旋转轴在最右,旋转角度不断增加,同时旋转轴逐渐往左移动;第二张图片旋转轴在自己的最左,旋转角度不断减小,同时旋转轴逐渐靠向左边;于是就产生了3D翻转切换的效果了。竖直方向类同。
如果你理解了上面讲述的过程,那么跟着这段描述来试着写出代码吧!

其实讲到这里,最关键的原理已经说完了,下面没有什么太干的货了,我们简单梳理一下分割变化的过程吧。

4.基础之上的扩展
整体3D翻转,我们处理的是图片的整个bitmap。分割翻转的道理其实是一样的,只是要先做一步:将bitmap均等分割成若干块,放到数组里备用。当启动效果时,依次拿出每个bitmap,处理它的旋转、位移,就可以了。

1.分割合并效果:这个没啥好说的,整体3D是操作一个,这里分成3个照整体3D哪样处理就可以了。唯一要注意的一点是:每一块bitmap平移回来的时候,记得算对参数,把图片完整的拼回一起。

2.百叶窗效果:唯一的不同就是每一块bitmap翻转的中心不同了,其他的旋转轴都在边沿,而它是在中心位置。

3.轮转效果:这个我认为最炫的一个效果,其实原理也就那么回事了,每块bitmap依次执行3D翻转,最后全部翻转过来,就是这样了。

结尾

最后还想说的是,在实践的过程中,我发现偏移某些参数相互搭配,其实会产生更加3D逼真绚丽的效果。我浅尝辄止,期待你们脑洞大开无限探索,只有想不到,没有做不到!

最后的最后,贴一遍项目地址吧,欢迎大家赏脸前去观看。https://github.com/zhangyuChen1991/Roll3DImageView
如发现问题,欢迎斧正!

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

推荐阅读更多精彩内容

  • 本文行文目录:一、Camera与Matrix初步认识二、Camera与Matrix旋转效果拆分介绍三、Camera...
    zhangke3016阅读 17,779评论 18 136
  • 前言 前段时间读到一篇文章,作者通过自定义View实现了一个高仿小米时钟,其中的3D效果很是吸引我,于是抽时间学习...
    实例波阅读 20,897评论 1 43
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,135评论 25 707
  • CSDN博客 img cquwentao android matrix 最全方法详解与进阶(完整篇) 发表于201...
    北风知我意阅读 4,820评论 0 0
  • 一个是整日里上蹿下跳不得安宁的萧游,一个是横行跋扈目中无人的萧逸,这两孩子混在一起,半个皇宫的人见着都得绕道走。 ...
    知了知了知了了阅读 292评论 0 0