public void SetColorArray (string name, Color[] values);
public void SetColorArray (int nameID, Color[] values);
public void SetColorArray (string name, List<Color> values);
public void SetColorArray (int nameID, List<Color> values);


nameProperty name.
nameIDProperty name ID, use Shader.PropertyToID to get it.
valuesArray of values to set.


Sets a color array property.

Sets a color array property on the material. If a color array property with the given name already exists, the old value is replaced.

It is just an alias to SetVectorArray, only colors are cast to vectors. No sRGB-linear conversion is done during the function call.

The array length can't be changed once it has been added to the block. If you subsequently try to set a longer array into the same property, the length will be capped to the original length and the extra items you tried to assign will be ignored. If you set a shorter array than the original length, your values will be assigned but the original values will remain for the array elements beyond the length of your new shorter array.

Array parameters are not exposed in the material inspector, nor serialized with the material asset. But they can be set and queried with SetFloatArray, SetColorArray, SetVectorArray, SetMatrixArray and the corresponding getters from scripts at runtime.

See Also: GetColorArray, SetVectorArray.