欢迎来到【信息录入系统源码】【组策略 源码】【maven tomcat源码】unity源码免费-皮皮网网站!!!

皮皮网

【信息录入系统源码】【组策略 源码】【maven tomcat源码】unity源码免费-皮皮网 扫描左侧二维码访问本站手机端

【信息录入系统源码】【组策略 源码】【maven tomcat源码】unity源码免费

2024-11-30 08:56:38 来源:{typename type="name"/} 分类:{typename type="name"/}

1.UGUI源码阅读之Mask
2.unity urp源码学习一(渲染流程)
3.源代码都要买吗

unity源码免费

UGUI源码阅读之Mask

       Mask主要基于模版测试来进行裁剪,码免因此先来了解一下unity中的码免模版测试。

       Unity Shader中的码免模版测试配置代码大致如上

       模版测试的伪代码大概如上

       传统的渲染管线中,模版测试和深度测试一般发生在片元着色器(Fragment Shader)之后,码免但是码免现在又出现了Early Fragment Test,可以在片元着色器之前进行。码免信息录入系统源码

       Mask直接继承了UIBehaviour类,码免同时继承了ICanvasRaycastFilter和IMaterialModifier接口。码免

       Mask主要通过GetModifiedMaterial修改graphic的码免Material。大致流程:

       1.获取当前Mask的码免层stencilDepth

       2.StencilMaterial.Add修改baseMaterial的模板测试相关配置,并将其缓存

       3.StencilMaterial.Add设置一个unmaskMaterial,码免用于最后将模板值还原

       MaskableGraphic通过MaskUtilities.GetStencilDepth计算父节点的码免组策略 源码Mask层数,然后StencilMaterial.Add修改模板测试的码免配置。

       通过Frame Debugger看看具体每个batch都做了什么。码免先看第一个,码免是Mask1的m_MaskMaterial,关注Stencil相关的数值,白色圆内的stencil buffer的值设置为1

       这个是Mask2的m_MaskMaterial,根据stencil的计算公式,Ref & ReadMask=1,Comp=Equal,只有stencil buffer & ReadMask=1的像素可以通过模板测试,即第一个白色圆内的maven tomcat源码像素,然后Pass=Replace,会将通过的像素写入模板值(Ref & WriteMask=3),即两圆相交部分模板值为3

       这个是RawImage的Material,只有模板值等于3的像素可以通过模板测试,所以只有两个圆相交的部分可以写入buffer,其他部分舍弃,通过或者失败都不改变模板值

       这是Mask2的unmaskMaterial,将两个圆相交部分的模板值设置为1,也就是还原Mask2之前的stencil buffer

       这是Mask1的unmaskMaterial,将第一个圆内的模板值设置为0,还有成最初的主机商源码stencil buffer

       可以看到Mask会产生比较严重的overdraw。

       2.drawcall和合批

       每添加一个mask,一般会增加2个drawcall(加上mask会阻断mask外和mask内的合批造成的额外drawcall),一个用于设置遮罩用的stencil buffer,一个用于还原stencil buffer。

       如图,同一个Mask下放置两个使用相同的RawImage,通过Profiler可以看到两个RawImage可以进行合批

       如图,两个RawImage使用相同的,它们处于不同的Mask之下,但是只要m_StencilValue相等,两个RawImage还是libwavpack源码下载可以进行合批。同时可以看到Mask1和Mask1 (1),Mask2和Mask2 (1)也进行了合批,说明stencilDepth相等的Mask符合合批规则也可以进行合批。

       StencilMaterial.Add会将修改后的材质球缓存在m_List中,因此调用StencilMaterial.Add在相同参数情况下将获得同一个材质球。

unity urp源码学习一(渲染流程)

       sprt的一些基础:

       绘制出物体的关键代码涉及设置shader标签(例如"LightMode" = "CustomLit"),以确保管线能够获取正确的shader并绘制物体。排序设置(sortingSettings)管理渲染顺序,如不透明物体从前至后排序,透明物体从后至前,以减少过绘制。逐物体数据的启用、动态合批和gpuinstance支持,以及主光源索引等配置均在此进行调整。

       过滤规则(filteringSettings)允许选择性绘制cullingResults中的几何体,依据RenderQueue和LayerMask等条件进行过滤。

       提交渲染命令是关键步骤,无论使用context还是commandbuffer,调用完毕后必须执行提交操作。例如,context.DrawRenderers()用于绘制场景中的网格体,本质上是执行commandbuffer以渲染网格体。

       sprt管线的基本流程涉及context的命令贯穿整个渲染流程。例如,首次调用渲染不透明物体,随后可能调用渲染半透明物体、天空盒、特定层渲染等。流程大致如下:

       多相机情况也通过单个context实现渲染。

       urp渲染流程概览:

       渲染流程始于遍历相机,如果是游戏相机,则调用RenderCameraStack函数。此函数区分base相机和Overlay相机:base相机遍历渲染自身及其挂载的Overlay相机,并将Overlay内容覆盖到base相机上;Overlay相机仅返回,不进行渲染操作。

       RenderCameraStack函数接受CameraData参数,其中包含各种pass信息。添加pass到m_ActiveRenderPassQueue队列是关键步骤,各种pass类实例由此添加至队列。

       以DrawObjectsPass为例,其渲染流程在UniversialRenderer.cs中实现。首先在Setup函数中将pass添加到队列,执行时,执行队列内的pass,并按顺序提交渲染操作。

源代码都要买吗

       不是的,很多代码都是开源的,很多人都是会分享自己的代码的,除了纯盈利性的项目,但是也可能会有源码流出的,网上有很多,要找到合适自己的,自己想要的,需要慢慢找。本人有空的时候也会写些unity的小游戏,可以相互交流交流。