Scriptable Build Pipeline - 2018.2 入门指南

2024-05-03 21:08

本文主要是介绍Scriptable Build Pipeline - 2018.2 入门指南,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

                   相关文章暂时还是太少了~  

        转载自:https://docs.google.com/document/d/1uuiEDV7WqpHEylzE4GQwOztCttrwPu6ak0kfELz6ilc/edit#

https://docs.unity3d.com/2018.2/Documentation/ScriptReference/Build.Player.PlayerBuildInterface.html   

https://docs.unity3d.com/Packages/com.unity.scriptablebuildpipeline@0.0-preview/api/UnityEditor.Build.Pipeline.html   

Addressable资源系统的文档可以点击下面来查看:
 https://docs.unity3d.com/Packages/com.unity.addressables@0.2/manual/index.html

==================================================  先个示例代码 =====================

Scriptable Build Pipeline 大多数都是使用 BuildTaskRunnerIBuildTaskIContextObject 类实现功能。

  • IContextObject: 存储数据的接口。
  • IBuildTask: 负责处理构建的接口。BuildTaskRunner按照他们在任务列表Run()中注册的顺序。要使用的数据会[InjectContext]自动注入现场。
  • BuildTaskRunner:执行构建的类

下面的代码只是一个简单的代码,可以注册字母,获取注册的字母并显示它们。

先安装插件:

                    (看到很多文章 说路径在  项目的 Library/ PackageCache  路径下,  但是并没有这个路径呀~~)

或者这样单独添加也行 : 

还要做一件事情:   做一下拷贝 (为什么要做这个拷贝?“我之前的文章   Unity3d 周分享 第x期 ,提到过,方便查看源码,  为了设断点调试   虽然一些反编译工具也可以做到, 但是 设断点查看它的内部执行过程这样做很方便~”  )

  

在 Legacy Build Pipeline 中, 能看到   应该是Unity 5系列的 AB 构建流程 。 

还有  类 DefaultBuildTasks.cs  中

   Demo

using System.Collections.Generic;
using UnityEditor;
using UnityEngine;
using UnityEditor.Build.Pipeline.Interfaces;
using UnityEditor.Build.Pipeline;
using UnityEditor.Build.Pipeline.Injector;
using UnityEngine.Assertions;public static class BuildTest
{// 菜单栏[MenuItem("Build/test build")]static void Build(){//注册上下文//此处注册的上下文用于TaskBuildContext buildContext = new BuildContext();buildContext.SetContextObject<IMyContextData>(new MyContextData { message = "hoge" });//创建任务//任务使用的参数是从上下文中获取的。//任务注册顺序=任务执行顺序IList<IBuildTask> taskList = new List<IBuildTask>();taskList.Add(new DisplayNameTask());//实际执行该过程var result = BuildTasksRunner.Run(taskList, buildContext);Assert.AreEqual(ReturnCode.Success, result);}
}//使用BuildTasksRunner注册的任务
class DisplayNameTask : IBuildTask
{//注入匹配接口的上下文// ContextUsage.In:使用从BuildContext注册的那个// ContextUsage.Out:注册在Run中创建的上下文[InjectContext(ContextUsage.In)]IMyContextData data = null;public int Version { get { return 1; } }public ReturnCode Run(){//仅显示字符的任务//实际上收集对象并更新/生成上下文Debug.Log(data.Name);return ReturnCode.Success;}
}//这次使用的字符数据接口
//在DisplayNameTask上使用InjectContext
public interface IMyContextData : IContextObject
{string Name { get; }
}//上下文数据的实体
public class MyContextData : IMyContextData
{public string message = null;public string Name => message;
}

 

 

======================================================

Note to readers: this content is for the Scriptable Build Pipeline package and will reside in the package documentation at
https://docs.unity3d.com/Manual/PackagesList.html

Documentation source will reside at
https://gitlab.internal.unity3d.com/build-pipeline/AddressablesDemo/tree/master/AddressablesDemo/Packages/com.unity.scriptablebuildpipeline/Documentation

Table of Contents (tableofcontents.md)

