c# – 在XNA中对网格进行排序
发布时间:2020-12-15 21:44:34 所属栏目:百科 来源:网络整理
导读:我在XNA中遇到树问题.当我有树时,我需要使用alpha混合来使非叶部分透明,但模型的某些部分未正确显示,因此alpha混合失败.我想知道是否有可能读取网格位置来对它们进行排序,或者是否有其他方法可以获得透明的非叶部分. 模型中的排序可能不起作用,因为我想从各
我在XNA中遇到树问题.当我有树时,我需要使用alpha混合来使非叶部分透明,但模型的某些部分未正确显示,因此alpha混合失败.我想知道是否有可能读取网格位置来对它们进行排序,或者是否有其他方法可以获得透明的非叶部分.
模型中的排序可能不起作用,因为我想从各个角度看这棵树. 解决方法
在3D环境中进行Alpha混合可能是一个棘手的问题.几年前,肖恩·哈格里夫斯写了一篇关于大多数主要问题的文章(题为“画家的算法”一节专门讨论了你的问题).长话短说:没有技术可以做到你想要的完美,所以问题就变成了:你愿意做出什么权衡?
进行alpha测试而不是alpha混合可能是最简单的解决方案.这是一个二元测试,其中出现或不出现不透明像素,因此绘制这些像素的顺序在很大程度上是无关紧要的.这将为您提供坚硬的边缘,但如果您的纹理具有足够的分辨率,它仍然可以看起来很好;我知道魔兽世界使用这种技术,我很确定我记得在“暗黑破坏神III”中看过它. 您可以使用内置的AlphaTestEffect来执行此操作,或者在像素着色器中自行实现它. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |