Unity IFilterBuildAssemblies

Unity IFilterBuildAssemblies是Unity引擎中的一个非常有用的功能,它可以让开发者在构建项目时自定义哪些程序集需要被包含在构建中,哪些程序集需要被排除在建之外。这个功能可以帮助开发者更好地控制项目的构建过程,减少构建时间和构建大小。在本文中,我们将介绍Unity IFilterBuildAssemblies的使用方法,并提供三个使用例子,帮助读者更好地理解这个功能。

Unity IFilterBuildAssemblies的使用方法

Unity IFilterBuildAssemblies是一个接口,它包含一个名为Filter方法。在这个方法中,我们可以编写我们需要执行的操作,并且可以获取构建报告。下是一个简单的例子,演示了如何在构建项目时自定义哪些程序集需要被包含在构建中,哪些程序集需要被排除在构建外:

using UnityEditor.Build;
using UnityEditor.Build.Reporting;
using System.Collections.Generic; public class BuildHandler : IFilterBuildAssemblies
{
public int callbackOrder { get { return 0; } } public void OnBeforeBuild()
{
// Do nothing
} public void OnAfterBuild()
{
// Do nothing
} public string[] OnFilterAssemblies(string[] assemblies)
{
List<string> filteredAssemblies = new List<string>();
foreach (string assembly in assemblies)
{
if (assembly.Contains("MyNamespace"))
{
filteredAssemblies.Add(assembly);
}
}
return filteredAssemblies.ToArray();
}
}

在这个例子中,我们实现了IFilterBuildAssemblies接口,并重写了它的OnFilterAssemblies方法。在这个方法中,我们首先创建了一个空的List对象,用于存储需要包含在构建中的程序集。然后,我们遍历所有的程序集,如果程序集的名称包含"MyNamespace",则将其添加到List对象中。最后,我们将List对象转换为string[]数组,并返回这个数组。

使用例子

下面是三个使用Unity IFilterBuildAssemblies的例子,每个例子都供了具体的实现。

例子1:只包含指定的程序集

在这个例子中,我们将演示如何在构建项目时只包含指定的程序集。

using UnityEditor.Build;
using UnityEditor.Build.Reporting;
using System.Collections.Generic; public class BuildHandler : IFilterBuildAssemblies
{
public int callbackOrder { get { return 0; } } public void OnBeforeBuild()
{
// Do nothing
} public void OnAfterBuild()
{
// Do nothing
} public string[] OnFilterAssemblies(string[] assemblies)
{
List<string> filteredAssemblies = new List<string>();
filteredAssemblies.Add("Assembly-CSharp.dll");
filteredAssemblies.Add("Assembly-CSharp-firstpass.dll");
return filteredAssemblies.ToArray();
}
}

在这个例子中,我们实现了IFilterBuildAssemblies接口,并重写了它的OnAssemblies方法。在这个方法中,我们首先创建了一个List对象,用于存储需要被包含在构建中的程序集。然后,我们将需要被包含在构建中的程序的名称添加到List对象中。最后,我们将List对象转换为string[]数组,并返回这个数组。

例子2:除指定的程序集

在这个例子中,我们将演示如何在构建项目时排除指定的程序集。

using UnityEditor.Build;
using UnityEditor.Build.Reporting;
using System.Generic; public class BuildHandler : IFilterBuildAssemblies
{
public int callbackOrder { get { return 0; } } public void OnBeforeBuild()
{
// Do nothing
} public void OnAfterBuild()
{
// Do nothing
} public string[] OnFilterAssemblies(string[] assemblies)
{
List<string> filteredAssemblies = new List<string>();
foreach (string assembly in assemblies)
{
if (!assembly.Contains("MyNamespace"))
{
filteredAssemblies.Add(assembly);
}
}
return filteredAssemblies.ToArray();
}
}

在这个例子中,我们实现了IFilterBuildAssemblies接口,并重写了它的OnFilterAssemblies方法。在这个方法中,我们首先创建了一个空的List对象,用于存储需要被包含在构建中的程序集。然后,我们遍历所有的程序集,如果程序集的名称不包含"MyNamespace",则将其添加到List对象中。最后,我们将List对象转换为string[]数组,并返回这个数组。

