本文整理匯總了C#中UnityEngine.Renderer.GetComponent方法的典型用法代碼示例。如果您正苦於以下問題:C# Renderer.GetComponent方法的具體用法?C# Renderer.GetComponent怎麽用?C# Renderer.GetComponent使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類UnityEngine.Renderer
的用法示例。
在下文中一共展示了Renderer.GetComponent方法的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: RemoveRenderer
public void RemoveRenderer(Renderer rend) {
if(AffectedRenderers.Contains(rend)) {
AffectedRenderers.Remove(rend);
mset.SkyAnchor anchor = rend.GetComponent<mset.SkyAnchor>();
if(anchor && anchor.CurrentApplicator == this) anchor.CurrentApplicator = null;
}
}
示例2: AddRenderer
public void AddRenderer(Renderer rend) {
mset.SkyAnchor anchor = rend.GetComponent<mset.SkyAnchor>();
if(anchor != null) {
if(anchor.CurrentApplicator != null) anchor.CurrentApplicator.RemoveRenderer(rend);
anchor.CurrentApplicator = this;
}
AffectedRenderers.Add(rend);
}
示例3: DrawHierachy
private void DrawHierachy(TreeData treeData, Renderer renderer, Rect sizeRect)
{
if (styles == null)
{
styles = new Styles();
}
this.hierachySpread = this.hierachyNodeSize + this.hierachyNodeSpace;
this.hierachyView = sizeRect;
Event event2 = new Event(Event.current);
List<HierachyNode> nodes = new List<HierachyNode>();
this.BuildHierachyNodes(treeData, nodes, treeData.root, 0);
this.LayoutHierachyNodes(nodes, sizeRect);
float num = 16f;
Vector2 zero = Vector2.zero;
if (sizeRect.width < this.hierachyRect.width)
{
zero.y -= 16f;
}
bool changed = GUI.changed;
this.hierachyDisplayRect = GUILayoutUtility.GetRect(sizeRect.width, this.hierachyRect.height + num);
this.hierachyDisplayRect.width = sizeRect.width;
GUI.Box(this.hierachyDisplayRect, GUIContent.none, styles.nodeBackground);
this.hierachyScroll = GUI.BeginScrollView(this.hierachyDisplayRect, this.hierachyScroll, this.hierachyRect, false, false);
GUI.changed = changed;
this.HandleDragHierachyNodes(treeData, nodes);
this.DrawHierachyNodes(treeData, nodes, treeData.root, (Vector2) (zero / 2f), 1f, 1f);
if ((this.dragNode != null) && this.isDragging)
{
Vector2 vector2 = Event.current.mousePosition - this.dragClickPos;
this.DrawHierachyNodes(treeData, nodes, this.dragNode.group, vector2 + ((Vector2) (zero / 2f)), 0.5f, 0.5f);
}
GUI.EndScrollView();
MeshFilter component = renderer.GetComponent<MeshFilter>();
if (((component != null) && (component.sharedMesh != null)) && (renderer != null))
{
int length = component.sharedMesh.vertices.Length;
int num3 = component.sharedMesh.triangles.Length / 3;
int num4 = renderer.sharedMaterials.Length;
Rect position = new Rect((this.hierachyDisplayRect.xMax - 80f) - 4f, ((this.hierachyDisplayRect.yMax + zero.y) - 40f) - 4f, 80f, 40f);
string text = TreeEditorHelper.GetGUIContent("Hierachy Stats").text.Replace("[v]", length.ToString()).Replace("[t]", num3.ToString()).Replace("[m]", num4.ToString()).Replace(" / ", "\n");
GUI.Label(position, text, EditorStyles.helpBox);
}
if ((event2.type == EventType.ScrollWheel) && (Event.current.type == EventType.Used))
{
Event.current = event2;
}
}
示例4: HasNormals
private static bool HasNormals(Renderer renderer)
{
Mesh mesh = (Mesh) null;
if (renderer is MeshRenderer)
{
MeshFilter component = renderer.GetComponent<MeshFilter>();
if ((UnityEngine.Object) component != (UnityEngine.Object) null)
mesh = component.sharedMesh;
}
else if (renderer is SkinnedMeshRenderer)
mesh = (renderer as SkinnedMeshRenderer).sharedMesh;
return InternalMeshUtil.HasNormals(mesh);
}
示例5: ApplyCorrectSky
public void ApplyCorrectSky(Renderer rend) {
//filter by ignored layers
bool localCube = false;
//if the anchor is a direct link to a sky, ignore applicators all together
mset.SkyAnchor anchor = rend.GetComponent<SkyAnchor>();
if(anchor && anchor.BindType == SkyAnchor.AnchorBindType.TargetSky) {
anchor.Apply();
localCube = true;
}
//look for localized applicators to bind this renderer to
foreach(mset.SkyApplicator app in skyApplicators) {
if(localCube) app.RemoveRenderer(rend);
else if(app.RendererInside(rend)) localCube = true;
}
//no local applicator found, but we have a global sky
if(!localCube && _GlobalSky != null) {
if(anchor != null) {
if(anchor.CurrentApplicator != null) {
anchor.CurrentApplicator.RemoveRenderer(rend);
anchor.CurrentApplicator = null;
}
//start last blend to global sky and tell the anchor it's gone global
anchor.BlendToGlobalSky(_GlobalSky);
} else {
//HACK: no applying to renderers outside of a sky anchor! it leaks memory.
//_GlobalSky.Apply(rend,0);
}
if(!globalSkyChildren.Contains(rend)) globalSkyChildren.Add(rend);
}
//if a local cube was found or there is no global sky, remove rend
if(localCube || _GlobalSky == null) {
if(globalSkyChildren.Contains(rend)) {
globalSkyChildren.Remove(rend);
}
}
}
示例6: RegisterNewRenderer
public void RegisterNewRenderer(Renderer rend) {
//filter by active
if(!rend.gameObject.activeInHierarchy) return;
//filter by ignored layers
int layerFlag = 1 << rend.gameObject.layer;
if((IgnoredLayerMask & layerFlag) != 0) return;
//sort by static/dynamic
if(rend.gameObject.isStatic) {
if(!staticRenderers.Contains(rend)) {
staticRenderers.Add(rend);
ApplyCorrectSky(rend);
}
} else if(!dynamicRenderers.Contains(rend)) {
dynamicRenderers.Add(rend);
if(rend.GetComponent<mset.SkyAnchor>() == null) {
rend.gameObject.AddComponent(typeof(mset.SkyAnchor));
}
}
}
示例7: HasNormals
private static bool HasNormals(Renderer renderer)
{
Mesh sharedMesh = null;
if (renderer is MeshRenderer)
{
MeshFilter component = renderer.GetComponent<MeshFilter>();
if (component != null)
{
sharedMesh = component.sharedMesh;
}
}
else if (renderer is SkinnedMeshRenderer)
{
sharedMesh = (renderer as SkinnedMeshRenderer).sharedMesh;
}
return InternalMeshUtil.HasNormals(sharedMesh);
}