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

相关文章

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu

java之Objects.nonNull用法代码解读

《java之Objects.nonNull用法代码解读》:本文主要介绍java之Objects.nonNull用法代码,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录Java之Objects.nonwww.chinasem.cnNull用法代码Objects.nonN

idea中创建新类时自动添加注释的实现

《idea中创建新类时自动添加注释的实现》在每次使用idea创建一个新类时,过了一段时间发现看不懂这个类是用来干嘛的,为了解决这个问题,我们可以设置在创建一个新类时自动添加注释,帮助我们理解这个类的用... 目录前言:详细操作:步骤一:点击上方的 文件(File),点击&nbmyHIgsp;设置(Setti

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

在C#中调用Python代码的两种实现方式

《在C#中调用Python代码的两种实现方式》:本文主要介绍在C#中调用Python代码的两种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#调用python代码的方式1. 使用 Python.NET2. 使用外部进程调用 Python 脚本总结C#调

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

Java中&和&&以及|和||的区别、应用场景和代码示例

《Java中&和&&以及|和||的区别、应用场景和代码示例》:本文主要介绍Java中的逻辑运算符&、&&、|和||的区别,包括它们在布尔和整数类型上的应用,文中通过代码介绍的非常详细,需要的朋友可... 目录前言1. & 和 &&代码示例2. | 和 ||代码示例3. 为什么要使用 & 和 | 而不是总是使

Java强制转化示例代码详解

《Java强制转化示例代码详解》:本文主要介绍Java编程语言中的类型转换,包括基本类型之间的强制类型转换和引用类型的强制类型转换,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录引入基本类型强制转换1.数字之间2.数字字符之间引入引用类型的强制转换总结引入在Java编程语言中,类型转换(无论

Vue 调用摄像头扫描条码功能实现代码

《Vue调用摄像头扫描条码功能实现代码》本文介绍了如何使用Vue.js和jsQR库来实现调用摄像头并扫描条码的功能,通过安装依赖、获取摄像头视频流、解析条码等步骤,实现了从开始扫描到停止扫描的完整流... 目录实现步骤:代码实现1. 安装依赖2. vue 页面代码功能说明注意事项以下是一个基于 Vue.js