Centos环境安装CollabNetSubversionEdge详细步骤
Linux小白,部署了4天才部署成功,一直csvn 无法启动,让我头疼了很久,最终各种Google 看了N多文章,无数次的试验(系统还原了N次 = =)终于是部署成功了。 成就感就不用说了,很开心啊。现在再从来安装一次,并且把步骤记录下来,以后方便自己从安装。
Protected: 我的2014年
[Unity3D学习]NGUI UILabel 图文混排扩展
之前发过一个图文混排的文章《[Unity3D学习]NGUI UILabel 图文混排》、一直感觉那样比较消耗。又由于公司项目也需要做图文混排,就想了另一种图文混排思路,从性能来说比之前的思路要好很多,不过也有弊端,现在这种解决方案,做动态表情不太适应。不过我想的是,手机游戏对聊天功能其实已经比较弱化了,所以个人认为聊天不需要做得太复杂,一切从简就好。
[Unity3D学习]NGUI UILabel 底层实现原理
这个代码放在草稿箱已经N久了,一直没时间来写写发布,因为我想从底层去实现一个图文混排的功能,所以就第一步先尝试去了解一下NGUI UILabel的底层实现方式。终于剥离了大部分UILabel的代码,找到了最终的动态文字的具体实现方式,具体的代码就贴在下面了,我就不详细叙述了,我这人一直以来都不太喜欢敲文字,文笔太烂,我更喜欢用代码说话。
大概都实现思路:通过动态字体库获取文字都顶点、UV、颜色信息,然后通过Mesh显示出来。具体的请看代码吧。
通过对UILabel都学习,图文混排都实现可以通过我们处理顶点来解决,其实新方案都图文混排功能我已经放在草稿里了,等有时间再整理发布。
阅读详细 »
[小技巧]Visual Studio 常用快捷键
在工作中,快捷键能够帮助自己提高很多效率。
所以一定要尽量多记一些好用都快捷键
下面都内容收集于互联网
[Unity学习]Vector3.Distance()函数与自己计算距离的效率对比
下面是我的测试代码,以及执行输出结果。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 |
using UnityEngine; using System.Collections; public class Distance : MonoBehaviour { private Vector3 start = new Vector3(0,0,0); private Vector3 end = new Vector3(100, 100, 100); // Use this for initialization void Start () { const int total = 1000000; System.Diagnostics.Stopwatch w1 = new System.Diagnostics.Stopwatch(); w1.Start(); int i=0; float dis1 = 0f; while (i < total) { dis1 = Vector3.Distance(start, end); i++; } w1.Stop(); Debug.Log("dis1Time : " + w1.ElapsedMilliseconds); Debug.Log("dis1 : " + dis1); System.Diagnostics.Stopwatch w2 = new System.Diagnostics.Stopwatch(); w2.Start(); int z = 0; float dis2 = 0f; float dx = end.x - start.x; float dy = end.y - start.y; float dz = end.z - start.z; while (z < total) { dis2 = Mathf.Sqrt(dx * dx + dy * dy + dz * dz); z++; } w2.Stop(); Debug.Log("dis2Time : " + w2.ElapsedMilliseconds); Debug.Log("dis2 : " + dis2); System.Diagnostics.Stopwatch w3 = new System.Diagnostics.Stopwatch(); w3.Start(); int x = 0; float dis3 = 0f; while (x < total) { dis3 = Mathf.Sqrt((end.x - start.x) * (end.x - start.x) + (end.y - start.y) * (end.y - start.y) + (end.z - start.z) * (end.z - start.z)); x++; } w3.Stop(); Debug.Log("dis3Time : " + w3.ElapsedMilliseconds); Debug.Log("dis3 : " + dis3); } } |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
dis1Time : 23 UnityEngine.Debug:Log(Object) Distance:Start() (at Assets/Distance.cs:26) dis1 : 173.2051 UnityEngine.Debug:Log(Object) Distance:Start() (at Assets/Distance.cs:27) dis2Time : 7 UnityEngine.Debug:Log(Object) Distance:Start() (at Assets/Distance.cs:44) dis2 : 173.2051 UnityEngine.Debug:Log(Object) Distance:Start() (at Assets/Distance.cs:45) dis3Time : 9 UnityEngine.Debug:Log(Object) Distance:Start() (at Assets/Distance.cs:58) dis3 : 173.2051 UnityEngine.Debug:Log(Object) Distance:Start() (at Assets/Distance.cs:59) |
可以看出,上面的三种计算方式,Unity自己的API执行效率是最慢的,不过这个计算量比较大,如果计算量比较小的情况下,这点效率其实可以忽略,还有就是如果是自己计算,很多情况下,Y轴的数据可以不包含在计算中,这样执行效率能够提升更多。
[Unity3D学习]获得两点之间连续坐标,向量加法、减法、乘法的运用。
这是一个很小的知识点,不过我觉得可以记录下来,就算是在大都项目都是这些小小的知识点堆积而来,之前我用这个小知识点获取了,两点之间都一系列点,今天当我想做一个移动的时候,发现这个知识点也能做这方面都事情,所以我觉得把它记录下来,虽然很简单,但是用处并不简单。
[Unity3D学习]Mesh创建三角形、长方形
今天看了下如何创建长方形和三角形,以前只是知道能够使用同一个Material的情况下就使用同一个,能减少Draw Calls ,今天自己也测试了一下,加深都理解。
我目前理解是为了降低Draw Calls 应当尽然重用 Materail,这中情况下,不管你创建多少个三角形,使用相同的Materail,那么Draw Calls只会+1,但是这种重用很有局限性,如果你改变Materail都颜色,那么所有都三角形都会改变颜色。从这点就应该大致知道为什么Draw Calls只会+1。
进而我尝试了创建多个三角形,每个三角形都实例化新都Materail,这种情况下,测试结果是在可视范围内,有多少个三角形,就会有多少Draw Calls 。这样就能清楚都知道Materail是增加Draw Calls都主要因素,所以以后得注意这一点。
下面贴出代码,创建三角形,长方形都代码以后应该能用到。
阅读详细 »
[Unity3D学习]TexturePacker与NGUI配合使用
首先我得感谢TexturePacker的作者,谢谢他免费给了我一个key,让我用上了正版。我决定下一年,我继续选择付费使用正版,我认为这是值得的。这是TexturePacker官网:http://www.codeandweb.com/
进入正题吧,说明我为什么放弃NGUI的整合工具而用TexturePacker吧,有三个原因:
1、我习惯使用TexturePacker,因为我之前的项目一直使用的它,所以我用顺手了。而且我感觉他比NGUI更方便好用。
2、TexturePacker打包出来的资源比NGUI打包的更小一些。NGUI打包一个资源700k、TexturePacker打包600k,能节约100k.对于手机内存,你懂的。
3、这也是最主要的,如果你看过我上一篇文章《Unity代码热更新解决方案测试结果总结》你就会知道我为什么要这么做了,都是泪啊。。
还是来看看TexturePacker怎么设置吧,直接上图,一目了然。
[Unity3D学习]Unity代码热更新解决方案测试结果总结
这几天一直在研究热更新方案
主要思路是:
1.先将代码打包成dll,然后用unity 打包成assetsbundle,
2.WWW加载进入主程序,
3使用System.Reflection.Assembly来创建程序集,
4.然后通过GetType(className),来获取这个类
5.AddComponent进入主程序,加载的dll就执行起来了。