diff options
| author | raysan5 <[email protected]> | 2020-06-07 11:49:24 +0200 |
|---|---|---|
| committer | raysan5 <[email protected]> | 2020-06-07 11:49:24 +0200 |
| commit | 992fefa823809aa4dff0170d3dcd3930a2cce52a (patch) | |
| tree | d86b64fe65e608c82a4821fc261b31c1d6218de0 /src | |
| parent | 0fda4b11839a67ad9c98de709cfc87a99dcbf1d7 (diff) | |
| parent | e07512e213a498a2987cf2347997d17a46433956 (diff) | |
| download | raylib-992fefa823809aa4dff0170d3dcd3930a2cce52a.tar.gz raylib-992fefa823809aa4dff0170d3dcd3930a2cce52a.zip | |
Merge branch 'master' of https://github.com/raysan5/raylib
Diffstat (limited to 'src')
| -rw-r--r-- | src/models.c | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/src/models.c b/src/models.c index 22809f89..d5a67c08 100644 --- a/src/models.c +++ b/src/models.c @@ -1273,15 +1273,21 @@ Mesh GenMeshPoly(int sides, float radius) { Mesh mesh = { 0 }; mesh.vboId = (unsigned int *)RL_CALLOC(DEFAULT_MESH_VERTEX_BUFFERS, sizeof(unsigned int)); + + if (sides < 3) return mesh; + int vertexCount = sides*3; // Vertices definition Vector3 *vertices = (Vector3 *)RL_MALLOC(vertexCount*sizeof(Vector3)); - for (int i = 0, v = 0; i < 360; i += 360/sides, v += 3) + + float d = 0.0f, dStep = 360.0f/sides; + for (int v = 0; v < vertexCount; v += 3) { vertices[v] = (Vector3){ 0.0f, 0.0f, 0.0f }; - vertices[v + 1] = (Vector3){ sinf(DEG2RAD*i)*radius, 0.0f, cosf(DEG2RAD*i)*radius }; - vertices[v + 2] = (Vector3){ sinf(DEG2RAD*(i + 360/sides))*radius, 0.0f, cosf(DEG2RAD*(i + 360/sides))*radius }; + vertices[v + 1] = (Vector3){ sinf(DEG2RAD*d)*radius, 0.0f, cosf(DEG2RAD*d)*radius }; + vertices[v + 2] = (Vector3){sinf(DEG2RAD*(d+dStep)) * radius, 0.0f, cosf(DEG2RAD * (d+dStep)) * radius }; + d += dStep; } // Normals definition |
