让我们实际的研究一下如何将NGUI和C#LightEvil结合起来。
这里使用NGUI2.7,因为他是一个开源的版本,NGUI最新的版本未经作者的许可,是不可以带入我们的开源项目使用的。
这个例子完成的功能是从NGUI例子里找出了三个界面,按最下方的按钮依次进行切换
这是在之前的框架演示Mode1的基础上做的
由一个状态机去进行驱动,这也是我推荐各位使用脚本的方式。
Mode1的模式是定义一个接口类,然后由脚本继承此类型实现,因为随时考虑AOT的缘故(要兼容IOS),我们的脚本有很多限制,比如不能运行时产生IL类型。
那么如果你熟悉AOT和JIT的机制,你一定会发现,脚本继承程序类型的是不可能的。
由于我们的脚本和C#语法兼容,所以,其实这个IState 会在程序中会和脚本中分别使用,他们是两个不同的东西。只是从语法上看起来一模一样。
通过一个叫做ScriptInstanceState的类,他是程序中的IState,他的作用是调用脚本中的IState,通过这个类型,脚本状态和程序状态可以实现无缝切换。
绕口令来了:
在实际的游戏中,你可以一部分状态用程序实现,一部分状态用脚本实现。
由于我们的脚本是c#的严格子集,所有脚本实现的状态,作为程序也都可以正常执行。
程序实现的状态,对语法进行改写,改成C#Light可以通过的状态,也就可以作为脚本执行了。
先不管这个,其实无缝切换很简单,往这里看。
s 就是状态,直接new 就是程序,从我们的粘合类ScriptInstanceState创建,就是脚本
大部分的操作都是没问题的
有一个比较讨厌的地方是回调,这里C#LightEvil 处于严谨的考虑只支持了对event的访问,而NGUI的使用却不是event
这里我们可以修改一下NGUI,对功能没有任何不良影响。
这是脚本中的代码,比较偷懒使用了匿名函数,实际上建议你使用一个独立定义在脚本里的函数,记得我们是一个严格照顾AOT的项目么,匿名函数我们是不可能真的产生的。
他是一个模拟匿名的实现,为了闭包是有额外的开销的。
这里的onClick +=是 event的用法。
就是这里,需要把onclick前面加一个event,由于目前C#LightEvil只支持了对event的访问,不允许直接对delegate赋值。
这个DeleType也要特别实现下,他的定义和Action<Gameobject>是一样的,只要将 RegHelper_DeleAction Copy过来修改一下就是了。
脚本注册回调并不是我推荐的方法,他实际上可以在IState里面定义一个OnClick事件,由程序处理,集中通过实现接口来完成。
这个例子专门使用了匿名,自定义事件,只是为了展示C#LightEvil的更多方面给大家看。
至于推荐的C#LightEvil使用方法,主要是通过一个接口来完成脚本和程序的对接,并且可以无缝切换。
Unity3D热更新全书-脚本(五) NGUI,布布扣,bubuko.com
原文:http://www.cnblogs.com/crazylights/p/3906048.html