首页 > 其他分享 >Unity显示一个对象的像素个数

Unity显示一个对象的像素个数

时间:2023-10-29 22:22:59浏览次数:35  
标签:fieldbuf MainTex int text 个数 shader 像素 Unity countBuf

下图显示了该面片占用的像素个数为147456
因为面片的大小为1,坐标为(0,0.5f,0)。相机为正交视角,OrthoSize为1. 面片完全显示且高度为 (768/2)^2 = 384^2 = 147456。

另外,可以推测,pixel shader渲染会在所有对象的vertex shader计算结束后开始。
即使面片被遮挡,但如果没做处理依然存在渲染的开销。【放置两个面片发现占用的像素个数数量加倍】。disable其中一个对象后,像素个数变回原值。

过程

使用了 https://github.com/cinight/MinimalCompute 项目中的 05_1_UAVInShader 例子。

修改代码如下:

using UnityEngine;
using System.Collections;
using UnityEngine.Rendering;

public class UAVInShader : MonoBehaviour
{
    public Material mat;
    public TextMesh text;

    private int targetID = 6; //match with shader "register(u6)"
    private ComputeBuffer fieldbuf;
    private float[] fdata = new float[3];

    private int ctargetID = 1; 
    private ComputeBuffer countBuf;
    private int[] cData = new int[1];

    public int count;


    void OnEnable()
    {
        Setup();
    }

    void OnDisable()
    {
        Graphics.ClearRandomWriteTargets(); //this prevent crash
        if (fieldbuf != null)
        {
            fieldbuf.Release();
            fieldbuf.Dispose();
            fieldbuf = null;
        }

        if(countBuf != null)
        {
            countBuf.Release();
            countBuf.Dispose();
            countBuf = null;
        }
    }

    void Setup()
    {
        if (fieldbuf == null)
        {
            fieldbuf = new ComputeBuffer(4, sizeof(float), ComputeBufferType.Default);
        }

        if(countBuf== null)
        {
            countBuf = new ComputeBuffer(1,sizeof(int), ComputeBufferType.Default);
        }

    }


    void OnRenderObject()
    {
        Graphics.ClearRandomWriteTargets();
        Setup();
        mat.SetPass(0);

        //名字和shader中的RWBuffer无关
        mat.SetBuffer("Field1", fieldbuf);
        mat.SetBuffer("Count2", countBuf);

        Graphics.SetRandomWriteTarget(targetID, fieldbuf);
        Graphics.SetRandomWriteTarget(ctargetID, countBuf);

        fieldbuf.GetData(fdata);
        text.text = "From shader, the RGB value of rainbow color \n";
        for (int i = 0; i < fdata.Length; i++)
        {
            text.text += i + ":  " + fdata[i] + "\n";
        }

        countBuf.GetData(cData);
        text.text += cData[0] + "\n";
    }
}

Shader "UAVTest/VertFrag"
{
	Properties
	{
		_MainTex("_MainTex (RGBA)", 2D) = "white" {}
		_Speed("_Speed",Range(0,0.5)) = 0.5
	}
	SubShader
	{
		Tags{ "RenderType" = "Opaque" }

		Pass
		{
			CGPROGRAM
			#pragma vertex vert
			#pragma fragment frag
			#pragma target 5.0

			#include "UnityCG.cginc"

			struct appdata
			{
				float4 vertex : POSITION;
				float2 uv : TEXCOORD0;
			};

			struct v2f
			{
				float2 uv : TEXCOORD0;
				float4 vertex : SV_POSITION;
			};

			sampler2D _MainTex;
			float4 _MainTex_ST;

			float _Speed;

			#ifdef UNITY_COMPILER_HLSL
				RWStructuredBuffer<float> Field : register(u6); //match with C# script "targetID"
				RWStructuredBuffer<int> Count : register(u1); //match with C# script "targetID"
			#endif

			v2f vert(appdata v)
			{
				Count[0] = 0;
				v2f o;
				o.vertex = UnityObjectToClipPos(v.vertex);
				o.uv = TRANSFORM_TEX(v.uv, _MainTex);

				return o;
			}

			fixed4 frag(v2f i) : SV_Target
			{
				//Rainbow color
				float3 c;
				c.r = frac(sin(_Time.x*_Speed));
				c.g = frac(sin(_Time.z*_Speed));
				c.b = frac(sin(_Time.w*_Speed));

				#ifdef UNITY_COMPILER_HLSL
					Field[0] = c.r;
					Field[1] = c.g;
					Field[2] = c.b;
				#endif

				InterlockedAdd(Count[0],1);

				float4 col = tex2D(_MainTex, i.uv);
				col.rgb *= c;
				return col;
			}
			ENDCG
		}
	}
}

