每個游戲對象(GameObject),其存在于游戲世界,都有一個位置、朝向、大小等基本定位信息;其存于Hierarchy面板,也存在與其他GameObject的相對關系,如父子關系、兄弟關系。Unity中使用Transform來描述和操作這些屬性。
Transform的字面理解就是“變換”的意思,所有的GameObject,當其被創(chuàng)建完成之后,均自動創(chuàng)建了這樣一個變換組件,你不需要手動創(chuàng)建這個組件,而且無法刪除此組件。
接下來,我們將變換組件的主要屬性和功能一一進行解釋。
3.3.1、層次相關的屬性和方法
層次面板
childCount:代表當前GameObject節(jié)點下方有幾個子節(jié)點
hierarchyCount:代表在當前GameObject所處的相互關聯(lián)的樹狀結構中,存在的層次數(shù)目。
相互關聯(lián)的樹狀結構指的是:以Hierarchy面板中的一個頂層GameObject作為根節(jié)點出發(fā)的一棵樹。任何一個GameObject都會存在于一棵樹中。
可以預想的是,這個樹狀結構中的任意一個節(jié)點的hierarchyCount屬性都是相同的。hierarchyCapacity:代表當前所在的樹的層次容量。就是這棵樹最大可以容納的節(jié)點數(shù)目,從整個樹中的任意一個節(jié)點訪問此屬性,所獲取的層次容量都是相同的。
這個參數(shù)是自動增長的,即當GameObject發(fā)生層次變動時,如果當前樹的容量不足,會自動擴容。
可以推測出:樹中所有節(jié)點所查詢的結果實際來自最頂層節(jié)點的屬性,而當層次所發(fā)生變動時,Unity內部只需要修改頂層節(jié)點的這個屬性即可。
需要注意的是,當頻繁變化hierarchyCapacity時,是需要帶來額外的內存消耗和性能消耗的,這與List類的內存擴容是一個道理。因此,應該為頻繁增長的樹的根節(jié)點在一開始就設置一個比較大的容量。parent:代表當前節(jié)點的父節(jié)點,返回一個Transform對象。當此parent為null時,就代表自己已經是頂層節(jié)點,也即樹狀結構中的根節(jié)點了。
root:獲得當前樹狀結構中的根節(jié)點。
DetachChildren():分離子節(jié)點,意思就是將當前節(jié)點下方的所有直接子節(jié)點都分離出去,讓他們成為根節(jié)點。有n個子節(jié)點,將產生n棵新的樹。
Find(string name):根據(jù)路徑查找子節(jié)點,雖然這里的參數(shù)在文檔上顯示為name,但是它實際代表一個路徑。它可以是"magazine/ammo"這種格式,即可以向著葉節(jié)點深度方向查詢多個層次,找到目標Transform并返回。如果找不到返回空。
GetChild(int index):根據(jù)