unity 制作书籍翻页效果

unity C# 翻书效果 2D 真实翻页 不使用插件 自制

实现思路

将书本分为两边,一边一个翻页实现;

image

下图为书本的右面,以OA为分界线,△OAB是下一面的如上图的左下角,△OAC是下一面的如上图的右下角;

image

利用unity的mask可以实现,也就是,假设这一页是1(左边那一页是0),需要有一个对象作为底面显示3,一个对象被mask遮住显示2的左下角在△OAB上,一个对象被mask遮住显示1的左上部分在◇OADE上;

OAB部分的mask可以如下图理解:◇OAFG是mask,◇OBCD是2,翻页时,◇OAFG逆时针转动,◇OBCD作为◇OAFG的子对象,相同的方向旋转相同角度;

image

其他部分以及左边页面实现的原理都同上,还有就是翻书的中心点是以两页中间底部为旋转原点;

image

实现步骤

1.新建一个2D项目并在hierarchy面板新建一个Canvas,并在其下建立如下对象,从上到下含义可以理解为左边底页面、左边逐渐消失页面(父对象为mask子对象为图片)、左边逐渐出现页面、右边底页面、右边逐渐消失页面(父对象为mask子对象为图片)、右边逐渐出现页面,其中的LeftPageShadow和RightPageShadow是翻书的阴影,如下图2的灰色线,会跟着◇OBCD一起旋转,但是是反方向才能和书折痕的边缘契合,折痕图片使用下图3有渐变的即可;

image
image
image

2.此处将单讲右边部分,左边部分同理。RightBottomPage_Appear不需要怎么修改,只需把坐标设置好,作为底面即可。把Width和Height设置成想要的尺寸,PosY为-Height*0.5f,调至页面的右侧,还需要把Pivot设置为0,0,把旋转中心点设置为书本中轴线的底部;

image

3.RightTopCover_DisAppear设置如下,为了顾及旋转时RightTopPage_DisAppear会出头,此处简单粗暴的把Width设置为2倍,同理也要把旋转中心点设置在中轴线底部,Pivot设置为0,0;

image

4.RightTopPage_DisAppear设置如下,不多说;

image

5.RightNextCover、RightNextPage和RightPageShadow基于同样的原因和效果出现的位置做如下设置,可在设置过程中体会理解,注意Pivot和Rotation,RightPageShadow可以减少颜色透明度来减淡阴影;

image
image
image

6.创建一个脚本并挂载在MainCanvas上,定义以下变量,上面部分的Image表示对应名字的Image属性,Sprite[]表示所有书页,turningTime表示翻页时间,isturing表示当前是否正在翻页;

image

7.右边翻向左边的代码如下,SetSiblingIndex是设置物体在hierarchy面板的位置,用来排序,因为排在下面的物体会显示在排在上面的物体的前面,SetSiblingIndex具体说明可参看unity文档。offsetAngle根据旋转时间来调节旋转的幅度。然后就是各种角度的叠加和旋转抵消。ResetBookImage函数和ResetPagesAttribute函数,后面细说。此处使用SetSiblingIndex也可通过,创建两个空物体然后附加一个canvas组件,把左右两边的物体分别作为子物体,然后通过调节sorting order来显示哪一页在前面;

image
image

8.左边翻向右边的代码如下,同理不再赘述

image

9.ResetPagesAttribute的代码如下,重置所有Image的坐标和角度;

image

10.创建如下变量,含义分别为当前页数,最大页数,还有左边翻页协程和右边翻页协程。ResetBookImage函数代码如下,用于重新设置各个Image对应的图片,此处比较需要抽象和想象,想通就很容易理解;

image
image

11.在Start里初始化变量和重设图片,然后再创建两个函数用来启动翻页的功能;

image
image

12.在hierarchy面板创建一个空物体并挂载新脚本InputControl用来控制点击,代码如下。此处使用Graphic Raycaster(UI射线)来检测点击的位置,还需要创建两个空Image并调至要响应翻页的地方,此处为页面左右两边并且宽度为总宽度的四分之一。射线检测通过比对name来进入不同翻页;

image
image
image
image

至此,使用unity原生组件制作书本翻页效果的功能就完成了,以下为效果

ezgif.com-video-to-gif.gif

另外还可参考GitHub上的这位道友的项目:

https://github.com/Dandarawy/Unity3DBookPageCurl

转载于:https://www.cnblogs.com/JinT-Hwang/p/9274984.html

相关资源:unity3d制作翻页效果

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

推荐阅读更多精彩内容