Unity - Scripting API: AssetPostprocessor.OnPreprocessMaterialDescription(MaterialDescription,Material, AnimationClip[]) (original) (raw)
Suggest a change
Success!
Thank you for helping us improve the quality of Unity Documentation. Although we cannot accept all submissions, we do read each suggested change from our users and will make updates where applicable.
Close
Submission failed
For some reason your suggested change could not be submitted. Please try again in a few minutes. And thank you for taking the time to help us improve the quality of Unity Documentation.
Close
Your name Your email Suggestion*
Cancel
Parameters
Parameter | Description |
---|---|
description | A MaterialDescription that describes the imported camera properties and animations. |
material | The material generated by the Model Importer. |
animations | The animation clips generated by the Model Importer. |
Description
Add this function to a subclass to recieve a notification when a new material is created during the import of a ModelImporter.
Unity only calls this function if you set ModelImporter.materialImportMode to ModelImporterMaterialImportMode.ImportViaMaterialDescription. This function gives you control over material properties and animations during the model import process. The MaterialDescription structure contains all the material data from the imported file. You can use it to populate the material and animation clips.
using System.Collections.Generic; using UnityEditor; using UnityEngine; using UnityEditor.AssetImporters;
public class CreateMaterialFromMaterialDescription : AssetPostprocessor { public void OnPreprocessMaterialDescription(MaterialDescription description, Material material, AnimationClip[] materialAnimation) { var shader = Shader.Find("Standard"); if (shader == null) return; material.shader = shader;
List<string> props = new List<string>();
// list the properties of type [Vector4](Vector4.html) :
description.GetVector4PropertyNames(props);
[Debug.Log](Debug.Log.html)(props);
// Read a texture property from the material description.
[TexturePropertyDescription](AssetImporters.TexturePropertyDescription.html) textureProperty;
if (description.TryGetProperty("DiffuseColor", out textureProperty))
{
// Assign the texture to the material.
material.SetTexture("_MainTex", textureProperty.texture);
}
}
}