Procházet zdrojové kódy

Update shaders_deferred_render.c

pull/4714/head
MikiZX1 před 2 měsíci
odevzdal GitHub
rodič
revize
e83e97dc69
V databázi nebyl nalezen žádný známý klíč pro tento podpis ID GPG klíče: B5690EEEBB952194
1 změnil soubory, kde provedl 36 přidání a 23 odebrání
  1. +36
    -23
      examples/shaders/shaders_deferred_render.c

+ 36
- 23
examples/shaders/shaders_deferred_render.c Zobrazit soubor

@ -43,7 +43,7 @@
#include "rlights.h"
#define MAX_CUBES 30
#define MAX_SPHERES 10
// GBuffer data
typedef struct GBuffer {
@ -111,7 +111,7 @@ int main(void)
// Load plane model from a generated mesh
Model model = LoadModelFromMesh(GenMeshPlane(10.0f, 10.0f, 3, 3));
Model cube = LoadModelFromMesh(GenMeshCube(2.0f, 2.0f, 2.0f));
Model sphere = LoadModelFromMesh(GenMeshSphere(1.0f, 10.0f, 10.0f));
// Load geometry buffer (G-buffer) shader and deferred shader
Shader gbufferShader = LoadShader(TextFormat("resources/shaders/glsl%i/gbuffer.vs", GLSL_VERSION),
@ -191,16 +191,22 @@ int main(void)
// Assign out lighting shader to model
model.materials[0].shader = gbufferShader;
cube.materials[0].shader = gbufferShader;
sphere.materials[0].shader = gbufferShader;
// add some specular noise to the material
Image tmp_img2=GenImagePerlinNoise(256,256,0,0,8.0);
Texture texture_specular=LoadTextureFromImage(tmp_img2);
// add some specular detail to the model material
Image tmp_img2=GenImageChecked(256,256,32,32,BLACK,LIGHTGRAY);
unsigned char* pixel=tmp_img2.data;
for (int i=0;i<256*256;i++)
if (pixel[i*4]<128)
pixel[i*4+3]=255;
else
pixel[i*4+3]=50;
Texture texture_albedo_specular=LoadTextureFromImage(tmp_img2);
UnloadImage(tmp_img2);
model.materials[0].maps[MATERIAL_MAP_ALBEDO].texture=texture_albedo_specular;
cube.materials[0].maps[MATERIAL_MAP_METALNESS].texture=texture_specular;
model.materials[0].maps[MATERIAL_MAP_METALNESS].texture=texture_specular;
// Create lights
//--------------------------------------------------------------------------------------
@ -210,25 +216,27 @@ int main(void)
lights[2] = CreateLight(LIGHT_POINT, (Vector3){ -2, 1, 2 }, Vector3Zero(), GREEN, deferredShader);
lights[3] = CreateLight(LIGHT_POINT, (Vector3){ 2, 1, -2 }, Vector3Zero(), BLUE, deferredShader);
const float CUBE_SCALE = 0.25;
Vector3 cubePositions[MAX_CUBES] = { 0 };
float cubeRotations[MAX_CUBES] = { 0 };
Color cubeColors[MAX_CUBES] = { 0 };
const float SPHERE_SCALE = 0.5;
Vector3 spherePositions[MAX_SPHERES] = { 0 };
float sphereRotations[MAX_SPHERES] = { 0 };
Color sphereColors[MAX_SPHERES] = { 0 };
for (int i = 0; i < MAX_CUBES; i++)
for (int i = 0; i < MAX_SPHERES; i++)
{
cubePositions[i] = (Vector3){
spherePositions[i] = (Vector3){
.x = (float)(rand()%10) - 5,
.y = (float)(rand()%5),
.z = (float)(rand()%10) - 5,
};
cubeRotations[i] = (float)(rand()%360);
sphereRotations[i] = (float)(rand()%360);
cubeColors[i] = (Color){GetRandomValue(0,128),GetRandomValue(0,128),GetRandomValue(0,128),255};
sphereColors[i] = (Color){GetRandomValue(0,128),GetRandomValue(0,128),GetRandomValue(0,128),255};
}
float time=0;
DeferredMode mode = DEFERRED_SHADING;
rlEnableDepthTest();
@ -241,6 +249,8 @@ int main(void)
{
// Update
//----------------------------------------------------------------------------------
time-=GetFrameTime()/1.5;
UpdateCamera(&camera, CAMERA_ORBITAL);
// Update the shader with the camera view vector (points towards { 0.0f, 0.0f, 0.0f })
@ -280,12 +290,12 @@ int main(void)
// When drawing a model here, make sure that the material's shaders
// are set to the gbuffer shader!
DrawModel(model, Vector3Zero(), 1.0f, WHITE);
DrawModel(cube, (Vector3) { 0.0, 1.0f, 0.0 }, 1.0f, WHITE);
DrawModel(sphere, (Vector3) { 0.0, 1.0f, 0.0 }, 1.0f, WHITE);
for (int i = 0; i < MAX_CUBES; i++)
for (int i = 0; i < MAX_SPHERES; i++)
{
Vector3 position = cubePositions[i];
DrawModelEx(cube, position, (Vector3) { 1, 1, 1 }, cubeRotations[i], (Vector3) { CUBE_SCALE, CUBE_SCALE, CUBE_SCALE }, cubeColors[i]);
Vector3 position = spherePositions[i];
DrawModelEx(sphere, position, (Vector3) { 1, 1, 1 }, sphereRotations[i], (Vector3) { SPHERE_SCALE, SPHERE_SCALE, SPHERE_SCALE }, sphereColors[i]);
}
rlDisableShader();
@ -333,6 +343,9 @@ int main(void)
rlEnableShader(rlGetShaderIdDefault());
for (int i = 0; i < MAX_LIGHTS; i++)
{
lights[i].position.x=cos((i+3*i*time)*i*1.57*0.002+time)*5;
lights[i].position.z=sin((i+3*i*time)*i*1.57*0.001+time)*5;
lights[i].position.y=Clamp(sin(i*0.77+time*0.1*i)*3,0,3)+0.5;
if (lights[i].enabled) DrawSphereEx(lights[i].position, 0.2f, 8, 8, lights[i].color);
else DrawSphereWires(lights[i].position, 0.2f, 8, 8, ColorAlpha(lights[i].color, 0.3f));
}
@ -368,7 +381,7 @@ int main(void)
.height = screenHeight,
}, (Rectangle) { 0, 0, (float)screenWidth, (float)-screenHeight }, Vector2Zero(), RAYWHITE);
DrawText("ALBEDO*SPECULAR TEXTURE", 10, screenHeight - 30, 20, DARKGREEN);
DrawText("ALBEDO TEXTURE", 10, screenHeight - 30, 20, DARKGREEN);
} break;
default: break;
}
@ -385,9 +398,9 @@ int main(void)
// De-Initialization
//--------------------------------------------------------------------------------------
UnloadModel(model); // Unload the models
UnloadModel(cube);
UnloadModel(sphere);
UnloadTexture(texture_specular);
UnloadTexture(texture_albedo_specular);
UnloadShader(deferredShader); // Unload shaders
UnloadShader(gbufferShader);

Načítá se…
Zrušit
Uložit