zoukankan      html  css  js  c++  java
  • Unity_Renderer 中(sharedMaterial 和Miaterial)

    sharedMaterial 和Miaterial 简介:

       我们在使用unity引擎的时候 ,有时候需要去修改某个物体上的material,在Unity的Renderer类里,提供了两个方法接口供我们使用。

      Renderer,material 和 Renderer.sharedMaterial 

      如果你需要修改模型材质的颜色,或者是修改材质shader的一些属性,通常情况是用获取模型的Renderer组件,然后获取他的material属性。

      举一个简单的例子,然后修改颜色或者直接更换shader

      

    1 material.color = Color.red;
    2 material.shader = Resources.Load(“Shader/Alpha-Diffuse”, typeof(Shader)) as Shader;

         Render可以使用material或者是sharedMaterial两个属性。

    1 Renderer render;
    3 render.material;
    5 render.sharedMaterial;

         这两个属性的用法是一样的,但是从效率上来说最好用sharedMaterial ,他是共享材质,无论如何操作材质的属性(如更换颜色或更换shader),内存中智慧占用一份。但是如果要是用material的话,每次更换属性的时候unity就会自动new一份新的material 作用于它。他直到application.loadLevel()或者Resources.UnLoadUnuseAssets()的时候才会释放内存,所以material就有可能会造成内存泄漏那么我们干脆就不要使用它。

       但是在代码中直接使用render.sharedMaterial的话,你会发现在编辑器开发模式下,运行一会游戏本地的 .material文件凡是修改了的都变化了,如果这些文件都在SVN管理中心,那么他们都会变成红色感叹号了,表示文件以及被修改。那样就危险了,一不小心 上传了怎么办。为了解决这个问题,可以用一个简单方法,每次获取material的时候根据平台而定。

         

    1  public static Material GetMaterial(Renderer render)  
    2 {  
    3     #if UNITY_EDITOR  
    4         return render.material;  
    5     #else  
    6         return render.sharedMaterial;  
    7     #endif  
    8 } 

        这样 就不会担心本地文件变化了。

       

    总结 :

        sharedMaterial 和Miaterial 这二者的区别主要在内存管理上,当然主要情况还是要因平台或编程环境而定。

    //------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

        附 带上简单的UV纹理动画

     1 using UnityEngine;
     2 using System.Collections;
     3 
     4 public class ExampleClass : MonoBehaviour {
     5     public float scrollSpeed = 0.5F;
     6     public Renderer rend;
     7     void Start() {
     8         rend = GetComponent<Renderer>();
     9     }
    10     void Update() {
    11         float offset = Time.time * scrollSpeed;
    12         rend.material.mainTextureOffset = new Vector2(offset, 0);
    13     }
    14 }

     

  • 相关阅读:
    es6 yield简单使用
    es6 generator 函数中的yield理解
    es6 promise的使用,同时处理多个异步请求
    es6 filter的使用
    ES6中reduce的计算过程
    es6函数的参数展开
    搭建基于express框架的运行环境
    通过node.js搭建服务,访问html静态页面
    docker compose
    JDBCUtil
  • 原文地址:https://www.cnblogs.com/Roz-001/p/11066081.html
Copyright © 2011-2022 走看看