Unity实现自定义图集(二)

news2025/1/13 19:44:15

以下内容是根据Unity 2020.1.0f1版本进行编写的

实现一个自定义图集,该怎么入手呢。首先简单思考一下unity是怎么实现图集的。
因为unity的ui部分是开源的,所以我们可以看到UGUI的源代码,另外,Unity的内置Shader也是开源的,可以直接在官网下载(在下载的网页选择Built in shaders下载即可):https://unity.com/releases/editor/archive

首先,图集在Unity编辑器中是可编辑的,因此,需要实现一个自定义图集的Inspector面板,并定义好图集的基础属性,方便使用。

1、实现自定义图集类MyAtlas

using System.Collections.Generic;
using UnityEngine;

[CreateAssetMenu(fileName = "MyAtlas", menuName = "My Atlas")]
public class MyAtlas : ScriptableObject
{
   
    public string atlasName = "";
    public List<string> guids = new List<string>();
    public List<string> packableObjects = new List<string>();
    public List<string> realPackObjs = new List<string>();
    public List<UnityEngine.Object> objs = new List<Object>();
}

首先,定义自定义的图集类MyAtlas,这里只定义Inspector面板需要用到的变量。需要继承ScriptableObject类,否则无法实现自定义类型的后处理导入
其中,atlasName是图集名字,guids是图集包含全部图片的guid,realPackObjs是图集包含全部图片的路径,Objs是显示在Inspector面板的Object,packableObjects是Objs对应的路径,因为有可能是文件夹,所以需要和realPackObjs区分开来。
在这里插入图片描述
在这里插入图片描述
右键新建一个MyAtlas文件,如上图,这样可以了

2、实现自定义图集类的Inspector面板

using System;
using System.Collections.Generic;
using System.IO;
using System.Runtime.InteropServices;
using System.Security.Cryptography;
using UnityEngine;

public class CommonFunc : MonoBehaviour
{
   
	public static void SeachFile(string path, List<string> files, string[] extensions)
	{
   
		if (Directory.Exists(path))
		{
   
			DirectoryInfo di = new DirectoryInfo(path);
			FileSystemInfo[] fsInfos = di.GetFileSystemInfos();
			bool isSkip;
			foreach (FileSystemInfo fsInfo in fsInfos)
			{
   
				isSkip = true;
				if (fsInfo is DirectoryInfo)
				{
   
					SeachFile(fsInfo.FullName, files, extensions);
				}
				if (fsInfo.Name.Contains(".meta"))
				{
   
					continue;
				}
				foreach (string extension in extensions)
				{
   
					if (fsInfo.Name.Contains(extension))
					{
   
						isSkip = false;
						break;
					}
				}
				if (!isSkip)
				{
   
					string fileN = fsInfo.FullName;
					string ss = "Assets" + fileN.Replace("\\", "/").Replace(Application.dataPath, "");
					if (!files.Contains(ss))
					{
   
						files.Add(ss);
					}
				}
			}
		}
	}

	public static List<string> GetAllFilesInDirectory(string path, string searchParttern, List<string> list = null, bool isUnityPath = false)
	{
   
		if (list == null)
		{
   
			list = new List<string>();
		}
		var files = Directory.GetFiles(path, searchParttern, SearchOption.AllDirectories);
		foreach (var file in files)
		{
   
			string filePath = file.Replace("\\", "/");
			if (isUnityPath)
            {
   
				filePath = GetUnityPath(filePath);
            }
			list.Add(filePath);
		}
		return list;
	}

	public static string GetMD5Hash(string filePath)
	{
   
		MD5 md5 = new MD5CryptoServiceProvider();
		return BitConverter.ToString(md5.ComputeHash(File.ReadAllBytes(filePath))).Replace("-", "").ToLower();
	}

	public static string GetUnityPath(string path)
	{
   
		string newPath = path;
		if (newPath.Contains(Application.dataPath))
		{
   
			newPath = newPath.Replace(Application.dataPath, "Assets");
		}
		if (newPath.Contains(Application.dataPath.Replace("/", "\\")))
		{
   
			newPath = newPath.Replace(Application.dataPath.Replace("/", "\\"), "Assets");
		}
		if (newPath.Contains(Application.dataPath.Replace("\\", "/")))
		{
   
			newPath = newPath.Replace(Application.dataPath.Replace("\\", "/"), "Assets");
		}
		newPath = newPath.Replace("\\", "/");
		return newPath;
	}

