Zed-Unity插件代码注释——ZEDLayersManager.cs

2023-11-04 22:38

本文主要是介绍Zed-Unity插件代码注释——ZEDLayersManager.cs,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • Zed-Unity插件代码注释——ZEDLayersManager.cs
    • 引言
    • 基础环境
    • ZEDLayersManager.cs脚本介绍
    • 代码(注释后)

Zed-Unity插件代码注释——ZEDLayersManager.cs

引言

略(2020-09-01 15.50)

基础环境

略(2020-09-01 15.58)

ZEDLayersManager.cs脚本介绍

  • 脚本位置:

在这里插入图片描述

  • 脚本功能:

这个脚本比较短,主要是在Unity启动的时候创建两个图层,一个图层可以在AR模式下被看到,一个看不到。 这个是为了混合现实的时候,控制用户看到的对象。例如把Unity的背景放在看不到的图层里面,然后把虚拟的人物放在可看到的图层里面。同时里面还定义了一个方法用以清除图层。

  • 脚本使用
    这个脚本是在编辑器阶段使用的,一般我们不会直接对里面的函数进行调用,但是里面创建的两个图层对我们来说比较重要。
    unity中默认一共有31个图层,但不一定全都会被使用上,一般0~7图层被unity默认占用,我们只可以自定义8 ~ 31的图层。
    这个脚本默认情况下会把不可见的图层定义在16层, 而把可见的ar图层定义在30层。具体原因可能跟习惯有关???
    在这里插入图片描述
  • 代码结构
    这个脚本比较短,代码结构比较简单,就是先定义了一个图层结构体,里面是图层的一些固定参数,然后定义了图层管理类,类里面两个函数,一个用于创建指定2个图层,一个用于清除给定名称的图层。
    在这里插入图片描述

代码(注释后)

#if UNITY_EDITOR  //Editor Lance: 条件编译, 指的是满足条件的话 把下面的引用对象添加进来
using UnityEditor;
#endif
/** Editor:lance**/
/// <summary>
/// This class creates automaticaly layers on load
/// 此类在加载时自动创建图层
/// Editor lances:创建的这个图层估计是ZED对象的主要图像 例如 画布等
/// </summary>
public struct ZEDLayers
{public static int tagInvisibleToZED = 16; //不可见的图层序号为16层,public static string ID_tagInvisibleToZED = "tagInvisibleToZED";  //图层名称,这个图层对ZED是不可见的//这个估计指的是在AR模式下 用户看不见的图层,例如Unity中的背景public static int arlayer = 30 ;    //定义 AR的图像序号,为30层,public static string ID_arlayer = "arlayer";  // AR图层的名称
}#if UNITY_EDITOR[InitializeOnLoad] // Editor Lance: 监听Unity启动事件 https://blog.csdn.net/huutu/article/details/42318499
public static class ZEDLayersManager
{static ZEDLayersManager() //构造函数,类的初始化{CreateLayer(ZEDLayers.ID_tagInvisibleToZED, ZEDLayers.tagInvisibleToZED); //创建ZED不可见的图层CreateLayer(ZEDLayers.ID_arlayer, ZEDLayers.arlayer);//创建AR图层}/// <summary>/// 创建图层的函数/// </summary>/// <param name="layerName"> 图层名称</param>/// <param name="layerIndex">图层序号</param>public static void CreateLayer(string layerName, int layerIndex){// Editor Lance: 代码的用法 https://docs.unity3d.com/ScriptReference/AssetDatabase.LoadAllAssetsAtPath.htmlUnityEngine.Object[] asset = AssetDatabase.LoadAllAssetsAtPath("ProjectSettings/TagManager.asset"); // Editor Lance:加载Unity工程里面的TagManager的资源if (layerIndex < 7 || layerIndex > 31) return; //Invalid ID.  Editor Lance:unity默认占用了0~7的图层,然后只有8~31的图层可以被自定义if ((asset != null) && (asset.Length > 0)) //资源里面有东西{//Editor Lance: 官方解释 https://docs.unity3d.com/ScriptReference/SerializedObject.html 但是我没看懂具体的意思//Editor Lance: 博客解释 https://blog.csdn.net/weixin_30360497/article/details/98998280?utm_medium=distribute.pc_relevant.none-task-blog-title-1&spm=1001.2101.3001.4242//Editor Lance: 大概的意思就是生成的这个实例是一个被序列化的物品对象,序列化的意思是说在面板上是可见的。SerializedObject serializedObject = new SerializedObject(asset[0]); //asset[0]应该是主要的对象SerializedProperty layers = serializedObject.FindProperty("layers");  // 这个对象有一个叫layers字段的属性for (int i = 0; i < layers.arraySize; ++i) //这个对象是个数组?遍历其中的元素{if (layers.GetArrayElementAtIndex(i).stringValue == layerName) //如果存在我们要创建的层,则修改对应的图层序号{layerIndex = i;//return;     // Layer already present, update layerindex value.}}// Editor Lance:如果上面遍历后发现没有我们要的图层,我们要重新创建if (layers.GetArrayElementAtIndex(layerIndex).stringValue == "") // 如果索引的图层还是空的{layers.GetArrayElementAtIndex(layerIndex).stringValue = layerName; // 赋值图层名称serializedObject.ApplyModifiedProperties(); //应用修改后的属性serializedObject.Update();//更新if (layers.GetArrayElementAtIndex(layerIndex).stringValue == layerName){return;     // to avoid unity locked layer}}}}/// <summary>/// 清除指定的图层名曾/// </summary>/// <param name="layerName"></param>public static void ClearLayer(string layerName){UnityEngine.Object[] asset = AssetDatabase.LoadAllAssetsAtPath("ProjectSettings/TagManager.asset");if ((asset != null) && (asset.Length > 0)){SerializedObject serializedObject = new SerializedObject(asset[0]);SerializedProperty layers = serializedObject.FindProperty("layers"); //Editor Lance:前面代码可以认为是对图层操作的固定代码for (int i = 0; i < layers.arraySize; ++i){if (layers.GetArrayElementAtIndex(i).stringValue == layerName){layers.GetArrayElementAtIndex(i).stringValue = "";}}serializedObject.ApplyModifiedProperties(); //需要调用这两个函数,才可以完成修改serializedObject.Update();//需要调用这两个函数,才可以完成修改}}
}
#endif