Unity Scriptable Build Pipeline (index.md)

  • Getting started with Scriptable Build Pipeline (gettingstarted.md)

  • Terminology (terminology.md)

  • Usage Examples (usageexamples.md)

  • Upgrade Guide (upgradeguide.md)

Unity Scriptable Build Pipeline

The Scriptable Build Pipeline (SBP) package allows you to control how Unity builds content. The package moves the previously C++-only build pipeline code to a public C# package with a pre-defined build flow for building AssetBundles. The pre-defined AssetBundle build flow reduces build time, improves incremental build processing, and provides greater flexibility than before.

 

If you are moving from using BuildPipeline methods to the SBP, see the Usage Examples and Upgrade Guide.

 

Getting started with Scriptable Build Pipeline

Installing the Scriptable Build Pipeline (SBP) package

Requires Unity 2018.2 or later.

To install this package, follow the instructions in the Package Manager documentation.

To build AssetBundles, use the ContentPipeline.BuildAssetBundles() method. In its simplest form, you supply the following parameters:

 

  • Build Parameters - An object that implements the IBuildParameters interface. The object specifies the BuildTarget, the BuildTargetGroup, the output path, and additional optional properties.

  • The content to build - An object that implements the IBundleBuildContent interface. The object specifies the content to build (the assets) and its layout (what assets in which bundles.)

  • A results object - An object that implements the IBundleBuildResults interface. The object receives the details of the built AssetBundles.

 

Note: The UnityEditor.Build.Pipeline namespace contains default implementations for all of the SBP required interfaces.  Implementation names mirror the interfaces, with the leading ‘I’ removed. For example, the IBuildParameters interface is implemented as BuildParameters.

 

To quickly switch to building AssetBundles with SBP, use the CompatibilityBuildPipeline.BuildAssetBundles() method as a drop in replacement for existing code. This method has the nearly identical parameters as the BuildPipeline.BuildAssetBundles() method. For additional information, see the Usage Examples and Upgrade Guide.

 

Terminology

Asset - A source file on disk, typically located in the Project’s Assets folder. This file is imported to a game-ready representation of your Asset internally which can contain multiple Objects (SubAssets.)

 

Object (SubAsset) - A single Unity serializable unit. Also known as a SubAsset. An imported Asset is made up of one or more Objects.

 

Includes - The unique set of Objects from which an Asset is constructed.

 

References - The unique set of Objects that are needed (referenced) by the Includes of an Asset, but not included in the Asset.

 

Usage Examples

Basic Example

This example assumes that your are already familiar with the basic usage of the two BuildPipeline.BuildAssetBundles methods and want to switch to using Scriptable Build Pipeline with as little effort  as possible.

 

The following code example shows how AssetBundles are currently built:

 

using System.IO;

using UnityEditor;

 

public static class BuildAssetBundlesExample

{

   public static bool BuildAssetBundles(string outputPath, bool forceRebuild, bool useChunkBasedCompression, BuildTarget buildTarget)

   {

       var options = BuildAssetBundleOptions.None;

       if (useChunkBasedCompression)

           options |= BuildAssetBundleOptions.ChunkBasedCompression;

 

       if (forceRebuild)

           options |= BuildAssetBundleOptions.ForceRebuildAssetBundle;

 

       Directory.CreateDirectory(outputPath);

       var manifest = BuildPipeline.BuildAssetBundles(outputPath, options, buildTarget);

       return manifest != null;

   }

}

 

To update the previous code example to use SBP instead, replace the call to BuildPipeline.BuildAssetBundles with CompatibilityBuildPipeline.BuildAssetBundles as shown below:

 

using System.IO;

using UnityEditor;

using UnityEditor.Build.Pipeline;

 

public static class BuildAssetBundlesExample

{

   public static bool BuildAssetBundles(string outputPath, bool forceRebuild, bool useChunkBasedCompression, BuildTarget buildTarget)