参考

https://github.com/cinight/MinimalCompute
https://forum.unity.com/threads/setting-buffer-data-from-inside-fragment-shader-to-be-read-from-c-script-urp.1229175/

标签:fieldbuf,MainTex,int,text,个数,shader,像素,Unity,countBuf
From: https://www.cnblogs.com/dewxin/p/17796633.html

相关文章

  • Unity学习笔记--入门
    Unity引擎学习入门:Unity中的坐标系:左手坐标系(z轴正方向向里面)x轴:平行屏幕向右正方向y轴:平行屏幕向上正方向Z轴:垂直屏幕向内为正方向【补】openGL是右手坐标系DirectX是左手坐标系窗口:窗口布局Layout:Scene这里我们可以看见所有的场景内容。窗口上的工具栏:有关......
  • Unity进阶开发-FSM有限状态机
    #Unity进阶开发-FSM有限状态机前言我们在进行开发时,到了一定程度上,会遇到数十种状态,继续使用Unity的Animator控制器会出现大量的bool,float类型的变量,而这些错综复杂的变量与Animatator控制器如同迷宫版连线相结合会变得极其的复杂且无法良好维护扩展,出现一个BUG会导致开发过程......
  • Unity进阶提升-2D游戏跳跃手感优化(跳起下落)
    在进行2D游戏开发时,跳跃是不可缺少的一个重要功能。但是我们在Unity开发时Unity本身的物理引擎并不能提供很好的的手感,下落的时候轻飘飘的,这操作起来显然非常不舒服。所以,我们需要自己对跳跃进行优化,以此来获得更好的手感。我们不难发现,在绝大多数2D游戏的跳跃中,下落的速度比上升......
  • 单像素成像中观测矩阵的设计
    1.2022-DeepLearningOptimizedTerahertzSingle-PixelImaging创新点:However,allthesereportsfocusonreducingthesamplingrateorthenumberofpatternsM,butleavethesamplingtimeperpatternt0untouched.观测矩阵:However,thesecompressedsensingalgor......
  • 代码随想训练营第十六天(Pyhton)| 104.二叉树的最大深度、 111.二叉树的最小深度、222.完
    104.二叉树的最大深度1、后续遍历递归法classSolution:defmaxDepth(self,root:Optional[TreeNode])->int:ifrootisNone:return0left_depth=self.maxDepth(root.left)#左right_depth=self.maxDepth(root.right)#......
  • LeetCode 611. 有效三角形的个数
    有效三角形的个数题目链接611.有效三角形的个数给定一个包含非负整数的数组nums,返回其中可以组成三角形三条边的三元组个数。示例1:输入:nums=[2,2,3,4]输出:3解释:有效的组合是:2,3,4(使用第一个2)2,3,4(使用第二个2)2,2,3示例2:输入:nums=[4,2,3,4]输出:......
  • 让物体动起来,Unity的几种移动方式
    一、前言在大部分的Unity游戏开发中,移动是极其重要的一部分,移动的手感决定着游戏的成败,一个优秀的移动手感无疑可以给游戏带来非常舒服的体验。而Unity中有多种移动方法,使用Transform,使用刚体Rigidbody,使用CharacterController,使用NavMesh导航系统等等等等。当然,对于新手来说,最常......
  • Unity 3D定点数物理引擎实战系列4
    1.4基于Unity整合BEPUphysicsint物理引擎实战 上一节我们详细的讲解BEPUphysicsint的物理事件。此物理引擎会产生了碰撞事件与非碰撞事件,碰撞事件大家好理解,非碰撞事件例如: 物理Entity的update事件,Entity的activation/deactivation事件等。本节课来实战如何编译BEPUphysics......
  • Unity DOTS系列之Aspect核心机制分析
      最近DOTS发布了正式的版本,我们来分享一下DOTS里面Aspect机制,方便大家上手学习掌握UnityDOTS开发。Aspect 机制概述当我们使用ECS开发的时候,编写某个功能可能需要某个entity的一些组件,如果我们一个个组件的查询出来,可能参数会写很长。如果我们编写某个功能的时候,需要enti......
  • 循序渐进介绍基于CommunityToolkit.Mvvm 和HandyControl的WPF应用端开发(6) -- 窗口控
    在我们窗口新增、编辑状态下的时候,我们往往会根据是否修改过的痕迹-也就是脏数据状态进行跟踪,如果用户发生了数据修改,我们在用户退出窗口的时候,提供用户是否丢弃修改还是继续编辑,这样在一些重要录入时的时候,可以避免用户不小心关掉窗口,导致窗口的数据要重新录入的尴尬场景。本篇随......