mirror of
				https://github.com/raysan5/raylib.git
				synced 2025-10-22 17:11:45 +00:00 
			
		
		
		
	Review example crashing
Note this example is not working properly, it still requires some review.
This commit is contained in:
		| @@ -52,14 +52,12 @@ int main(void) | |||||||
|  |  | ||||||
|     model.materials[0] = LoadMaterialPBR((Color){ 255, 255, 255, 255 }, 1.0f, 1.0f); |     model.materials[0] = LoadMaterialPBR((Color){ 255, 255, 255, 255 }, 1.0f, 1.0f); | ||||||
|  |  | ||||||
|     // Define lights attributes |     // Create lights | ||||||
|     // NOTE: Shader is passed to every light on creation to define shader bindings internally |     // NOTE: Lights are added to an internal lights pool automatically | ||||||
|     Light lights[MAX_LIGHTS] = { |     CreateLight(LIGHT_POINT, (Vector3){ LIGHT_DISTANCE, LIGHT_HEIGHT, 0.0f }, (Vector3){ 0.0f, 0.0f, 0.0f }, (Color){ 255, 0, 0, 255 }, model.materials[0].shader); | ||||||
|         CreateLight(LIGHT_POINT, (Vector3){ LIGHT_DISTANCE, LIGHT_HEIGHT, 0.0f }, (Vector3){ 0.0f, 0.0f, 0.0f }, (Color){ 255, 0, 0, 255 }, model.materials[0].shader), |     CreateLight(LIGHT_POINT, (Vector3){ 0.0f, LIGHT_HEIGHT, LIGHT_DISTANCE }, (Vector3){ 0.0f, 0.0f, 0.0f }, (Color){ 0, 255, 0, 255 }, model.materials[0].shader); | ||||||
|         CreateLight(LIGHT_POINT, (Vector3){ 0.0f, LIGHT_HEIGHT, LIGHT_DISTANCE }, (Vector3){ 0.0f, 0.0f, 0.0f }, (Color){ 0, 255, 0, 255 }, model.materials[0].shader), |     CreateLight(LIGHT_POINT, (Vector3){ -LIGHT_DISTANCE, LIGHT_HEIGHT, 0.0f }, (Vector3){ 0.0f, 0.0f, 0.0f }, (Color){ 0, 0, 255, 255 }, model.materials[0].shader); | ||||||
|         CreateLight(LIGHT_POINT, (Vector3){ -LIGHT_DISTANCE, LIGHT_HEIGHT, 0.0f }, (Vector3){ 0.0f, 0.0f, 0.0f }, (Color){ 0, 0, 255, 255 }, model.materials[0].shader), |     CreateLight(LIGHT_DIRECTIONAL, (Vector3){ 0.0f, LIGHT_HEIGHT*2.0f, -LIGHT_DISTANCE }, (Vector3){ 0.0f, 0.0f, 0.0f }, (Color){ 255, 0, 255, 255 }, model.materials[0].shader); | ||||||
|         CreateLight(LIGHT_DIRECTIONAL, (Vector3){ 0.0f, LIGHT_HEIGHT*2.0f, -LIGHT_DISTANCE }, (Vector3){ 0.0f, 0.0f, 0.0f }, (Color){ 255, 0, 255, 255 }, model.materials[0].shader) |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     SetCameraMode(camera, CAMERA_ORBITAL);  // Set an orbital camera mode |     SetCameraMode(camera, CAMERA_ORBITAL);  // Set an orbital camera mode | ||||||
|  |  | ||||||
| @@ -113,7 +111,7 @@ int main(void) | |||||||
| // NOTE: PBR shader is loaded inside this function | // NOTE: PBR shader is loaded inside this function | ||||||
| static Material LoadMaterialPBR(Color albedo, float metalness, float roughness) | static Material LoadMaterialPBR(Color albedo, float metalness, float roughness) | ||||||
| { | { | ||||||
|     Material mat = { 0 };       // NOTE: All maps textures are set to { 0 } |     Material mat = LoadMaterialDefault();   // Initialize material to default | ||||||
|  |  | ||||||
| #if defined(PLATFORM_DESKTOP) | #if defined(PLATFORM_DESKTOP) | ||||||
|     mat.shader = LoadShader("resources/shaders/glsl330/pbr.vs", "resources/shaders/glsl330/pbr.fs"); |     mat.shader = LoadShader("resources/shaders/glsl330/pbr.vs", "resources/shaders/glsl330/pbr.fs"); | ||||||
| @@ -136,7 +134,7 @@ static Material LoadMaterialPBR(Color albedo, float metalness, float roughness) | |||||||
|  |  | ||||||
|     // Set view matrix location |     // Set view matrix location | ||||||
|     mat.shader.locs[LOC_MATRIX_MODEL] = GetShaderLocation(mat.shader, "matModel"); |     mat.shader.locs[LOC_MATRIX_MODEL] = GetShaderLocation(mat.shader, "matModel"); | ||||||
|     mat.shader.locs[LOC_MATRIX_VIEW] = GetShaderLocation(mat.shader, "view"); |     //mat.shader.locs[LOC_MATRIX_VIEW] = GetShaderLocation(mat.shader, "view"); | ||||||
|     mat.shader.locs[LOC_VECTOR_VIEW] = GetShaderLocation(mat.shader, "viewPos"); |     mat.shader.locs[LOC_VECTOR_VIEW] = GetShaderLocation(mat.shader, "viewPos"); | ||||||
|  |  | ||||||
|     // Set PBR standard maps |     // Set PBR standard maps | ||||||
|   | |||||||
| @@ -33,6 +33,8 @@ | |||||||
| #ifndef RLIGHTS_H | #ifndef RLIGHTS_H | ||||||
| #define RLIGHTS_H | #define RLIGHTS_H | ||||||
|  |  | ||||||
|  | #include "raylib.h" | ||||||
|  |  | ||||||
| //---------------------------------------------------------------------------------- | //---------------------------------------------------------------------------------- | ||||||
| // Defines and Macros | // Defines and Macros | ||||||
| //---------------------------------------------------------------------------------- | //---------------------------------------------------------------------------------- | ||||||
| @@ -65,15 +67,10 @@ typedef struct { | |||||||
| extern "C" {            // Prevents name mangling of functions | extern "C" {            // Prevents name mangling of functions | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| //---------------------------------------------------------------------------------- |  | ||||||
| // Global Variables Definition |  | ||||||
| //---------------------------------------------------------------------------------- |  | ||||||
| int lightsCount = 0;                     // Current amount of created lights |  | ||||||
|  |  | ||||||
| //---------------------------------------------------------------------------------- | //---------------------------------------------------------------------------------- | ||||||
| // Module Functions Declaration | // Module Functions Declaration | ||||||
| //---------------------------------------------------------------------------------- | //---------------------------------------------------------------------------------- | ||||||
| Light CreateLight(int type, Vector3 pos, Vector3 targ, Color color, Shader shader);         // Defines a light and get locations from PBR shader | void CreateLight(int type, Vector3 pos, Vector3 targ, Color color, Shader shader);         // Defines a light and get locations from PBR shader | ||||||
| void UpdateLightValues(Shader shader, Light light);                                        // Send to PBR shader light values | void UpdateLightValues(Shader shader, Light light);                                        // Send to PBR shader light values | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| @@ -106,7 +103,8 @@ void UpdateLightValues(Shader shader, Light light); | |||||||
| //---------------------------------------------------------------------------------- | //---------------------------------------------------------------------------------- | ||||||
| // Global Variables Definition | // Global Variables Definition | ||||||
| //---------------------------------------------------------------------------------- | //---------------------------------------------------------------------------------- | ||||||
| // ... | static Light lights[MAX_LIGHTS] = { 0 }; | ||||||
|  | static int lightsCount = 0;    // Current amount of created lights | ||||||
|  |  | ||||||
| //---------------------------------------------------------------------------------- | //---------------------------------------------------------------------------------- | ||||||
| // Module specific Functions Declaration | // Module specific Functions Declaration | ||||||
| @@ -118,7 +116,7 @@ void UpdateLightValues(Shader shader, Light light); | |||||||
| //---------------------------------------------------------------------------------- | //---------------------------------------------------------------------------------- | ||||||
|  |  | ||||||
| // Defines a light and get locations from PBR shader | // Defines a light and get locations from PBR shader | ||||||
| Light CreateLight(int type, Vector3 pos, Vector3 targ, Color color, Shader shader) | void CreateLight(int type, Vector3 pos, Vector3 targ, Color color, Shader shader) | ||||||
| { | { | ||||||
|     Light light = { 0 }; |     Light light = { 0 }; | ||||||
|  |  | ||||||
| @@ -148,10 +146,10 @@ Light CreateLight(int type, Vector3 pos, Vector3 targ, Color color, Shader shade | |||||||
|         light.colorLoc = GetShaderLocation(shader, colorName); |         light.colorLoc = GetShaderLocation(shader, colorName); | ||||||
|  |  | ||||||
|         UpdateLightValues(shader, light); |         UpdateLightValues(shader, light); | ||||||
|  |  | ||||||
|  |         lights[lightsCount] = light; | ||||||
|         lightsCount++; |         lightsCount++; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     return light; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // Send to PBR shader light values | // Send to PBR shader light values | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Ray
					Ray