-
Notifications
You must be signed in to change notification settings - Fork 47
/
GameObjectSet.cs
226 lines (181 loc) · 6.73 KB
/
GameObjectSet.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
using System;
using System.Collections.Generic;
using UnityEngine;
namespace f3
{
// [RMS] use gameObj.AddComponent<IgnoreMaterialChanges>() on
// GameObject instances to prevent material from being modified by
// other calls to GameObjectSet
public class IgnoreMaterialChanges : MonoBehaviour
{
}
/// <summary>
/// GameObjectSet is a utility class that provides a more useful interface
/// to a set of GameObject children. Most implementations of core F3 classes
/// like SceneObject, SceneUIElement, etc, are derived from GameObjectSet.
/// </summary>
public class GameObjectSet
{
protected List<GameObject> vObjects;
public GameObjectSet ()
{
vObjects = new List<GameObject> ();
}
public List<GameObject> GameObjects {
get { return vObjects; }
}
public void ClearGameObjects(bool bDestroy = true, float fDelay = 0.0f)
{
if ( bDestroy ) {
foreach (GameObject go in vObjects)
UnityUtil.DestroyAllGameObjects(go, fDelay);
}
vObjects = new List<GameObject>();
}
public bool HasGO(GameObject go) {
GameObject found = vObjects.Find (x => x == go);
return found != null;
}
/// <summary>
/// Finds the first child GO named sName. Optionally searches nested children.
/// </summary>
public GameObject FindGOByName(string sName, bool bRecurse = true)
{
for (int i = 0; i < vObjects.Count; ++i) {
if (vObjects[i].GetName() == sName)
return vObjects[i];
if ( bRecurse && vObjects[i].HasChildren() ) {
GameObject found = vObjects[i].FindChildByName(sName, bRecurse);
if (found != null)
return found;
}
}
return null;
}
public virtual void AppendExistingGO(GameObject go)
{
vObjects.Add(go);
}
public virtual GameObject AppendExistingChildGO(GameObject parent, string childName)
{
GameObject child = parent.transform.Find(childName).gameObject;
vObjects.Add(child);
child.SetLayer(parent.GetLayer());
return child;
}
public virtual void AppendNewGO(fGameObject go, fGameObject parent, bool bKeepPosition)
{
vObjects.Add(go);
go.SetParent(parent, bKeepPosition);
go.SetLayer(parent.GetLayer());
foreach (GameObject child_go in go.Children()) {
vObjects.Add(child_go);
child_go.SetLayer(parent.GetLayer());
}
}
public virtual fMeshGameObject AppendMeshGO(string name, fMesh mesh, fMaterial setMaterial, fGameObject parent, bool bCollider = true) {
fMeshGameObject go = new fMeshGameObject(mesh, true, bCollider);
go.EnableCollisions = false;
go.SetMaterial(setMaterial);
go.SetName(name);
vObjects.Add (go);
if (parent != null) {
parent.AddChild(go);
go.SetLayer(parent.GetLayer());
}
return go;
}
public virtual fGameObject AppendUnityPrimitiveGO(string name, PrimitiveType eType, Material setMaterial, GameObject parent, bool bCollider = true) {
var gameObj = GameObject.CreatePrimitive (eType);
if (bCollider) {
gameObj.AddComponent<MeshCollider>();
gameObj.DisableCollider();
}
gameObj.GetComponent<MeshRenderer> ().material = setMaterial;
gameObj.SetName(name);
vObjects.Add (gameObj);
if (parent != null) {
gameObj.transform.parent = parent.transform;
gameObj.SetLayer(parent.GetLayer());
}
return new fGameObject(gameObj, FGOFlags.NoFlags);
}
public virtual void RemoveGO(fGameObject go)
{
vObjects.Remove(go);
go.SetParent(null, true);
}
public virtual void SetAllGOMaterials(Material m) {
foreach (var go in vObjects) {
if (go.GetComponent<IgnoreMaterialChanges>() == null) {
MeshRenderer ren = go.GetComponent<MeshRenderer>();
if (ren != null)
ren.material = m;
}
}
}
// use for fading, etc
public virtual void SetAllGOAlphaMultiply(float fT)
{
foreach (var go in vObjects)
go.SetAlphaMultiply(fT);
}
public virtual void SetAllGOLayer(int nLayer)
{
foreach (var go in vObjects)
go.SetLayer(nLayer);
}
public virtual bool FindGORayIntersection (Ray ray, out GameObjectRayHit hit, Func<GameObject, bool> FilterF = null)
{
hit = new GameObjectRayHit();
RaycastHit hitInfo;
// [RMS] this keeps popping up...why??
//if (Mathf.Abs(ray.direction.sqrMagnitude - 1.0f) > 0.001) {
// DebugUtil.Log(2, "FindGORayIntersection: ray direction is not normalized! {0} {1}", ray.direction, ray.direction.magnitude);
// return false;
//}
foreach (var go in vObjects) {
if ( FilterF != null && FilterF(go) == false)
continue;
if (go.IsVisible() == false)
continue;
Collider collider = go.GetComponent<Collider>();
if (collider) {
go.EnableCollider();
if (collider.Raycast(ray, out hitInfo, Mathf.Infinity)) {
if (hitInfo.distance < hit.fHitDist) {
hit.fHitDist = hitInfo.distance;
hit.hitPos = hitInfo.point;
hit.hitNormal = hitInfo.normal;
hit.hitGO = go;
}
}
go.DisableCollider();
}
}
return (hit.hitGO != null);
}
public virtual bool IsGOHit(Ray ray, GameObject go) {
if (go.IsVisible() == false)
return false;
bool bHit = false;
RaycastHit hitInfo;
MeshCollider collider = go.GetComponent<MeshCollider>();
if (collider) {
go.EnableCollider();
if (collider.Raycast(ray, out hitInfo, Mathf.Infinity))
bHit = true;
go.DisableCollider();
}
return bHit;
}
public virtual GameObject FindHitGO(Ray ray)
{
foreach ( GameObject go in vObjects ) {
if (IsGOHit(ray, go))
return go;
}
return null;
}
}
}