XNA教程(三)—— sprite绘制效率

2024-01-19 00:32
文章标签 教程 绘制 效率 sprite xna

本文主要是介绍XNA教程(三)—— sprite绘制效率,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 作者:clayman
仅供个人学习使用,请勿转载,勿用于任何商业用途。
由于本人水平有限,难免出错,不清楚的地方请大家以原著为准。欢迎大家和我多多交流。
Blog:
http://blog.csdn.net/soilwork
clayman_joe@yahoo.com.cn  

虽然内容有所变动,但我的xna教程还会继续^_^
本文图片和部分文字来自
XNA Diaries
参考了其中两篇关于sprite alpha blend的文章

         SpriteBatch.begin 通过接受几个参数,来控制如何渲染 sprite 。参数 BlendMode 表示进行哪种模式的混合。 Xna 只提供了三种,也是最常见的混合模式:AlphaBlend Additive 以及 InverseColor 。这里,我们主要讨论 AlphaBlend
       AlphaBlend 根据当前 sprite alpha 通道中的值,对 sprite 颜色和帧缓冲中已存在的颜色进行混合。计算的公式为 finalColor = spriteColor * alpha + backgroundColor * alpha 。由于要查询缓冲中的当前颜色,因此, alpha 混合是一个相对较昂贵的操作。
       单有 SpriteBlendMode 并不能完全达到我们所希望的效果,当绘制多个图形时,还需按照一定的顺序绘制 sprite 才行。

         上面这张图片掩饰了 5 个半透明的环,按照不同顺序绘制时,所得到的结果,其中,后者是我们所期望的效果。左图中,我们最先绘制了中间的圆形,因此,它将和蓝色的背景混合,导致最终的效果有一条蓝边。而右图中,我们最后才绘制中央的圆形。
         有两种方法来控制 sprite 绘制顺序。第一种,使用 SpriteBatch.Draw depth 参数的重载,让计算机在绘制图形时根据 depth 值,为我们排序;第二种则是在我们自己编写代码来控制。
         当场景中有大量 sprite 时,第一种方法是不错的解决方案。为每个 sprite 都指定一个 depth ,当物体移动时,简单的改变它的深度,就能获得正确的效果,比如 2D 游戏中,让玩家从树后移动到树前。使用 SpriteBatch.begin sortMode 参数来指定从后到前,还是从前到后排序,通常情况下我们选择前者。
         另一种方法,侧需要我们自己安排绘图顺序,比如先绘制背景,然后游戏对象,接下来再绘制前方的遮挡物, UI 等等。当大量物体相互遮挡时,决定绘图顺序的逻辑可能会很复杂。但是,当场景不太复杂时,这是一种很高效的方法。
         到这里,就需要讨论一下几种混合模式下的效率:

Y 轴表示帧速率, X 轴表示 sprite 数量
         图中,红色是 SpriteBlendMode.None ,绿色是 SpriteBlendMode.AlphaBlend ,蓝色是 AlphaBlend 以及 SpriteSortOptions.BackToFront ,灰色是 SpriteSortOptions.FrontToBack
         可以看到,如果自己排序,那么在有大量( >500 )个 sprite 的时候,能获得相当不错的收益(当然,这里并未考虑我们手动排序的代价)。
         而如果使用 SpriteBatch 来进行排序,那么 sprite 数量最好不要超过 400 个。当然,如果不使用 alpha 混合,效率又会提高很多。
         当然,也许你还注意到了 SpriteSortOptions.FrontToBack 状态下性能异常的好,但不幸的是,这种方法通常不能创建正确的效果。

 

这篇关于XNA教程(三)—— sprite绘制效率的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/620747

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

【WebGPU Unleashed】1.1 绘制三角形

一部2024新的WebGPU教程,作者Shi Yan。内容很好,翻译过来与大家共享,内容上会有改动,加上自己的理解。更多精彩内容尽在 dt.sim3d.cn ,关注公众号【sky的数孪技术】,技术交流、源码下载请添加微信号:digital_twin123 在 3D 渲染领域,三角形是最基本的绘制元素。在这里,我们将学习如何绘制单个三角形。接下来我们将制作一个简单的着色器来定义三角形内的像素

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者

Flutter 进阶:绘制加载动画

绘制加载动画:由小圆组成的大圆 1. 定义 LoadingScreen 类2. 实现 _LoadingScreenState 类3. 定义 LoadingPainter 类4. 总结 实现加载动画 我们需要定义两个类:LoadingScreen 和 LoadingPainter。LoadingScreen 负责控制动画的状态,而 LoadingPainter 则负责绘制动画。

沁恒CH32在MounRiver Studio上环境配置以及使用详细教程

目录 1.  RISC-V简介 2.  CPU架构现状 3.  MounRiver Studio软件下载 4.  MounRiver Studio软件安装 5.  MounRiver Studio软件介绍 6.  创建工程 7.  编译代码 1.  RISC-V简介         RISC就是精简指令集计算机(Reduced Instruction SetCom

前端技术(七)——less 教程

一、less简介 1. less是什么? less是一种动态样式语言,属于css预处理器的范畴,它扩展了CSS语言,增加了变量、Mixin、函数等特性,使CSS 更易维护和扩展LESS 既可以在 客户端 上运行 ,也可以借助Node.js在服务端运行。 less的中文官网:https://lesscss.cn/ 2. less编译工具 koala 官网 http://koala-app.

【Shiro】Shiro 的学习教程(三)之 SpringBoot 集成 Shiro

目录 1、环境准备2、引入 Shiro3、实现认证、退出3.1、使用死数据实现3.2、引入数据库,添加注册功能后端代码前端代码 3.3、MD5、Salt 的认证流程 4.、实现授权4.1、基于角色授权4.2、基于资源授权 5、引入缓存5.1、EhCache 实现缓存5.2、集成 Redis 实现 Shiro 缓存 1、环境准备 新建一个 SpringBoot 工程,引入依赖:

利用matlab bar函数绘制较为复杂的柱状图,并在图中进行适当标注

示例代码和结果如下:小疑问:如何自动选择合适的坐标位置对柱状图的数值大小进行标注?😂 clear; close all;x = 1:3;aa=[28.6321521955954 26.2453660695847 21.69102348512086.93747104431360 6.25442246899816 3.342835958564245.51365061796319 4.87

Windows环境利用VS2022编译 libvpx 源码教程

libvpx libvpx 是一个开源的视频编码库,由 WebM 项目开发和维护,专门用于 VP8 和 VP9 视频编码格式的编解码处理。它支持高质量的视频压缩,广泛应用于视频会议、在线教育、视频直播服务等多种场景中。libvpx 的特点包括跨平台兼容性、硬件加速支持以及灵活的接口设计,使其可以轻松集成到各种应用程序中。 libvpx 的安装和配置过程相对简单,用户可以从官方网站下载源代码