我为什么想干掉Unity3D?

这个问题容我不答,每个做技术的人总有一些完美主义。

你使用u3d的过程中是不是痛并快乐着呢。

就从两个国内具有相当普遍性的痛点说起。

  1. il2cpp,unity作出了这个决策以来,导致每个程序员都拥有了大姨妈,每当接入ios平台,就得再死上一次。每当看一眼打出来的包的容量,就会有一种压力山大的感觉。
  2. unity的底层c++ api没有公开,如果想要接入脚本层,只能通过dotnet进行互操作,导致u3d平台上难以实现比较完美的脚本方案。首先性能就是一个问题

还有第三个痛点,一直是我的一块心病。Unity不能在手机平台断点调试,本来断点调试作为程序员的最后手段,居然被剥夺了。很是担忧。

痛点这么多,还一直赖在Unity3D,又是为什么呢

因为unity3d还有一些优点,太过于吸引人。

  1. 成熟、稳定(稳定要打个折扣)的IDE
  2. 多平台一键发布(IOS这个一键也差了一点,是发布为xcode项目)
  3. C#语言buf加持

有没有可能解决痛点,保持优势?

当然有

让我们看一下unity3d的架构,这是个我随便画的示意图

Unity3d的架构是以c++编写的引擎框架为基础,这里很传统。

反传统之处在于unity3d完全将所有的接口置于monoruntime之后,unity本身的部分功能也是由dotnet开发,比如unityengine.ui

用户代码更是完全限制为使用dotnet开发。

虽然unity提供了plugin机制,可以用其他语言混编,但是这些插件均无法访问unity底层c++代码(或许可以,我没有见到任何资料)。

这导致了unity无法高效的接入c++实现的脚本语言,lua在unity的实际表现有目共睹。

这是痛点2的原因,痛点1是unity自己作死,不多说。痛点3也是unity工作没有做好。

解决痛点

有没有一个架构,可以解决痛点123呢,答案是有。

基于xamarin方案,android、ios平台均可断点调试

底层代码同时对monoruntime和脚本层公开接口,可以插入c++实现的各种脚本,比如lua,并取得原生性能。

用户代码分为dotnet 和 脚本两种,两者之间不互访,通过底层接口互发消息。

Il2cpp自然也不用担心。

还有附加的好处,c# 5.0走起。

Xamarin平台上现有monogame,他是都在monoruntime之后实现的,调用otk,也不能提供原生性能,也不可以插入原生脚本。

该方案实现在于:

  1. 为xamarin编写不同平台的原生插件,主要是绘图、音效、触摸、键盘这些底层公开接口。主要是ios、android、当然pc也要,pc可以不用xamarin,改为windows+vs,这样在windows调试更给力。
  2. P/invoke导出到dotnet,对接什么脚本层也做对应导出。

这样重度用户代码用dotnet编写,轻度易变代码用脚本编写,轻度代码为资源,任何平台均可实现下载执行。

保持优势

  1. c#加持,更优了,unity整合c# 3.5,xarmarin整合c# 5.0,你还想说什么。
  2. 多平台一键发布,这个xamarin没有做,需要我们自己做。
  3. 成熟稳定的场景编辑器,这个需要我们自己做。

场编怎么做,抄袭unityeditor,unityeditor这个脚本扩展比较方便,抄。

一键发布怎么做。在android很容易,我们已经做了原理测试程序,弄个模板apk文件,解包,把资源放进去,再重新打包签名,已经完全实现了。

Android上面的dotnet用户代码我们也一键编译成dll当资源放了进去,因为android上monoruntime用的jit,很容易实现。

在ios一键发布要麻烦一点,需要用monoaot 将dotnet用户代码编译为.a,再用模板包重签名。说实话aot弄成.a 我不知道怎么弄。Ipa重签名我也不知道怎么弄。

但是aot弄成.a,我们可以找到unity源码学习,我们可以找畅游的引擎源码学习。Ipa重签名,国内一把越狱平台都有这功能,还有个著名的软件iresign,我们去找他的源码学习。至少我们知道方向在哪里。

实现了一键发布,我们还让发布阶段不依赖xamarin了,xamarin仅需要出模板包。

这样也可以帮用户节省一个xamarin授权的费用。

 

这就是新FB引擎想去的方向。

如果你想支持赞助我们的工作

用支付宝:

lightsever@hotmail.com

李剑英

 

如果你是想要加入讨论

用QQ群:223823428

 