例子3:根据平台选择程序集

在这个例子中,我们将演示如何在构建项目时根据平台选择需要被包含在构建中的程序集。

using UnityEditor.Build;
using UnityEditor.Build.Reporting;
using System.Collections.Generic; public class BuildHandler : IFilterBuildAssemblies
{
public int callbackOrder { get { return 0; } } public void OnBeforeBuild()
{
// Do nothing
} public void OnAfterBuild()
{
// Do nothing
} public string[] OnFilterAssemblies(string[] assemblies)
{
List<string> filteredAssemblies = new List<string>();
if (EditorUserBuildSettings.activeBuildTarget == BuildTarget.Android)
{
filteredAssemblies.Add("Assembly-CSharp.dll");
filteredAssemblies.Add("Assembly-CSharp-firstpass.dll");
}
else if (EditorUserBuildSettings.activeBuildTarget == BuildTarget.iOS)
{
filteredAssemblies.Add("Assembly-CSharp.dll");
filteredAssemblies.Add("Assembly-CSharp-firstpass.dll");
filteredAssemblies.Add("Assembly-CSharp-iOS.dll");
}
else
{
filteredAssemblies.AddRange(assemblies);
}
return filteredAssemblies.ToArray();
}
}

在这个例子中,我们实现了IFilterBuildAssemblies接口,并重写了它的OnFilterAssemblies方法。在这个方法中,我们先创建了一个空的List对象,用于存储需要被包含在构建中的程序集。然后,我们根据当前的平台选择需要被包含在构建中的程序集。如果当前的平台是Android,则只包含"Assembly-CSharp.dll"和"Assembly-CSharp-firstpass.dll"。如果当前的平台iOS,则包含"Assembly-CSharp.dll"、"Assembly-CSharp-firstpass.dll"和"Assembly-CSharp-iOS.dll"。如果当前的平台不是Android或iOS,则包含所有的程序集。最后,我们将List对象转换为string[]数组,并返回这个数组。

结论

Unity IFilterBuildAssemblies是一个非常有用的功能,可以帮助开发者更好地控制项目的构建过程,减少构建时间和构建大小。在本文中,我们介绍了Unity IFilterBuildAssemblies的方法,并提供了三个使用例子,帮助读者更好地理解这个功能。希望这篇文章对读者有所帮助。

Unity的IFilterBuildAssemblies:深入解析与实用案例的更多相关文章

  1. 基于TP5.1实用案例及教程

    推荐<基于TP5.1实用案例及教程>书 目录: 通用封装 Export通用封装Import通用封装配合Import通用封装的ImportBaseVerify类Files通用封装Direct ...

  2. Android之三种网络请求解析数据(最佳案例)

    AsyncTask解析数据 AsyncTask主要用来更新UI线程,比较耗时的操作可以在AsyncTask中使用. AsyncTask是个抽象类,使用时需要继承这个类,然后调用execute()方法. ...

  3. 用DOM4J解析XML文件案例

    用DOM4J解析XML文件案例,由于DOM4J不像JAXP属于JAVASE里,所以如果要使用DOM4J,则必须额外引入jar包,如图:

  4. 精选19款华丽的HTML5动画和实用案例

    下面是本人收集的19款超酷HTML5动画和实用案例,觉得不错,分享给大家. 1.HTML5 Canvas火焰喷射动画效果 还记得以前分享过的一款HTML5烟花动画HTML5 Canvas烟花特效,今天 ...

  5. JAVA实用案例之水印开发

    写在最前面 上周零零碎碎花了一周的时间研究水印的开发,现在终于写了个入门级的Demo,做下笔记同时分享出来供大家参考. Demo是在我上次写的 JAVA实用案例之文件导入导出(POI方式) 框架基础上 ...

  6. JAVA实用案例之图片水印开发

    写在最前面 上周零零碎碎花了一周的时间研究水印的开发,现在终于写了个入门级的Demo,做下笔记同时分享出来供大家参考. Demo是在我上次写的 JAVA实用案例之文件导入导出(POI方式) 框架基础上 ...

  7. JAVA实用案例之文件导出(JasperReport踩坑实录)

    写在最前面 想想来新公司也快五个月了,恍惚一瞬间. 翻了翻博客,因为太忙,也有将近五个多月没认真总结过了. 正好趁着今天老婆出门团建的机会,记录下最近这段时间遇到的大坑-JasperReport. 六 ...

  8. (转载)Android之三种网络请求解析数据(最佳案例)

    [置顶] Android之三种网络请求解析数据(最佳案例) 2016-07-25 18:02 4725人阅读 评论(0) 收藏 举报  分类: Gson.Gson解析(1)  版权声明:本文为博主原创 ...

  9. DNS解析综合学习案例

    DNS解析综合学习案例 #图右侧为做题前环境配置 #命令为红色 #命令加载内容为绿色 #vi编辑内容为蓝色 1.用户需把/dev/myvg/mylv逻辑卷以支持磁盘配额的方式挂载到网页目录下 [roo ...

  10. InfluxDB 聚合函数实用案例

    InfluxDB 聚合函数实用案例 文章大纲 InfluxDB 简介 InfluxDB是GO语言编写的分布式时间序列化数据库,非常适合对数据(跟随时间变化而变化的数据)的跟踪.监控和分析.在我们的项目 ...