这篇关于Zed-Unity插件代码注释——ZEDLayersManager.cs的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

代码随想录冲冲冲 Day39 动态规划Part7

198. 打家劫舍 dp数组的意义是在第i位的时候偷的最大钱数是多少 如果nums的size为0 总价值当然就是0 如果nums的size为1 总价值是nums[0] 遍历顺序就是从小到大遍历 之后是递推公式 对于dp[i]的最大价值来说有两种可能 1.偷第i个 那么最大价值就是dp[i-2]+nums[i] 2.不偷第i个 那么价值就是dp[i-1] 之后取这两个的最大值就是d

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

vscode中文乱码问题,注释,终端,调试乱码一劳永逸版

忘记咋回事突然出现了乱码问题,很多方法都试了,注释乱码解决了,终端又乱码,调试窗口也乱码,最后经过本人不懈努力,终于全部解决了,现在分享给大家我的方法。 乱码的原因是各个地方用的编码格式不统一,所以把他们设成统一的utf8. 1.电脑的编码格式 开始-设置-时间和语言-语言和区域 管理语言设置-更改系统区域设置-勾选Bata版:使用utf8-确定-然后按指示重启 2.vscode

D4代码AC集

贪心问题解决的步骤: (局部贪心能导致全局贪心)    1.确定贪心策略    2.验证贪心策略是否正确 排队接水 #include<bits/stdc++.h>using namespace std;int main(){int w,n,a[32000];cin>>w>>n;for(int i=1;i<=n;i++){cin>>a[i];}sort(a+1,a+n+1);int i=1

Maven(插件配置和生命周期的绑定)

1.这篇文章很好,介绍的maven插件的。 2.maven的source插件为例,可以把源代码打成包。 Goals Overview就可以查看该插件下面所有的目标。 这里我们要使用的是source:jar-no-fork。 3.查看source插件的example,然后配置到riil-collect.xml中。  <build>   <plugins>    <pl

jenkins 插件执行shell命令时,提示“Command not found”处理方法

首先提示找不到“Command not found,可能我们第一反应是查看目标机器是否已支持该命令,不过如果相信能找到这里来的朋友估计遇到的跟我一样,其实目标机器是没有问题的通过一些远程工具执行shell命令是可以执行。奇怪的就是通过jenkinsSSH插件无法执行,经一番折腾各种搜索发现是jenkins没有加载/etc/profile导致。 【解决办法】: 需要在jenkins调用shell脚