   {

       var options = BuildAssetBundleOptions.None;

       if (useChunkBasedCompression)

           options |= BuildAssetBundleOptions.ChunkBasedCompression;

 

       if (forceRebuild)

           options |= BuildAssetBundleOptions.ForceRebuildAssetBundle;

 

       Directory.CreateDirectory(outputPath);

       var manifest = CompatibilityBuildPipeline.BuildAssetBundles(outputPath, options, buildTarget);

       return manifest != null;

   }

}

 

Notes: Some changes in the SBP building and loading process do not match the BuildPipeline behavior. For more information on these changes, see the Upgrade Guide.

 

Cache Server Integration Example

This following example shows how to share build artifacts between team members or multiple machines to achieve faster build times.

 

Requirements:

  1. A separate Cache Server instance dedicated to build artifacts. It cannot be shared as an Asset Cache Server as data collisions will occur.

  2. The build code must use the ContentPipeline.BuildAssetBundles method.

  3. BundleBuildParameters.UseCache is set to true.

  4. BundleBuildParameters.CacheServerHost and BundleBuildParameters.CacheServerPort are set to the cache server instance host or IP address and port respectively.

 

Example code:

 

using UnityEditor;

using UnityEditor.Build.Content;

using UnityEditor.Build.Pipeline;

using UnityEditor.Build.Pipeline.Interfaces;

 

public static class BuildAssetBundlesExample

{

   public static bool BuildAssetBundles(string outputPath, bool useChunkBasedCompression, BuildTarget buildTarget, BuildTargetGroup buildGroup)

   {

       var buildContent = new BundleBuildContent(ContentBuildInterface.GenerateAssetBundleBuilds());

       var buildParams = new BundleBuildParameters(buildTarget, buildGroup, outputPath);

       buildParams.UseCache = true;

       buildParams.CacheServerHost = "buildcache.unitygames.com";

       buildParams.CacheServerPort = 8126;

 

       if (useChunkBasedCompression)

           buildParams.BundleCompression = BuildCompression.DefaultLZ4;

 

       IBundleBuildResults results;

       ReturnCode exitCode = ContentPipeline.BuildAssetBundles(buildParams, buildContent, out results);

       return exitCode == ReturnCode.Success;

   }

}

 

Per-Bundle Compression Example

The following example shows how to build your AssetBundles using different compression levels for each AssetBundle.This is useful if you are planning on shipping part of your bundles as Lz4 or Uncompressed with Player and want to download the remainder as Lzma later.

 

The simplest implementation is to create a custom build parameters class that inherits from BundleBuildParameters and override the GetCompressionForIdentifier method. Then construct and pass this into the ContentPipeline.BuildAssetBundles method.

 

using UnityEditor;

using UnityEditor.Build.Content;

using UnityEditor.Build.Pipeline;

using UnityEditor.Build.Pipeline.Interfaces;

 

public static class BuildAssetBundlesExample

{

   class CustomBuildParameters : BundleBuildParameters

   {

       public Dictionary<string, BuildCompression> PerBundleCompression { get; set; }

 

       public CustomBuildParameters(BuildTarget target, BuildTargetGroup group, string outputFolder) : base(target, group, outputFolder)

       {

           PerBundleCompression = new Dictionary<string, BuildCompression>();

       }

 

       public new BuildCompression GetCompressionForIdentifier(string identifier)

       {

           BuildCompression value;

           if (PerBundleCompression.TryGetValue(identifier, out value))

               return value;

           return BundleCompression;

       }

   }

 

   public static bool BuildAssetBundles(string outputPath, bool useChunkBasedCompression, BuildTarget buildTarget, BuildTargetGroup buildGroup)