随机推荐

  1. 基于 Rainbond 的混合云管理解决方案

    内容概要:文章探讨了混合云场景中的难点.要点,以及Rainbond平台在跨云平台的混合云管理方面的解决方案.包括通过通过统一控制台对多集群中的容器进行编排和管理,实现了对混合云中应用的一致性管理.文章 ...

  2. 粘包/拆包问题一直都存在,只是到TCP就拆不动了。

    OSI open-system-Interconnection TCP/IP 5层协议栈 应用层和操作系统的边界是 系统调用 ,对应到网络编程是socket api TCP/UDP 概况 TCP粘包问 ...

  3. 2022-01-25:序列化和反序列化 N 叉树。 序列化是指将一个数据结构转化为位序列的过程,因此可以将其存储在文件中或内存缓冲区中,以便稍后在相同或不同的计算机环境中恢复结构。 设计一个序列化和反

    2022-01-25:序列化和反序列化 N 叉树. 序列化是指将一个数据结构转化为位序列的过程,因此可以将其存储在文件中或内存缓冲区中,以便稍后在相同或不同的计算机环境中恢复结构. 设计一个序列化和反 ...

  4. java中this的内存原理以及成员变量和局部变量

    this的内存原理 1.this的作用: 区分局部变量和成员变量 eg: public class Student{ private int age; public void method(){ in ...

  5. 用rust 写一个jar包 class冲突检测工具

    Rust很适合写命令行工具,特别是使用clap crate 更加方便,这篇文章介绍使用rust写一个jar包class冲突检测的工具.项目地址: https://github.com/Aitozi/j ...

  6. docker 下MySQL主从读写分离配置

    主从同步机制: 同步基于耳机子机制,主服务器使用二进制来记录数据库的变动状况,从服务器通过读取和执行日志文件来保存主服务的数据一致 首先要保障主从的版本一致或相近 1 登陆docker,拉取镜像 do ...

  7. odoo开发教程六:工作流、安全机制、向导

    一:工作流 工作流是与业务流程相关联的模型,可用于跟踪工序的动态演变过程. 工作流.活动(节点或操作).转换通常在xml里以record定义.在工作流中处理的单个流程称为工作项. 与模型关联的工作流是 ...

  8. ODDO之三 :Odoo 13 开发之创建第一个 Odoo 应用

    Odoo 开发通常都需要创建自己的插件模块.本文中我们将通过创建第一个应用来一步步学习如何在 Odoo 中开启和安装这个插件.我们将从基础的开发流学起,即创建和安装新插件,然后在开发迭代中更新代码来进 ...

  9. drf之频率类源码

    1 频率类 写一个类,继承SimpleRateThrottle,重写get_cache_key,返回[ip,用户id]什么,就以什么做限制,编写类属性 scope = 字符串,在配置文件中配置 'DE ...

  10. 柏林噪声&幻想大陆地图生成

    序言 之前介绍过perlin噪声的实现,现在应用实践一下--程序化生成幻想大陆 这里使用的是perlin噪声倍频技术(也称分形噪声),详情传送门:柏林噪声算法 代码示例使用的是shadertoy的语法 ...