Last active
January 29, 2024 12:41
-
-
Save josephbk117/123be8038f266601b8798170f42e1193 to your computer and use it in GitHub Desktop.
Code for generating 2d surfaces like in Alto's Adventure
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/*Please do support www.bitshiftprogrammer.com by joining the facebook page : fb.com/BitshiftProgrammer | |
Legal Stuff: | |
This code is free to use no restrictions but attribution would be appreciated. | |
Any damage caused either partly or completly due to usage of this stuff is not my responsibility*/ | |
using UnityEngine; | |
public class SurfaceGenerator : MonoBehaviour | |
{ | |
public bool generateContinuously = false; | |
public bool generateCollider = false; | |
[Range(0.1f,50.0f)] | |
public float yScaling = 5.0f; | |
[Range(0.1f,20.0f)] | |
public float detailScaling = 1.0f; | |
[HideInInspector] | |
public Vector3[] vertices; | |
private Mesh mesh; | |
void Start() | |
{ | |
mesh = GetComponent<MeshFilter>().mesh; | |
vertices = mesh.vertices; | |
} | |
void Update() | |
{ | |
GenerateSurface(); | |
} | |
void GenerateSurface() | |
{ | |
vertices = mesh.vertices; | |
int counter = 0; | |
for (int i = 0; i < 11; i++) | |
{ | |
for (int j = 0; j < 11; j++) | |
{ | |
MeshCalculate(counter, i); | |
counter++; | |
} | |
} | |
mesh.vertices = vertices; | |
mesh.RecalculateBounds(); | |
mesh.RecalculateNormals(); | |
if (generateCollider) | |
{ | |
Destroy(GetComponent<MeshCollider>()); | |
MeshCollider collider = gameObject.AddComponent<MeshCollider>(); | |
collider.sharedMesh = null; | |
collider.sharedMesh = mesh; | |
} | |
} | |
void MeshCalculate(int vertexIndex, int yOffset) | |
{ | |
if (generateContinuously) | |
{ | |
vertices[vertexIndex].z = Mathf.PerlinNoise | |
(Time.time + (vertices[vertexIndex].x + transform.position.x) / detailScaling, | |
Time.time + (vertices[vertexIndex].y + transform.position.y)) * yScaling; | |
vertices[vertexIndex].z -= yOffset; | |
} | |
else | |
{ | |
vertices[vertexIndex].z = Mathf.PerlinNoise | |
((vertices[vertexIndex].x + transform.position.x) / detailScaling, | |
(vertices[vertexIndex].y + transform.position.y)) * yScaling; | |
vertices[vertexIndex].z -= yOffset; | |
} | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment