本文整理汇总了C#中TileSet.GetUVForType方法的典型用法代码示例。如果您正苦于以下问题:C# TileSet.GetUVForType方法的具体用法?C# TileSet.GetUVForType怎么用?C# TileSet.GetUVForType使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类TileSet
的用法示例。
在下文中一共展示了TileSet.GetUVForType方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: RPlate
public GameObject RPlate(World world, TileSet tileSet, int i)
{
GameObject output = (GameObject)Instantiate(worldPrefab, Vector3.zero, Quaternion.identity);
MeshFilter myFilter = output.GetComponent<MeshFilter>();
MeshCollider myCollider = output.GetComponent<MeshCollider>();
SerializableVector3 origin = world.origin;
List<Vector3> vertices = new List<Vector3>();
List<int> triangles = new List<int>();
List<Vector3> normals = new List<Vector3>();
List<Vector2> uvs = new List<Vector2>();
//Switch between UV Modes
if (hexagonal) //Hexagonal uvs
{
//Copypasta from worldrenderer
float texHeight = tileSet.texture.height;
float texWidth = tileSet.texture.width;
//float root3 = Mathf.Sqrt(3);
float uvTileWidth = tileSet.tileWidth / texWidth;
float uvTileHeight = tileSet.tileWidth / texHeight;
float side = uvTileWidth / 2;
float radius = Mathf.Sqrt((3 * side * side) / 4);
Vector2 uv0 = new Vector2(side, side),
uv1 = new Vector2(side, side + side),
uv2 = new Vector2(side + radius, side + side / 2),
uv3 = new Vector2(side + radius, side / 2),
uv4 = new Vector2(side, 0),
uv5 = new Vector2(side - radius, side / 2),
uv6 = new Vector2(side - radius, side + side / 2);
//Generate quadrant
foreach (HexTile ht in world.tiles)
{
if (ht.plate == i)
{
IntCoord uvCoord = tileSet.GetUVForType(ht.type);
//Debug.Log("xCoord: "+ uvCoord.x + " type: "+ ht.type);
Vector2 uvOffset = new Vector2(uvCoord.x * uvTileWidth, uvCoord.y * uvTileHeight);
// Origin point
int originIndex = vertices.Count;
vertices.Add(origin);
uvs.Add(uv0 + uvOffset);
normals.Add(ht.hexagon.center - origin);
// Center of hexagon
int centerIndex = vertices.Count;
// Triangle 1
vertices.Add(ht.hexagon.center);
normals.Add((origin + ht.hexagon.center));
uvs.Add(uv1 + uvOffset);
vertices.Add(ht.hexagon.v1);
normals.Add((origin + ht.hexagon.v1));
uvs.Add(uv1 + uvOffset);
vertices.Add(ht.hexagon.v2);
normals.Add((origin + ht.hexagon.v2));
uvs.Add(uv2 + uvOffset);
triangles.Add(centerIndex);
triangles.Add(vertices.Count - 2);
triangles.Add(vertices.Count - 1);
// T2
vertices.Add(ht.hexagon.v3);
normals.Add((origin + ht.hexagon.v3));
uvs.Add(uv3 + uvOffset);
triangles.Add(centerIndex);
triangles.Add(vertices.Count - 2);
triangles.Add(vertices.Count - 1);
// T3
vertices.Add(ht.hexagon.v4);
normals.Add((origin + ht.hexagon.v4));
uvs.Add(uv4 + uvOffset);
triangles.Add(centerIndex);
triangles.Add(vertices.Count - 2);
triangles.Add(vertices.Count - 1);
// T4
vertices.Add(ht.hexagon.v5);
normals.Add((origin + ht.hexagon.v5));
uvs.Add(uv5 + uvOffset);
triangles.Add(centerIndex);
triangles.Add(vertices.Count - 2);
triangles.Add(vertices.Count - 1);
// T5
vertices.Add(ht.hexagon.v6);
normals.Add((origin + ht.hexagon.v6));
uvs.Add(uv6 + uvOffset);
triangles.Add(centerIndex);
//.........这里部分代码省略.........