   {

       var buildContent = new BundleBuildContent(ContentBuildInterface.GenerateAssetBundleBuilds());

       var buildParams = new CustomBuildParameters(buildTarget, buildGroup, outputPath);

       buildParams.PerBundleCompression.Add("Bundle1", BuildCompression.DefaultUncompressed);

       buildParams.PerBundleCompression.Add("Bundle2", BuildCompression.DefaultLZMA);

 

       if (m_Settings.compressionType == CompressionType.None)

           buildParams.BundleCompression = BuildCompression.DefaultUncompressed;

       else if (m_Settings.compressionType == CompressionType.Lzma)

           buildParams.BundleCompression = BuildCompression.DefaultLZMA;

       else if (m_Settings.compressionType == CompressionType.Lz4 || m_Settings.compressionType == CompressionType.Lz4HC)

           buildParams.BundleCompression = BuildCompression.DefaultLZ4;

 

       IBundleBuildResults results;

       ReturnCode exitCode = ContentPipeline.BuildAssetBundles(buildParams, buildContent, out results);

       return exitCode == ReturnCode.Success;

   }

}

Load By Filename Example

The following example shows how to use the CompatibilityBuildPipeline methods to load by a filename instead of the full path.

 

The example uses the ContentBuildInterface.GenerateAssetBundleBuilds() method to get the set of bundles and assets to build, then modifies addressableNames field to set the loading path of the filename instead of the full path.

 

using System.IO;

using System.Linq;

using UnityEditor;

using UnityEditor.Build.Content;

using UnityEditor.Build.Pipeline;

 

public static class BuildAssetBundlesExample

{

   public static bool BuildAssetBundles(string outputPath, bool forceRebuild, bool useChunkBasedCompression, BuildTarget buildTarget)

   {

       var options = BuildAssetBundleOptions.None;

       if (useChunkBasedCompression)

           options |= BuildAssetBundleOptions.ChunkBasedCompression;

 

       if (forceRebuild)

           options |= BuildAssetBundleOptions.ForceRebuildAssetBundle;

 

       var bundles = ContentBuildInterface.GenerateAssetBundleBuilds();

       for (var i = 0; i < bundles.Length; i++)

           bundles[i].addressableNames = bundles[i].assetNames.Select(Path.GetFileNameWithoutExtension).ToArray();

 

       var manifest = CompatibilityBuildPipeline.BuildAssetBundles(m_Settings.outputPath, bundles, options, m_Settings.buildTarget);

       return manifest != null;

   }

}

 

Custom Build Task Example

 

// TODO: make code example

 

Assign Built-In Objects to Bundles Example

 

// TODO: Maybe this should just be built-in shader extraction?

 

Upgrade Guide

To build your AssetBundles with the SBP package, use the CompatibilityBuildPipeline.BuildAssetBundles method wherever you used the BuildPipeline.BuildAssetBundle method.

 

Note: Not all of the features that were supported previously are supported in SBP.

 

The following tables list the features of the CompatibilityBuildPipeline.BuildAssetBundles method in comparison to the BuildPipeline.BuildAssetBundle method.

 

Feature

Support

Notes

AssetBundles

Supported

SBP builds AssetBundles that are built nearly identically to the previous build pipeline. You load them in a similar manner to how you currently load AssetBundles.

Incremental Building

Supported

SBP implements this feature using the BuildCache.

Asset loading path

Behavior changed

AssetBundles built with BuildPipeline today support loading an Asset by full path (“Assets/ExampleFolder/Asset.prefab”) file name (“Asset”) or file name with extension (“Asset.prefab”). However AssetBundles built with SBP by default only support loading an Asset by full path (“Assets/ExampleFolder/Asset.prefab”). This is to avoid loading collision that can occur if two Assets in the same AssetBundle have the different full paths, but the same file name. To change this behavior, the loading path can be set using IBundleBuildContent.Addresses with the ContentPipeline API or AssetBundleBuild.addressableNames field. See Code Examples.

AssetBundle Manifest

Behavior changed

SBP implements replacement functionality using the new class name CompatibilityAssetBundleManifest. This has an identical API to the existing AssetBundleManifest class, and has an additional method to get the CRC value for a bundle which did not exist before.

AssetBundle Variants

Not supported

There is currently no replacement functionality for AssetBundle Variants.



 

BuildAssetBundleOptions Enum:

 

Value

Support

Notes

UncompressedAssetBundle

Supported

Identical to using BuildCompression.DefaultUncompressed with the new API.

ChunkBasedCompression

Supported