干掉Unity3D的更多相关文章

  1. 总结:Unity3D游戏上线后的流程回顾

    原地址:http://unity3d.9tech.cn/news/2014/0127/39748.html 首先.unity 灯光烘焙 :Unity 3d FBX模型导入.选项Model 不导入资源球 ...

  2. Unity3d 打包时报错 CommandInvokationFailure: Unable to convert classes into dex format. See the Console for details.

    今天打包带有Android插件的unity3d 项目是,报错CommandInvokationFailure: Unable to convert classes into dex format. S ...

  3. Spine输出资源一键入Unity3D工具代码

    之前预研过2D骨骼动画编辑工具SPINE,感觉其比cocosStudio及Unity3D自带的骨骼动画编辑器(原生Sprite Tree或Uni2D)要更适合有3DSMax习惯的美术,即Spine更容 ...

  4. Unity3d学习 预设体(prefab)的一些理解

    之前一直在想如果要在Unity3d上创建很多个具有相同结构的对象,是如何做的,后来查了相关资料发现预设体可以解决这个问题! 预设体的概念: 组件的集合体 , 预制物体可以实例化成游戏对象. 创建预设体 ...

  5. Unity3d入门 - 关于unity工具的熟悉

    上周由于工作内容较多,花在unity上学习的时间不多,但总归还是学习了一些东西,内容如下: .1 根据相关的教程在mac上安装了unity. .2 学习了unity的主要的工具分布和对应工具的相关的功 ...

  6. TDD在Unity3D游戏项目开发中的实践

    0x00 前言 关于TDD测试驱动开发的文章已经有很多了,但是在游戏开发尤其是使用Unity3D开发游戏时,却听不到特别多关于TDD的声音.那么本文就来简单聊一聊TDD如何在U3D项目中使用以及如何使 ...

  7. warensoft unity3d 更新说明

    warensoft unity3d 组件的Alpha版本已经发布了将近一年,很多网友发送了改进的Email,感谢大家的支持. Warensoft Unity3D组件将继续更新,将改进的功能如下: 1. ...

  8. Unity3D框架插件uFrame实践记录(一)

    1.概览 uFrame是提供给Unity3D开发者使用的一个框架插件,它本身模仿了MVVM这种架构模式(事实上并不包含Model部分,且多出了Controller部分).因为用于Unity3D,所以它 ...

  9. Unity3D 5.3 新版AssetBundle使用方案及策略

    1.概览 Unity3D 5.0版本之后的AssetBundle机制和之前的4.x版本已经发生了很大的变化,一些曾经常用的流程已经不再使用,甚至一些老的API已经被新的API所取代. 因此,本文的主要 ...

随机推荐

  1. react native 多选按钮

    在做项目的时候有一个需求,是可以选择多个条件的,特地在Github上找了一些案例,发现没有什么合适的,于是自己根据这些案例,改装一下,封装了一个合适自己的.先看我封装的代码. import React ...

  2. 《DSP using MATLAB》第6章开始了

    看到第6章了,标记一下,全书近一半,继续加油 构建滤波器的三种元件: 下面是函数floor和size的部分帮助截图

  3. 使用CocoaPods过程中 Unable to find a specification for

    文章转自:http://blog.csdn.net/zhangao0086/article/details/39703083 当把CocoaPods生成的workspace移动到上层目录时,需要改下P ...

  4. Android 利用RecyclerView.Adapter刷新列表中的单个view问题

    首先使用RecyclerView的adapter继承:RecyclerView.Adapter public class OrderListAdapter extends RecyclerView.A ...

  5. WindowManager massge和handler

    在一个可移动浮动按钮的demo源码学习中,有一些WindowManager的使用,在此做下总结. 1.翻译过来就是窗口管理,是和应用框架层的窗口管理器交互的接口,通过 mWindowManager = ...

  6. 在mvc里面有htmlhelper方法,在webform里面有什么?

    终于是找到原来在webform里面已经提供了htmlcontrol这样的控件,可以直接拿来用.以前一直在想mvc有htmlhelper,webform里面不能用,其实是webform里面已经有了. 例 ...

  7. dd——留言板再加验证码功能

    1.找到后台-核心-频道模型-自定义表单 2.然后点击增加新的自定义表单 diyid 这个,不管他,默认就好 自定义表单名称 这个的话,比如你要加个留言板还是投诉建议?写上去呗 数据表  这个不要碰, ...

  8. WebService的工作原理

    Web Service全称XML Web Service WebService是一种可以接收从Internet或者Intranet上的其它系统中传递过来的请求,轻量级的独立的通讯技术.是:通过SOAP ...

  9. 输出日志实例改成用Spring的AOP来实现

    1.采用Interception Around通知的形式实现 Interception Around通知会在Join Point的前后执行,实现Interception Around通知的类需要实现接 ...

  10. Smart3D系列教程3之 《论照片三维重建中Smart3D几个工作模块的功能意义》

    [摘要] 近年来,倾斜摄影测量技术是国际测绘遥感领域近年发展起来的一项高新技术,利用照片进行三维重建成为一项关键性的技术.Smart3D软件,是照片三维重建主流软件之一,本文将就Smart3D建模软件 ...