EditorTool3D/Assets/TriLib/TriLibSamples/LoadModelFromURL/Scripts/LoadModelFromURLSample.cs

67 lines
2.9 KiB
C#

using UnityEngine;
namespace TriLibCore.Samples
{
/// <summary>
/// Represents a sample that loads a compressed (Zipped) Model.
/// </summary>
public class LoadModelFromURLSample : MonoBehaviour
{
/// <summary>
/// The Model URL.
/// </summary>
public string ModelURL = "https://ricardoreis.net/trilib/demos/sample/TriLibSampleModel.zip";
/// <summary>
/// Creates the AssetLoaderOptions instance, configures the Web Request, and downloads the Model.
/// </summary>
/// <remarks>
/// You can create the AssetLoaderOptions by right clicking on the Assets Explorer and selecting "TriLib->Create->AssetLoaderOptions->Pre-Built AssetLoaderOptions".
/// </remarks>
private void Start()
{
var assetLoaderOptions = AssetLoader.CreateDefaultLoaderOptions();
var webRequest = AssetDownloader.CreateWebRequest(ModelURL);
AssetDownloader.LoadModelFromUri(webRequest, OnLoad, OnMaterialsLoad, OnProgress, OnError, null, assetLoaderOptions);
}
/// <summary>
/// Called when any error occurs.
/// </summary>
/// <param name="obj">The contextualized error, containing the original exception and the context passed to the method where the error was thrown.</param>
private void OnError(IContextualizedError obj)
{
Debug.LogError($"An error occurred while loading your Model: {obj.GetInnerException()}");
}
/// <summary>
/// Called when the Model loading progress changes.
/// </summary>
/// <param name="assetLoaderContext">The context used to load the Model.</param>
/// <param name="progress">The loading progress.</param>
private void OnProgress(AssetLoaderContext assetLoaderContext, float progress)
{
Debug.Log($"Loading Model. Progress: {progress:P}");
}
/// <summary>
/// Called when the Model (including Textures and Materials) has been fully loaded.
/// </summary>
/// <remarks>The loaded GameObject is available on the assetLoaderContext.RootGameObject field.</remarks>
/// <param name="assetLoaderContext">The context used to load the Model.</param>
private void OnMaterialsLoad(AssetLoaderContext assetLoaderContext)
{
Debug.Log("Materials loaded. Model fully loaded.");
}
/// <summary>
/// Called when the Model Meshes and hierarchy are loaded.
/// </summary>
/// <remarks>The loaded GameObject is available on the assetLoaderContext.RootGameObject field.</remarks>
/// <param name="assetLoaderContext">The context used to load the Model.</param>
private void OnLoad(AssetLoaderContext assetLoaderContext)
{
Debug.Log("Model loaded. Loading materials.");
}
}
}