| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172 | /*********************************************************************************************   raylib [models] example - rlgl module usage with push/pop matrix transformations**   This example uses [rlgl] module funtionality (pseudo-OpenGL 1.1 style coding)**   This example has been created using raylib 2.5 (www.raylib.com)*   raylib is licensed under an unmodified zlib/libpng license (View raylib.h for details)**   Copyright (c) 2018 Ramon Santamaria (@raysan5)*********************************************************************************************/#include "raylib.h"#include "rlgl.h"//------------------------------------------------------------------------------------// Module Functions Declaration//------------------------------------------------------------------------------------void DrawSphereBasic(Color color);      // Draw sphere without any matrix transformation//------------------------------------------------------------------------------------// Program main entry point//------------------------------------------------------------------------------------int main(void){    // Initialization    //--------------------------------------------------------------------------------------    const int screenWidth = 800;    const int screenHeight = 450;    const float sunRadius = 4.0f;    const float earthRadius = 0.6f;    const float earthOrbitRadius = 8.0f;    const float moonRadius = 0.16f;    const float moonOrbitRadius = 1.5f;    InitWindow(screenWidth, screenHeight, "raylib [models] example - rlgl module usage with push/pop matrix transformations");    // Define the camera to look into our 3d world    Camera camera = { 0 };    camera.position = (Vector3){ 16.0f, 16.0f, 16.0f };    camera.target = (Vector3){ 0.0f, 0.0f, 0.0f };    camera.up = (Vector3){ 0.0f, 1.0f, 0.0f };    camera.fovy = 45.0f;    camera.projection = CAMERA_PERSPECTIVE;    SetCameraMode(camera, CAMERA_FREE);    float rotationSpeed = 0.2f;         // General system rotation speed    float earthRotation = 0.0f;         // Rotation of earth around itself (days) in degrees    float earthOrbitRotation = 0.0f;    // Rotation of earth around the Sun (years) in degrees    float moonRotation = 0.0f;          // Rotation of moon around itself    float moonOrbitRotation = 0.0f;     // Rotation of moon around earth in degrees    SetTargetFPS(60);                   // Set our game to run at 60 frames-per-second    //--------------------------------------------------------------------------------------    // Main game loop    while (!WindowShouldClose())        // Detect window close button or ESC key    {        // Update        //----------------------------------------------------------------------------------        UpdateCamera(&camera);        earthRotation += (5.0f*rotationSpeed);        earthOrbitRotation += (365/360.0f*(5.0f*rotationSpeed)*rotationSpeed);        moonRotation += (2.0f*rotationSpeed);        moonOrbitRotation += (8.0f*rotationSpeed);        //----------------------------------------------------------------------------------        // Draw        //----------------------------------------------------------------------------------        BeginDrawing();            ClearBackground(RAYWHITE);            BeginMode3D(camera);                rlPushMatrix();                    rlScalef(sunRadius, sunRadius, sunRadius);          // Scale Sun                    DrawSphereBasic(GOLD);                              // Draw the Sun                rlPopMatrix();                rlPushMatrix();                    rlRotatef(earthOrbitRotation, 0.0f, 1.0f, 0.0f);    // Rotation for Earth orbit around Sun                    rlTranslatef(earthOrbitRadius, 0.0f, 0.0f);         // Translation for Earth orbit                    rlRotatef(-earthOrbitRotation, 0.0f, 1.0f, 0.0f);   // Rotation for Earth orbit around Sun inverted                    rlPushMatrix();                        rlRotatef(earthRotation, 0.25, 1.0, 0.0);       // Rotation for Earth itself                        rlScalef(earthRadius, earthRadius, earthRadius);// Scale Earth                        DrawSphereBasic(BLUE);                          // Draw the Earth                    rlPopMatrix();                    rlRotatef(moonOrbitRotation, 0.0f, 1.0f, 0.0f);     // Rotation for Moon orbit around Earth                    rlTranslatef(moonOrbitRadius, 0.0f, 0.0f);          // Translation for Moon orbit                    rlRotatef(-moonOrbitRotation, 0.0f, 1.0f, 0.0f);    // Rotation for Moon orbit around Earth inverted                    rlRotatef(moonRotation, 0.0f, 1.0f, 0.0f);          // Rotation for Moon itself                    rlScalef(moonRadius, moonRadius, moonRadius);       // Scale Moon                    DrawSphereBasic(LIGHTGRAY);                         // Draw the Moon                rlPopMatrix();                // Some reference elements (not affected by previous matrix transformations)                DrawCircle3D((Vector3){ 0.0f, 0.0f, 0.0f }, earthOrbitRadius, (Vector3){ 1, 0, 0 }, 90.0f, Fade(RED, 0.5f));                DrawGrid(20, 1.0f);            EndMode3D();            DrawText("EARTH ORBITING AROUND THE SUN!", 400, 10, 20, MAROON);            DrawFPS(10, 10);        EndDrawing();        //----------------------------------------------------------------------------------    }    // De-Initialization    //--------------------------------------------------------------------------------------    CloseWindow();        // Close window and OpenGL context    //--------------------------------------------------------------------------------------    return 0;}//--------------------------------------------------------------------------------------------// Module Functions Definitions (local)//--------------------------------------------------------------------------------------------// Draw sphere without any matrix transformation// NOTE: Sphere is drawn in world position ( 0, 0, 0 ) with radius 1.0fvoid DrawSphereBasic(Color color){    int rings = 16;    int slices = 16;        // Make sure there is enough space in the internal render batch    // buffer to store all required vertex, batch is reseted if required    rlCheckRenderBatchLimit((rings + 2)*slices*6);    rlBegin(RL_TRIANGLES);        rlColor4ub(color.r, color.g, color.b, color.a);        for (int i = 0; i < (rings + 2); i++)        {            for (int j = 0; j < slices; j++)            {                rlVertex3f(cosf(DEG2RAD*(270+(180/(rings + 1))*i))*sinf(DEG2RAD*(j*360/slices)),                           sinf(DEG2RAD*(270+(180/(rings + 1))*i)),                           cosf(DEG2RAD*(270+(180/(rings + 1))*i))*cosf(DEG2RAD*(j*360/slices)));                rlVertex3f(cosf(DEG2RAD*(270+(180/(rings + 1))*(i+1)))*sinf(DEG2RAD*((j+1)*360/slices)),                           sinf(DEG2RAD*(270+(180/(rings + 1))*(i+1))),                           cosf(DEG2RAD*(270+(180/(rings + 1))*(i+1)))*cosf(DEG2RAD*((j+1)*360/slices)));                rlVertex3f(cosf(DEG2RAD*(270+(180/(rings + 1))*(i+1)))*sinf(DEG2RAD*(j*360/slices)),                           sinf(DEG2RAD*(270+(180/(rings + 1))*(i+1))),                           cosf(DEG2RAD*(270+(180/(rings + 1))*(i+1)))*cosf(DEG2RAD*(j*360/slices)));                rlVertex3f(cosf(DEG2RAD*(270+(180/(rings + 1))*i))*sinf(DEG2RAD*(j*360/slices)),                           sinf(DEG2RAD*(270+(180/(rings + 1))*i)),                           cosf(DEG2RAD*(270+(180/(rings + 1))*i))*cosf(DEG2RAD*(j*360/slices)));                rlVertex3f(cosf(DEG2RAD*(270+(180/(rings + 1))*(i)))*sinf(DEG2RAD*((j+1)*360/slices)),                           sinf(DEG2RAD*(270+(180/(rings + 1))*(i))),                           cosf(DEG2RAD*(270+(180/(rings + 1))*(i)))*cosf(DEG2RAD*((j+1)*360/slices)));                rlVertex3f(cosf(DEG2RAD*(270+(180/(rings + 1))*(i+1)))*sinf(DEG2RAD*((j+1)*360/slices)),                           sinf(DEG2RAD*(270+(180/(rings + 1))*(i+1))),                           cosf(DEG2RAD*(270+(180/(rings + 1))*(i+1)))*cosf(DEG2RAD*((j+1)*360/slices)));            }        }    rlEnd();}
 |