Renderer.material与Renderer.sharedMaterial的区别

简介: 此函数自动实例化材质并使它们对于此渲染器是唯一的。在销毁游戏对象时销毁材料是您的责任。 Resources.UnloadUnusedAssets 也会破坏材质,但通常仅在加载新关卡时调用。

Renderer.materialRenderer.sharedMaterial的区别

material

Returns the first instantiated Material assigned to the renderer.

Modifying material will change the material for this object only.

If the material is used by any other renderers, this will clone the shared material and start using it from now on.

Note:This function automatically instantiates the materials and makes them unique to this renderer. It is your responsibility to destroy the materials when the game object is being destroyed. Resources.UnloadUnusedAssets also destroys the materials but it is usually only called when loading a new level.

返回分配给渲染器的第一个实例化材质。

修改材质只会更改此对象的材质。

如果该材质被任何其他渲染器使用,这将克隆共享材质并从现在开始使用它。

笔记: 此函数自动实例化材质并使它们对于此渲染器是唯一的。在销毁游戏对象时销毁材料是您的责任。 Resources.UnloadUnusedAssets 也会破坏材质,但通常仅在加载新关卡时调用。

usingUnityEngine;

usingSystem.Collections;

 

publicclassExampleClass : MonoBehaviour

{

   Materialm_Material;

 

   voidStart()

   {

       //从游戏对象的渲染器中获取材质

       m_Material=GetComponent<Renderer>().material;

       print("Materials "+Resources.FindObjectsOfTypeAll(typeof(Material)).Length);

   }

 

   voidUpdate()

   {

       if (Input.GetKeyDown(KeyCode.A))

       {

           //输出游戏对象被销毁前的材质数量

           print("Materials "+Resources.FindObjectsOfTypeAll(typeof(Material)).Length);

           //销毁游戏对象

           Destroy(gameObject);

       }

   }

 

   voidOnMouseOver()

   {

       // 当鼠标悬停在游戏对象上时更改游戏对象的颜色

       m_Material.color=Color.red;

   }

 

   voidOnMouseExit()

   {

       //当鼠标退出游戏对象时将颜色改回白色

       m_Material.color=Color.white;

   }

 

   voidOnDestroy()

   {

       //销毁实例

       Destroy(m_Material);

       //输出材料数量以显示实例是否被删除

       print("Materials "+Resources.FindObjectsOfTypeAll(typeof(Material)).Length);

   }

}

sharedMaterial

Modifying sharedMaterial 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 sharedMaterial. If you want to modify the material of a renderer use material instead.

修改 sharedMaterial 将改变所有使用此材质的对象的外观,并更改存储在项目中的材质设置。 不建议修改 sharedMaterial 返回的材质。

如果要修改渲染器的材质,请改用material

总结

Renderer.sharedMaterial:当多个Renderer共用一个材质时,修改Renderer.sharedMaterial将修改所有引用它的Renderer。Renderer.material:修改Renderer.material只会影响Renderer本身。

运行实例

 

usingSystem.Collections;

usingSystem.Collections.Generic;

usingUnityEngine;

usingUnityEngine.EventSystems;

 

publicclassChange_T : MonoBehaviour

{

 

    publicGameObjectCube;

    //申请GameObject类型的变量 储存Cube模型

 

    publicTextureCard_01;

    //申请Texture类型的变量  储存Card_01图片

 

    // Use this for initialization

    voidStart()

    {

       

    }

 

    // Update is called once per frame

    voidUpdate()

    {

       

    }

 

    //换贴图的按钮函数

    publicvoidButton_T()

    {  

        Cube.GetComponent<Renderer>().sharedMaterial.mainTexture=Card_01;

        //将Cube模型材质的主贴图替换为Card_01

    }

}

 

由图可见,此时Cube模型的材质是Mat_Red,是没有贴图的;我们运行一次并按下Button按钮可见,Mat_Red的贴图已经换成了Card_01


相关文章
|
12天前
|
前端开发 JavaScript API
React 图片放大组件 Image Zoom
本文介绍如何使用React创建图片放大组件(Image Zoom),提升用户体验。组件通过鼠标悬停或点击触发放大效果,利用`useState`管理状态,CSS实现视觉效果。常见问题包括图片失真、性能下降和移动端支持,分别可通过高质量图片源、优化事件处理和添加触摸事件解决。易错点涉及状态管理混乱、样式冲突和过多事件绑定,建议使用上下文API、CSS模块及优化事件绑定逻辑。高级功能扩展如多张图片支持和自定义放大区域进一步丰富了组件的实用性。
43 25
|
3月前
|
XML 编解码 前端开发
svg和canvas的区别
【10月更文挑战第24天】SVG和Canvas各有优缺点,在实际应用中需要根据具体的需求和场景来选择合适的技术来实现图形绘制和交互效果。
72 1
|
4月前
|
XML 存储 前端开发
canvas与svg的区别
canvas与svg的区别
33 4
|
4月前
|
XML 前端开发 JavaScript
Canvas 和 SVG 的区别
Canvas 和 SVG 的区别
71 0
|
4月前
|
XML 移动开发 前端开发
Canvas和SVG的区别
Canvas和SVG的区别
154 0
|
9月前
|
XML 存储 前端开发
canvas和svg的区别
canvas和svg的区别
|
9月前
|
XML 前端开发 JavaScript
canvas和svg有什么区别
canvas和svg的区别
|
XML 前端开发 JavaScript
canvas 和 svg 的区别是什么
canvas 和 svg 的区别是什么
98 0
|
9月前
|
前端开发 开发者
Flutter Canvas 属性详解与实际运用
Flutter Canvas 属性详解与实际运用
185 1
|
9月前
|
XML 移动开发 前端开发
Canvas和SVG有什么区别?
Canvas和SVG有什么区别?
80 1