请选择 进入手机版 | 继续访问电脑版

【3D技术宅公社】XR数字艺术论坛  XR技术讨论 XR互动电影 定格动画

 找回密码
 立即注册

QQ登录

只需一步,快速开始

调查问卷
论坛即将给大家带来全新的技术服务,面向三围图形学、游戏、动画的全新服务论坛升级为UTF8版本后,中文用户名和用户密码中有中文的都无法登陆,请发邮件到324007255(at)QQ.com联系手动修改密码

3D技术论坛将以计算机图形学为核心,面向教育 推出国内的三维教育引擎该项目在持续研发当中,感谢大家的关注。

查看: 4095|回复: 0

[NGUI插件] NGUI官网示例8 – Scroll View(Camera)

[复制链接]
发表于 2013-11-22 15:20:16 | 显示全部楼层 |阅读模式
在上一个示例中的ScrollView使用到了Shader的处理,而对于一些低端的机器或者移动设备可能会出现显示不正常的结果,所以,NGUI还为我们准备了另外一个处理方式,也就是通过摄像机的移动来达到同样的目的。接下来,这个示例就是告诉大家如何实现这个功能。



首先先制作一个普通的GUI界面,这些界面在上面的教程中已经说过,这里就不再赘述,其最终效果如图所示:







现在来制作那些可以滚动的Item结构。使用Create  a new UI创建一个NGUI基本结构,并调整它们的层次关系,并把UIRoot下的Panel组件删除掉,最终如图所示:







新建一个新的空游戏对象,并命名为Offset,并放置在anchor成为它的子物体,并reset一下,同时给它添加一个Panel组件(Component->NGUI->Interation-> Panel),这样,该对象才能放置NGUI元件。如图所示:







NGUI官网示例7-- ScrollView讲解(一) 一样,创建1个Item元件,然后用Ctrl+D的方法复制出9个来,当然你也可以复制你需要的数量,现在这些Item都是重叠在一起的,最终效果如图所示:







选择Offset,为其添加一个Table组件(Component->NGUI->Interaction -> Table)。哈,神奇的效果在此出现,只是上一个教程使用Grid组件,这次使用的是Table,这个Table和Grid的不同,可以查下官网的说明。这里不赘述。如图所示:







选择第一次创建的GUI结构,选择Window下的TiledSprite,如图所示:







在下面创建两个空的游戏对象,并分别命名为BottomRight和TopLeft,这两个空对象用来标记滚动Item的边界,并在场景编辑窗口中放置在对应的位置,最后为该TiledSprite添加一个UIDragCamera组件(Component->NGUI->Interation -> DragCamera)如图所示:





选择第二个Camera,为其添加一个ViewCamera组件(Component->NGUI->UI-> ViewCamera),并把第一个摄像机赋值给SourceCamera,把TopLeft对象赋值给Top Left,把BottomRight赋值给Bottom Right,然后选择Offset,调整该对象的位置,如图所示:





为该摄像机添加一个DraggableCamera组件(Component->NGUI->Interaction-> DraggableCamera),并为其设置参数,如图所示







再次选择刚才添加了两个空对象的择Window下的TiledSprite,把第二个Camera赋值给该元件中的DragCamera组件中的DraggableCamera,其结果如下:







接着同样选择该TiledSprite,为其添加一个Collider,这样,才能接受输入信息(NGUI-> Attach a Collider)。看结果,结果一个点击播放,成这样了?!虽然能够接受到输入信息,但是拖不动?







原来,在第二个GUI结构中的Anchor对象中,原来默认组件UIAnchor中的参数UICamera是第二个摄像机,我们现在把它改成第一个摄像机,再点击播放,Well Done!成功了!







接着给每个Item添加一个DragCamera组件(Component->NGUI-> Interaction -> DragCamera)和一个Trigger(Ngui->Attach a Collider)。再为其添加一个ButtonScale组件和一个buttonSound组件(都在Component->NGUI->Interaction中)







最后来实现那个Press me按钮。首先,选择Window对象,为其添加一个TweenPosisiton组件(Component->Tween->osition),并关闭它(我们将用按钮来开启它),并设置它的参数,如图所示:



您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|3D数字艺术论坛 ( 沪ICP备14023054号 )

GMT+8, 2024-4-18 23:38

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表