Identical to using BuildCompression.DefaultLZ4 with the new API.

Note: This has always been LZ4HC in the Editor, and LZ4 if it was recompressed at Runtime.

DisableWriteTypeTree

Supported

Identical to using ContentBuildFlags.DisableWriteTypeTree with the new API.

DeterministicAssetBundle

Supported

This is enabled by default, and it can’t be disabled. SBP builds deterministically.

ForceRebuildAssetBundle

Supported

Identical to using IBuildParameters.UseCache = false; with the new API.

AppendHashToAssetBundleName

Supported

Identical to using IBundleBuildParameters.AppendHash = true; with the new API.

DisableLoadAssetByFileName

Always enabled

This is enabled by default, and can’t be disabled. SBP is strict about the rule: “what you pass in is exactly what you get out”. If you pass in “My/Example1/Example2/Asset.asset” as the file name to use to load the Asset, you must use that identifier exactly, including the correct upper and lower case, and all punctuation.

DisableLoadAssetByFileNameWithExtension

Always enabled

See above details on DisableLoadAssetByFileName.

IgnoreTypeTreeChanges

Not supported

The incremental build system used this value to prevent rebuilding AssetBundles when an Asset's serialization layout changed, but the data for the Asset itself did not change. SBP currently rebuilds if there are any changes.

StrictMode

Not supported

The SBP is stricter about properly building AssetBundles and knowing when builds fail.

DryRunBuild

Not supported

SBP works fundamentally differently. It is faster to do a full build to determine if anything has changed.



 

 

这篇关于Scriptable Build Pipeline - 2018.2 入门指南的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

SQL Server数据库迁移到MySQL的完整指南

《SQLServer数据库迁移到MySQL的完整指南》在企业应用开发中,数据库迁移是一个常见的需求,随着业务的发展,企业可能会从SQLServer转向MySQL,原因可能是成本、性能、跨平台兼容性等... 目录一、迁移前的准备工作1.1 确定迁移范围1.2 评估兼容性1.3 备份数据二、迁移工具的选择2.1

在 Windows 上安装 DeepSeek 的完整指南(最新推荐)

《在Windows上安装DeepSeek的完整指南(最新推荐)》在Windows上安装DeepSeek的完整指南,包括下载和安装Ollama、下载DeepSeekRXNUMX模型、运行Deep... 目录在www.chinasem.cn Windows 上安装 DeepSeek 的完整指南步骤 1:下载并安装

nginx-rtmp-module构建流媒体直播服务器实战指南

《nginx-rtmp-module构建流媒体直播服务器实战指南》本文主要介绍了nginx-rtmp-module构建流媒体直播服务器实战指南,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. RTMP协议介绍与应用RTMP协议的原理RTMP协议的应用RTMP与现代流媒体技术的关系2

Spring Boot统一异常拦截实践指南(最新推荐)

《SpringBoot统一异常拦截实践指南(最新推荐)》本文介绍了SpringBoot中统一异常处理的重要性及实现方案,包括使用`@ControllerAdvice`和`@ExceptionHand... 目录Spring Boot统一异常拦截实践指南一、为什么需要统一异常处理二、核心实现方案1. 基础组件

电脑密码怎么设置? 一文读懂电脑密码的详细指南

《电脑密码怎么设置?一文读懂电脑密码的详细指南》为了保护个人隐私和数据安全,设置电脑密码显得尤为重要,那么,如何在电脑上设置密码呢?详细请看下文介绍... 设置电脑密码是保护个人隐私、数据安全以及系统安全的重要措施,下面以Windows 11系统为例,跟大家分享一下设置电脑密码的具体办php法。Windo

Python使用qrcode库实现生成二维码的操作指南

《Python使用qrcode库实现生成二维码的操作指南》二维码是一种广泛使用的二维条码,因其高效的数据存储能力和易于扫描的特点,广泛应用于支付、身份验证、营销推广等领域,Pythonqrcode库是... 目录一、安装 python qrcode 库二、基本使用方法1. 生成简单二维码2. 生成带 Log

高效管理你的Linux系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用