	public static string GetSystemPath(string path)
	{
   
		string newPath = path;
		if (newPath.StartsWith("Assets"))
		{
   
			newPath = Application.dataPath.Replace("Assets", "") + newPath;
		}
		newPath = newPath.Replace("/", "\\");
		return newPath;
	}

	public class Messagebox
	{
   
		[DllImport("User32.dll", SetLastError = true, ThrowOnUnmappableChar = true, CharSet = CharSet.Auto)]
		public static extern int MessageBox(IntPtr handle, String message, String title, int type);
	}
}

首先实现一个通用的类CommonFunc,包含一些通用方法,如文件路径转换UnityPath,或者转换为系统路径,等等。

using System.Collections.Generic;
using System.IO;
using UnityEditor;
using UnityEditor.UI;
using UnityEditorInternal;
using UnityEngine;

[

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2199306.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

一文彻底搞懂大模型 - Hugging Face Transformers

Hugging Face Hugging Face Transformers是一个开源的预训练模型库&#xff0c;旨在将NLP领域的最新进展向更广泛的机器学习社区开放。该库包含了经过精心设计的最先进的Transformer架构&#xff0c;并提供了易于使用的API**&#xff0c;使得研究人员和开发者能够轻松地加载、…

Linux环境安装Anaconda

1.环境检查 uname -a2.下载Anaconda 下载地址: Anaconda 根据自己的版本下载 3.安装Anaconda 将下载的文件上传到Linux服务器设置权限 chmod x Anaconda3-2024.02-1-Linux-x86_64.sh执行.sh文件 ./Anaconda3-2024.02-1-Linux-x86_64.sh直接回车&#xff0c;一直回车&…

解决:由于没有远程桌面授权服务器可以提供许可证,远程会话连接已断开.请跟服务器管理员联系

今天早上远程连接京东云服务器&#xff0c;居然蹦出了下面的提示 查了下这个提示&#xff0c;出现这个报错的原因有两种&#xff1a; 1. 系统添加了“远程桌面会话主机”角色后&#xff0c;该授权到期&#xff08;可以免费试用120天&#xff0c;到期需要付费才能使用&#xff…

有哪些AI产品可以真正提高办公和学习效率?

你还在为加班熬夜、效率低下而苦恼吗&#xff1f;还在担心错过AI时代的风口&#xff0c;被时代抛弃吗&#xff1f; 告别效率焦虑&#xff0c;AI赋能你的学习和工作 现在有一些AI产品能为我们提供帮助&#xff0c;比如豆包、KIMI、通义千问、ChatGPT等等&#xff0c;帮助我们做P…

【深度学习】—激活函数、ReLU 函数、 Sigmoid 函数、Tanh 函数

【深度学习】—激活函数、ReLU 函数、 Sigmoid 函数、Tanh 函数 4.1.2 激活函数ReLU 函数参数化 ReLU Sigmoid 函数背景绘制 sigmoid 函数Sigmoid 函数的导数 Tanh 函数Tanh 函数的导数总结 4.1.2 激活函数 激活函数&#xff08;activation function&#xff09;用于计算加权和…

【有啥问啥】逆向工程(Reverse Engineering,RE):深度解析与技术方法

逆向工程&#xff08;Reverse Engineering&#xff0c;RE&#xff09;&#xff1a;深度解析与技术方法 引言 逆向工程&#xff08;Reverse Engineering&#xff0c;简称RE&#xff09;&#xff0c;作为现代科技领域中的一项重要技术&#xff0c;其影响力已远远超越了传统的硬…

“聪明车”上线“智慧路”!批量苏州金龙海格公交甘肃静宁投运

近日&#xff0c;甘肃省静宁县智慧公交系统正式上线&#xff0c;20台苏州金龙海格蔚蓝新能源公交车正式投入使用&#xff0c;大大提升了当地城市公共交通的智能水平以及城市形象。 智慧交通&#xff0c;势在必行 随着公共交通出行需求的不断升级&#xff0c;客运市场对于智能化…

爬虫请求响应以及提取数据

爬虫请求响应以及提取数据 回顾: 网页给客户端响应数据, 有哪些写法(在爬虫入门之爬虫原理以及请求响应这篇博客咯嘛有提到)? 1.响应对象.text(获取网页数据的时候会用到) 2.响应对象.content(将图片, 音频或视频等数据存放到文件的时候会用到) 那这一篇文章, 介绍一个新的写法…

小白打造爆款必备:速卖通平台测评与买家号培养全解析

随着亚马逊平台风控的持续升级&#xff0c;众多卖家面临着封店、侵权等诸多挑战&#xff0c;迫使许多商家开始探索其他市场&#xff0c;如速卖通、Temu等平台&#xff0c;这些平台对新入驻的卖家提供了显著的流量扶持。在速卖通平台的运营中&#xff0c;如何迅速且有效地提升店…

动态规划11:面试题 17.16. 按摩师

动态规划解题步骤&#xff1a; 1.确定状态表示&#xff1a;dp[i]是什么 2.确定状态转移方程&#xff1a;dp[i]等于什么 3.初始化&#xff1a;确保状态转移方程不越界 4.确定填表顺序&#xff1a;根据状态转移方程即可确定填表顺序 5.确定返回值 题目链接&#xff1a;面试…

论文翻译 | Language Models are Few-Shot Learners 语言模型是少样本学习者(上)

摘要 最近的工作表明&#xff0c;通过在大规模文本语料库上进行预训练&#xff0c;然后在特定任务上进行微调&#xff0c;许多自然语言处理&#xff08;NLP&#xff09;任务和基准测试都取得了显著的提升。尽管这种方法在架构上通常是任务无关的&#xff0c;但它仍然需要成千上…

【vue2.7.16系列】手把手教你搭建后台系统__配置路由(3)

新建页面 我们把 components 改名为 views&#xff0c;并在 views 目录下添加三个页面&#xff0c;Login.vue&#xff0c;Home.vue&#xff0c;404.vue。 三个页面内容简单相似&#xff0c;只有简单的页面标识&#xff0c;如首页页面是 “Home Page”。 Home.vue&#xff0c;…

windows客户端SSH连接ubuntu/linux服务器,三种网络连接:局域网,内网穿透(sakuraftp),虚拟局域网(zerotier)

windows客户端SSH连接ubuntu/linux服务器&#xff0c;三种网络连接&#xff1a;局域网&#xff0c;内网穿透&#xff08;sakuraftp&#xff09;&#xff0c;虚拟局域网&#xff08;zerotier&#xff09; 目录 SSH简述、三种网络连接特点SSH简述局域网内连接内网穿透&#xff08…

SpringBoot助力校园资料分享:快速上手指南

2相关技术 2.1 MYSQL数据库 MySQL是一个真正的多学生、多线程SQL数据库服务器。 是基于SQL的客户/服务器模式的关系数据库管理系统&#xff0c;它的有点有有功能强大、使用简单、管理方便、安全可靠性高、运行速度快、多线程、跨平台性、完全网络化、稳定性等&#xff0c;非常适…

LabVIEW提高开发效率技巧----队列使用

在LabVIEW开发中&#xff0c;队列是实现并行处理、数据传递和任务调度的关键机制之一&#xff0c;合理使用队列可以有效提高程序性能并避免内存问题。结合队列长度限制和其他队列相关技巧&#xff0c;以下是队列使用的详细说明&#xff1a; 1. 队列长度限制 限制队列的长度可以…

maven打包常用命令

跳过tset打包 mvn package -Dmaven.test.skiptrue

构建高效水果购物平台:SpringBoot飘香网站案例

1系统概述 1.1 研究背景 如今互联网高速发展&#xff0c;网络遍布全球&#xff0c;通过互联网发布的消息能快而方便的传播到世界每个角落&#xff0c;并且互联网上能传播的信息也很广&#xff0c;比如文字、图片、声音、视频等。从而&#xff0c;这种种好处使得互联网成了信息传…

入门级攻略:如何容器化部署微服务?

如何容器化部署微服务&#xff1f;第一步理解容器化基础&#xff0c;第二步创建Dockerfile&#xff0c;第三步构建推送镜像&#xff0c;第四步部署微服务&#xff0c;第五步管理微服务、第六步优化更新。容器化部署微服务是现代软件开发中的一种高效方法&#xff0c;可提供良好…

55页可编辑PPT | 制造企业数字化转型顶层规划案例

基于集团的战略和运营特点&#xff0c;数字化转型应如何考虑&#xff1f; 在集团的战略和运营特点基础上进行数字化转型&#xff0c;需要实现业务多元化&#xff0c;整合资源和流程&#xff0c;推动国际化拓展&#xff0c;实施差异化战略&#xff0c;并通过数据驱动决策&#…

3D图形学新手简明教程

如今&#xff0c;3D 计算机图形 (CG) 无处不在。从视频游戏到医疗应用。 电影行业由计算机主导&#xff0c;而不仅仅是科幻和动画。在拍摄《爱尔兰人》时&#xff0c;马丁斯科塞斯使用计算机特效让演员罗伯特德尼罗、乔佩西和阿尔帕西诺变年轻。 当你意识到第一部采用计算机生…