Legacy Documentation: Version 4.5.0

Script language:

  • JS
  • C#
  • Boo
Script language

Select your preferred scripting language. All code snippets will be displayed in this language.

Renderer.sharedMaterials

Switch to Manual
var sharedMaterials: Material[];
Material[] sharedMaterials;
sharedMaterials as Material[]

Description

All the shared materials of this object.

This is an array of all materials used by the renderer. Unity supports a single object using multiple materials; in this case sharedMaterials contains all the materials. sharedMaterial and material properties return the first used material if there is more than one.

Modifying any material in sharedMaterials will change the appearance of all objects using this material, and change material settings that are stored in the project too.

It is not recommended to modify materials returned by sharedMaterials. If you want to modify the material of a renderer use material instead.

Note that like all arrays returned by Unity, this returns a copy of materials array. If you want to change some materials in it, get the value, change an entry and set materials back.

	print ("I'm using " + renderer.sharedMaterials.Length + " material(s)");
using UnityEngine;
using System.Collections;

public class ExampleClass : MonoBehaviour {
    void Example() {
        print("I'm using " + renderer.sharedMaterials.Length + " material(s)");
    }
}
import UnityEngine
import System.Collections

public class ExampleClass(MonoBehaviour):

	def Example() as void:
		print((('I\'m using ' + renderer.sharedMaterials.Length) + ' material(s)'))

See Also: material, sharedMaterial properties.