Initial Check-int 5.2
Resolved forced script errors due to change from UIVertex to Mesh **ToDo Updated FILLVBO updates to PopulateMesh --HG-- branch : develop_5.2release
parent
a6b6d4793b
commit
79d8969f83
|
@ -17,13 +17,19 @@ namespace UnityEngine.UI.Extensions
|
||||||
//
|
//
|
||||||
// Methods
|
// Methods
|
||||||
//
|
//
|
||||||
public override void ModifyVertices (List<UIVertex> verts)
|
public override void ModifyMesh (Mesh mesh)
|
||||||
{
|
{
|
||||||
if (!this.IsActive ())
|
if (!this.IsActive ())
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
List<UIVertex> verts = new List<UIVertex>();
|
||||||
|
using (var helper = new VertexHelper(mesh))
|
||||||
|
{
|
||||||
|
helper.GetUIVertexStream(verts);
|
||||||
|
}
|
||||||
|
|
||||||
Text foundtext = GetComponent<Text>();
|
Text foundtext = GetComponent<Text>();
|
||||||
|
|
||||||
float best_fit_adjustment = 1f;
|
float best_fit_adjustment = 1f;
|
||||||
|
@ -35,16 +41,22 @@ namespace UnityEngine.UI.Extensions
|
||||||
|
|
||||||
int start = 0;
|
int start = 0;
|
||||||
int count = verts.Count;
|
int count = verts.Count;
|
||||||
base.ApplyShadow (verts, base.effectColor, start, verts.Count, base.effectDistance.x*best_fit_adjustment, base.effectDistance.y*best_fit_adjustment);
|
base.ApplyShadowZeroAlloc(verts, base.effectColor, start, verts.Count, base.effectDistance.x*best_fit_adjustment, base.effectDistance.y*best_fit_adjustment);
|
||||||
start = count;
|
start = count;
|
||||||
count = verts.Count;
|
count = verts.Count;
|
||||||
base.ApplyShadow (verts, base.effectColor, start, verts.Count, base.effectDistance.x*best_fit_adjustment, -base.effectDistance.y*best_fit_adjustment);
|
base.ApplyShadowZeroAlloc(verts, base.effectColor, start, verts.Count, base.effectDistance.x*best_fit_adjustment, -base.effectDistance.y*best_fit_adjustment);
|
||||||
start = count;
|
start = count;
|
||||||
count = verts.Count;
|
count = verts.Count;
|
||||||
base.ApplyShadow (verts, base.effectColor, start, verts.Count, -base.effectDistance.x*best_fit_adjustment, base.effectDistance.y*best_fit_adjustment);
|
base.ApplyShadowZeroAlloc(verts, base.effectColor, start, verts.Count, -base.effectDistance.x*best_fit_adjustment, base.effectDistance.y*best_fit_adjustment);
|
||||||
start = count;
|
start = count;
|
||||||
count = verts.Count;
|
count = verts.Count;
|
||||||
base.ApplyShadow (verts, base.effectColor, start, verts.Count, -base.effectDistance.x*best_fit_adjustment, -base.effectDistance.y*best_fit_adjustment);
|
base.ApplyShadowZeroAlloc(verts, base.effectColor, start, verts.Count, -base.effectDistance.x*best_fit_adjustment, -base.effectDistance.y*best_fit_adjustment);
|
||||||
|
|
||||||
|
using (var helper = new VertexHelper())
|
||||||
|
{
|
||||||
|
helper.AddUIVertexTriangleStream(verts);
|
||||||
|
helper.FillMesh(mesh);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,7 @@ namespace UnityEngine.UI.Extensions
|
||||||
{
|
{
|
||||||
[RequireComponent(typeof(Text), typeof(RectTransform))]
|
[RequireComponent(typeof(Text), typeof(RectTransform))]
|
||||||
[AddComponentMenu("UI/Effects/Extensions/Curved Text")]
|
[AddComponentMenu("UI/Effects/Extensions/Curved Text")]
|
||||||
public class CurvedText : BaseVertexEffect
|
public class CurvedText : BaseMeshEffect
|
||||||
{
|
{
|
||||||
public AnimationCurve curveForText = AnimationCurve.Linear(0, 0, 1, 10);
|
public AnimationCurve curveForText = AnimationCurve.Linear(0, 0, 1, 10);
|
||||||
public float curveMultiplier = 1;
|
public float curveMultiplier = 1;
|
||||||
|
@ -40,18 +40,19 @@ namespace UnityEngine.UI.Extensions
|
||||||
rectTrans = GetComponent<RectTransform>();
|
rectTrans = GetComponent<RectTransform>();
|
||||||
OnRectTransformDimensionsChange();
|
OnRectTransformDimensionsChange();
|
||||||
}
|
}
|
||||||
public override void ModifyVertices(System.Collections.Generic.List<UIVertex> verts)
|
public override void ModifyMesh(Mesh mesh)
|
||||||
{
|
{
|
||||||
if (!IsActive())
|
if (!IsActive())
|
||||||
return;
|
return;
|
||||||
|
Vector3[] verts = mesh.vertices;
|
||||||
for (int index = 0; index < verts.Count; index++)
|
for (int index = 0; index < verts.Length; index++)
|
||||||
{
|
{
|
||||||
var uiVertex = verts[index];
|
var uiVertex = verts[index];
|
||||||
//Debug.Log ();
|
//Debug.Log ();
|
||||||
uiVertex.position.y += curveForText.Evaluate(rectTrans.rect.width * rectTrans.pivot.x + uiVertex.position.x) * curveMultiplier;
|
uiVertex.y += curveForText.Evaluate(rectTrans.rect.width * rectTrans.pivot.x + uiVertex.x) * curveMultiplier;
|
||||||
verts[index] = uiVertex;
|
verts[index] = uiVertex;
|
||||||
}
|
}
|
||||||
|
mesh.vertices = verts;
|
||||||
}
|
}
|
||||||
protected override void OnRectTransformDimensionsChange()
|
protected override void OnRectTransformDimensionsChange()
|
||||||
{
|
{
|
||||||
|
|
|
@ -6,7 +6,7 @@ using System.Collections.Generic;
|
||||||
namespace UnityEngine.UI.Extensions
|
namespace UnityEngine.UI.Extensions
|
||||||
{
|
{
|
||||||
[AddComponentMenu("UI/Effects/Extensions/Gradient")]
|
[AddComponentMenu("UI/Effects/Extensions/Gradient")]
|
||||||
public class Gradient : BaseVertexEffect
|
public class Gradient : BaseMeshEffect
|
||||||
{
|
{
|
||||||
public GradientMode gradientMode = GradientMode.Global;
|
public GradientMode gradientMode = GradientMode.Global;
|
||||||
public GradientDir gradientDir = GradientDir.Vertical;
|
public GradientDir gradientDir = GradientDir.Vertical;
|
||||||
|
@ -20,14 +20,18 @@ namespace UnityEngine.UI.Extensions
|
||||||
targetGraphic = GetComponent<Graphic>();
|
targetGraphic = GetComponent<Graphic>();
|
||||||
}
|
}
|
||||||
|
|
||||||
public override void ModifyVertices(List<UIVertex> vertexList)
|
public override void ModifyMesh(Mesh mesh)
|
||||||
{
|
{
|
||||||
if (!IsActive() || vertexList.Count == 0)
|
if (!IsActive() || mesh.vertexCount == 0)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
int count = vertexList.Count;
|
|
||||||
UIVertex uiVertex = vertexList[0];
|
Vector3[] vertexList = mesh.vertices;
|
||||||
|
Color[] vertexListColors = mesh.colors;
|
||||||
|
int count = mesh.vertexCount;
|
||||||
|
Vector3 uiVertex = vertexList[0];
|
||||||
|
Color uiVertexColor = vertexListColors[0];
|
||||||
if (gradientMode == GradientMode.Global)
|
if (gradientMode == GradientMode.Global)
|
||||||
{
|
{
|
||||||
if (gradientDir == GradientDir.DiagonalLeftToRight || gradientDir == GradientDir.DiagonalRightToLeft)
|
if (gradientDir == GradientDir.DiagonalLeftToRight || gradientDir == GradientDir.DiagonalRightToLeft)
|
||||||
|
@ -37,18 +41,19 @@ namespace UnityEngine.UI.Extensions
|
||||||
#endif
|
#endif
|
||||||
gradientDir = GradientDir.Vertical;
|
gradientDir = GradientDir.Vertical;
|
||||||
}
|
}
|
||||||
float bottomY = gradientDir == GradientDir.Vertical ? vertexList[vertexList.Count - 1].position.y : vertexList[vertexList.Count - 1].position.x;
|
float bottomY = gradientDir == GradientDir.Vertical ? vertexList[vertexList.Length - 1].y : vertexList[vertexList.Length - 1].x;
|
||||||
float topY = gradientDir == GradientDir.Vertical ? vertexList[0].position.y : vertexList[0].position.x;
|
float topY = gradientDir == GradientDir.Vertical ? vertexList[0].y : vertexList[0].x;
|
||||||
|
|
||||||
float uiElementHeight = topY - bottomY;
|
float uiElementHeight = topY - bottomY;
|
||||||
|
|
||||||
for (int i = 0; i < count; i++)
|
for (int i = 0; i < count; i++)
|
||||||
{
|
{
|
||||||
uiVertex = vertexList[i];
|
uiVertex = vertexList[i];
|
||||||
if (!overwriteAllColor && uiVertex.color != targetGraphic.color)
|
uiVertexColor = vertexListColors[i];
|
||||||
|
if (!overwriteAllColor && uiVertexColor != targetGraphic.color)
|
||||||
continue;
|
continue;
|
||||||
uiVertex.color *= Color.Lerp(vertex2, vertex1, ((gradientDir == GradientDir.Vertical ? uiVertex.position.y : uiVertex.position.x) - bottomY) / uiElementHeight);
|
uiVertexColor *= Color.Lerp(vertex2, vertex1, ((gradientDir == GradientDir.Vertical ? uiVertex.y : uiVertex.x) - bottomY) / uiElementHeight);
|
||||||
vertexList[i] = uiVertex;
|
vertexListColors[i] = uiVertexColor;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -56,27 +61,29 @@ namespace UnityEngine.UI.Extensions
|
||||||
for (int i = 0; i < count; i++)
|
for (int i = 0; i < count; i++)
|
||||||
{
|
{
|
||||||
uiVertex = vertexList[i];
|
uiVertex = vertexList[i];
|
||||||
if (!overwriteAllColor && !CompareCarefully(uiVertex.color, targetGraphic.color))
|
uiVertexColor = vertexListColors[i];
|
||||||
|
if (!overwriteAllColor && !CompareCarefully(uiVertexColor, targetGraphic.color))
|
||||||
continue;
|
continue;
|
||||||
switch (gradientDir)
|
switch (gradientDir)
|
||||||
{
|
{
|
||||||
case GradientDir.Vertical:
|
case GradientDir.Vertical:
|
||||||
uiVertex.color *= (i % 4 == 0 || (i - 1) % 4 == 0) ? vertex1 : vertex2;
|
uiVertexColor *= (i % 4 == 0 || (i - 1) % 4 == 0) ? vertex1 : vertex2;
|
||||||
break;
|
break;
|
||||||
case GradientDir.Horizontal:
|
case GradientDir.Horizontal:
|
||||||
uiVertex.color *= (i % 4 == 0 || (i - 3) % 4 == 0) ? vertex1 : vertex2;
|
uiVertexColor *= (i % 4 == 0 || (i - 3) % 4 == 0) ? vertex1 : vertex2;
|
||||||
break;
|
break;
|
||||||
case GradientDir.DiagonalLeftToRight:
|
case GradientDir.DiagonalLeftToRight:
|
||||||
uiVertex.color *= (i % 4 == 0) ? vertex1 : ((i - 2) % 4 == 0 ? vertex2 : Color.Lerp(vertex2, vertex1, 0.5f));
|
uiVertexColor *= (i % 4 == 0) ? vertex1 : ((i - 2) % 4 == 0 ? vertex2 : Color.Lerp(vertex2, vertex1, 0.5f));
|
||||||
break;
|
break;
|
||||||
case GradientDir.DiagonalRightToLeft:
|
case GradientDir.DiagonalRightToLeft:
|
||||||
uiVertex.color *= ((i - 1) % 4 == 0) ? vertex1 : ((i - 3) % 4 == 0 ? vertex2 : Color.Lerp(vertex2, vertex1, 0.5f));
|
uiVertexColor *= ((i - 1) % 4 == 0) ? vertex1 : ((i - 3) % 4 == 0 ? vertex2 : Color.Lerp(vertex2, vertex1, 0.5f));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
}
|
}
|
||||||
vertexList[i] = uiVertex;
|
vertexListColors[i] = uiVertexColor;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
mesh.colors = vertexListColors;
|
||||||
}
|
}
|
||||||
private bool CompareCarefully(Color col1, Color col2)
|
private bool CompareCarefully(Color col1, Color col2)
|
||||||
{
|
{
|
||||||
|
|
|
@ -46,7 +46,7 @@ using System.Collections.Generic;
|
||||||
namespace UnityEngine.UI.Extensions
|
namespace UnityEngine.UI.Extensions
|
||||||
{
|
{
|
||||||
[AddComponentMenu("UI/Effects/Extensions/Letter Spacing")]
|
[AddComponentMenu("UI/Effects/Extensions/Letter Spacing")]
|
||||||
public class LetterSpacing : BaseVertexEffect
|
public class LetterSpacing : BaseMeshEffect
|
||||||
{
|
{
|
||||||
[SerializeField]
|
[SerializeField]
|
||||||
private float m_spacing = 0f;
|
private float m_spacing = 0f;
|
||||||
|
@ -72,10 +72,12 @@ namespace UnityEngine.UI.Extensions
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public override void ModifyVertices(List<UIVertex> verts)
|
public override void ModifyMesh(Mesh mesh)
|
||||||
{
|
{
|
||||||
if (! IsActive()) return;
|
if (! IsActive()) return;
|
||||||
|
|
||||||
|
Vector3[] verts = mesh.vertices;
|
||||||
|
|
||||||
Text text = GetComponent<Text>();
|
Text text = GetComponent<Text>();
|
||||||
if (text == null)
|
if (text == null)
|
||||||
{
|
{
|
||||||
|
@ -123,19 +125,19 @@ namespace UnityEngine.UI.Extensions
|
||||||
int idx4 = glyphIdx * 4 + 3;
|
int idx4 = glyphIdx * 4 + 3;
|
||||||
|
|
||||||
// Check for truncated text (doesn't generate verts for all characters)
|
// Check for truncated text (doesn't generate verts for all characters)
|
||||||
if (idx4 > verts.Count - 1) return;
|
if (idx4 > verts.Length - 1) return;
|
||||||
|
|
||||||
UIVertex vert1 = verts[idx1];
|
Vector3 vert1 = verts[idx1];
|
||||||
UIVertex vert2 = verts[idx2];
|
Vector3 vert2 = verts[idx2];
|
||||||
UIVertex vert3 = verts[idx3];
|
Vector3 vert3 = verts[idx3];
|
||||||
UIVertex vert4 = verts[idx4];
|
Vector3 vert4 = verts[idx4];
|
||||||
|
|
||||||
pos = Vector3.right * (letterOffset * charIdx - lineOffset);
|
pos = Vector3.right * (letterOffset * charIdx - lineOffset);
|
||||||
|
|
||||||
vert1.position += pos;
|
vert1 += pos;
|
||||||
vert2.position += pos;
|
vert2 += pos;
|
||||||
vert3.position += pos;
|
vert3 += pos;
|
||||||
vert4.position += pos;
|
vert4 += pos;
|
||||||
|
|
||||||
verts[idx1] = vert1;
|
verts[idx1] = vert1;
|
||||||
verts[idx2] = vert2;
|
verts[idx2] = vert2;
|
||||||
|
@ -148,6 +150,7 @@ namespace UnityEngine.UI.Extensions
|
||||||
// Offset for carriage return character that still generates verts
|
// Offset for carriage return character that still generates verts
|
||||||
glyphIdx++;
|
glyphIdx++;
|
||||||
}
|
}
|
||||||
|
mesh.vertices = verts;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,7 +6,7 @@ namespace UnityEngine.UI.Extensions
|
||||||
{
|
{
|
||||||
//An outline that looks a bit nicer than the default one. It has less "holes" in the outline by drawing more copies of the effect
|
//An outline that looks a bit nicer than the default one. It has less "holes" in the outline by drawing more copies of the effect
|
||||||
[AddComponentMenu("UI/Effects/Extensions/Nicer Outline")]
|
[AddComponentMenu("UI/Effects/Extensions/Nicer Outline")]
|
||||||
public class NicerOutline : BaseVertexEffect
|
public class NicerOutline : BaseMeshEffect
|
||||||
{
|
{
|
||||||
[SerializeField]
|
[SerializeField]
|
||||||
private Color m_EffectColor = new Color (0f, 0f, 0f, 0.5f);
|
private Color m_EffectColor = new Color (0f, 0f, 0f, 0.5f);
|
||||||
|
@ -87,45 +87,52 @@ namespace UnityEngine.UI.Extensions
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void ApplyShadowZeroAlloc(List<UIVertex> verts, Color32 color, int start, int end, float x, float y)
|
||||||
|
{
|
||||||
|
UIVertex vt;
|
||||||
|
|
||||||
|
var neededCpacity = verts.Count * 2;
|
||||||
|
if (verts.Capacity < neededCpacity)
|
||||||
|
verts.Capacity = neededCpacity;
|
||||||
|
|
||||||
|
for (int i = start; i < end; ++i)
|
||||||
|
{
|
||||||
|
vt = verts[i];
|
||||||
|
verts.Add(vt);
|
||||||
|
|
||||||
|
Vector3 v = vt.position;
|
||||||
|
v.x += x;
|
||||||
|
v.y += y;
|
||||||
|
vt.position = v;
|
||||||
|
var newColor = color;
|
||||||
|
if (m_UseGraphicAlpha)
|
||||||
|
newColor.a = (byte)((newColor.a * verts[i].color.a) / 255);
|
||||||
|
vt.color = newColor;
|
||||||
|
verts[i] = vt;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//
|
|
||||||
// Methods
|
|
||||||
//
|
|
||||||
protected void ApplyShadow(List<UIVertex> verts, Color32 color, int start, int end, float x, float y)
|
protected void ApplyShadow(List<UIVertex> verts, Color32 color, int start, int end, float x, float y)
|
||||||
{
|
{
|
||||||
//Debug.Log("verts count: "+verts.Count);
|
var neededCpacity = verts.Count * 2;
|
||||||
int num = verts.Count * 2;
|
if (verts.Capacity < neededCpacity)
|
||||||
if (verts.Capacity < num)
|
verts.Capacity = neededCpacity;
|
||||||
{
|
|
||||||
verts.Capacity = num;
|
|
||||||
}
|
|
||||||
for (int i = start; i < end; i++)
|
|
||||||
{
|
|
||||||
UIVertex uIVertex = verts [i];
|
|
||||||
verts.Add (uIVertex);
|
|
||||||
|
|
||||||
Vector3 position = uIVertex.position;
|
ApplyShadowZeroAlloc(verts, color, start, end, x, y);
|
||||||
//Debug.Log("vertex pos: "+position);
|
|
||||||
position.x += x;
|
|
||||||
position.y += y;
|
|
||||||
uIVertex.position = position;
|
|
||||||
Color32 color2 = color;
|
|
||||||
if (this.m_UseGraphicAlpha)
|
|
||||||
{
|
|
||||||
color2.a = (byte)(color2.a * verts [i].color.a / 255);
|
|
||||||
}
|
|
||||||
uIVertex.color = color2;
|
|
||||||
//uIVertex.color = (Color32)Color.blue;
|
|
||||||
verts [i] = uIVertex;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public override void ModifyVertices (List<UIVertex> verts)
|
|
||||||
|
public override void ModifyMesh (Mesh mesh)
|
||||||
{
|
{
|
||||||
if (!this.IsActive ())
|
if (!this.IsActive ())
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
List < UIVertex > verts = new List<UIVertex>();
|
||||||
|
using (var helper = new VertexHelper(mesh))
|
||||||
|
{
|
||||||
|
helper.GetUIVertexStream(verts);
|
||||||
|
}
|
||||||
|
|
||||||
Text foundtext = GetComponent<Text>();
|
Text foundtext = GetComponent<Text>();
|
||||||
|
|
||||||
|
@ -166,6 +173,12 @@ namespace UnityEngine.UI.Extensions
|
||||||
start = count;
|
start = count;
|
||||||
count = verts.Count;
|
count = verts.Count;
|
||||||
this.ApplyShadow (verts, this.effectColor, start, verts.Count, 0, -distanceY);
|
this.ApplyShadow (verts, this.effectColor, start, verts.Count, 0, -distanceY);
|
||||||
|
|
||||||
|
using (var helper = new VertexHelper())
|
||||||
|
{
|
||||||
|
helper.AddUIVertexTriangleStream(verts);
|
||||||
|
helper.FillMesh(mesh);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#if UNITY_EDITOR
|
#if UNITY_EDITOR
|
||||||
|
|
|
@ -7,7 +7,7 @@ namespace UnityEngine.UI.Extensions
|
||||||
{
|
{
|
||||||
[RequireComponent(typeof(RectTransform), typeof(Graphic)), DisallowMultipleComponent]
|
[RequireComponent(typeof(RectTransform), typeof(Graphic)), DisallowMultipleComponent]
|
||||||
[AddComponentMenu("UI/Effects/Extensions/Flippable")]
|
[AddComponentMenu("UI/Effects/Extensions/Flippable")]
|
||||||
public class UIFlippable : MonoBehaviour, IVertexModifier
|
public class UIFlippable : MonoBehaviour, IMeshModifier
|
||||||
{
|
{
|
||||||
[SerializeField] private bool m_Horizontal = false;
|
[SerializeField] private bool m_Horizontal = false;
|
||||||
[SerializeField] private bool m_Veritical = false;
|
[SerializeField] private bool m_Veritical = false;
|
||||||
|
@ -37,24 +37,27 @@ namespace UnityEngine.UI.Extensions
|
||||||
this.GetComponent<Graphic>().SetVerticesDirty();
|
this.GetComponent<Graphic>().SetVerticesDirty();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void ModifyVertices(List<UIVertex> verts)
|
public void ModifyMesh(Mesh mesh)
|
||||||
{
|
{
|
||||||
|
Vector3[] verts = mesh.vertices;
|
||||||
RectTransform rt = this.transform as RectTransform;
|
RectTransform rt = this.transform as RectTransform;
|
||||||
|
|
||||||
for (int i = 0; i < verts.Count; ++i)
|
for (int i = 0; i < verts.Length; ++i)
|
||||||
{
|
{
|
||||||
UIVertex v = verts[i];
|
Vector3 v = verts[i];
|
||||||
|
|
||||||
// Modify positions
|
// Modify positions
|
||||||
v.position = new Vector3(
|
v = new Vector3(
|
||||||
(this.m_Horizontal ? (v.position.x + (rt.rect.center.x - v.position.x) * 2) : v.position.x),
|
(this.m_Horizontal ? (v.x + (rt.rect.center.x - v.x) * 2) : v.x),
|
||||||
(this.m_Veritical ? (v.position.y + (rt.rect.center.y - v.position.y) * 2) : v.position.y),
|
(this.m_Veritical ? (v.y + (rt.rect.center.y - v.y) * 2) : v.y),
|
||||||
v.position.z
|
v.z
|
||||||
);
|
);
|
||||||
|
|
||||||
// Apply
|
// Apply
|
||||||
verts[i] = v;
|
verts[i] = v;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mesh.vertices = verts;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue