Changeset a00eb06 in opengl-game


Ignore:
Timestamp:
Apr 10, 2021, 12:58:17 AM (4 years ago)
Author:
Dmitry Portnoy <dportnoy@…>
Branches:
feature/imgui-sdl
Children:
8d92284
Parents:
914bb99
git-author:
Dmitry Portnoy <dportnoy@…> (04/10/21 00:49:42)
git-committer:
Dmitry Portnoy <dportnoy@…> (04/10/21 00:58:17)
Message:

In VulkanGame, add a normal varying attribute to ModelVertex

Files:
4 edited

Legend:

Unmodified
Added
Removed
  • shaders/model.frag

    r914bb99 ra00eb06  
    66layout(location = 0) in vec3 fragColor;
    77layout(location = 1) in vec2 fragTexCoord;
     8layout(location = 2) in vec3 normal_eye;
    89
    910layout(location = 0) out vec4 outColor;
    1011
    1112void main() {
    12    outColor = vec4(fragColor * texture(texSampler, fragTexCoord).rgb, 1.0);
     13   outColor = vec4(fragColor * texture(texSampler, fragTexCoord).rgb, 1.0) + vec4(normal_eye, 0.0) - vec4(normal_eye, 0.0);
    1314}
  • shaders/model.vert

    r914bb99 ra00eb06  
    1515} sbo;
    1616
     17layout (binding = 2) uniform UboInstance {
     18        mat4 model;
     19} uboInstance;
     20
    1721layout(location = 0) in vec3 inPosition;
    1822layout(location = 1) in vec3 inColor;
    1923layout(location = 2) in vec2 inTexCoord;
    20 layout(location = 3) in uint obj_index;
     24layout(location = 3) in vec3 vertex_normal;
     25layout(location = 4) in uint obj_index;
    2126
    2227layout(location = 0) out vec3 fragColor;
    2328layout(location = 1) out vec2 fragTexCoord;
     29layout(location = 2) out vec3 normal_eye;
    2430
    2531void main() {
     32   // Using 0.0 instead of 1.0 means translations won't effect the normal
     33   normal_eye = normalize(vec3(ubo.view * sbo.objects[obj_index].model * vec4(vertex_normal, 0.0)));
     34
    2635   fragColor = inColor;
    2736   fragTexCoord = inTexCoord;
  • vulkan-game.cpp

    r914bb99 ra00eb06  
    117117   modelPipeline.addAttribute(VK_FORMAT_R32G32B32_SFLOAT, offset_of(&ModelVertex::color));
    118118   modelPipeline.addAttribute(VK_FORMAT_R32G32_SFLOAT, offset_of(&ModelVertex::texCoord));
     119   modelPipeline.addAttribute(VK_FORMAT_R32G32B32_SFLOAT, offset_of(&ModelVertex::normal));
    119120   modelPipeline.addAttribute(VK_FORMAT_R32_UINT, offset_of(&ModelVertex::objIndex));
    120121
     
    131132
    132133   texturedSquare = &addObject(modelObjects, modelPipeline,
    133       addObjectIndex<ModelVertex>(modelObjects.size(), {
    134          {{-0.5f, -0.5f,  0.0f}, {1.0f, 0.0f, 0.0f}, {0.0f, 1.0f}},
    135          {{ 0.5f, -0.5f,  0.0f}, {0.0f, 1.0f, 0.0f}, {1.0f, 1.0f}},
    136          {{ 0.5f,  0.5f,  0.0f}, {0.0f, 0.0f, 1.0f}, {1.0f, 0.0f}},
    137          {{ 0.5f,  0.5f,  0.0f}, {0.0f, 0.0f, 1.0f}, {1.0f, 0.0f}},
    138          {{-0.5f,  0.5f,  0.0f}, {1.0f, 1.0f, 1.0f}, {0.0f, 0.0f}},
    139          {{-0.5f, -0.5f,  0.0f}, {1.0f, 0.0f, 0.0f}, {0.0f, 1.0f}}
    140       }), {
    141          0, 1, 2, 3, 4, 5
    142       }, {
    143          mat4(1.0f)
    144       }, false);
     134      addObjectIndex<ModelVertex>(modelObjects.size(),
     135         addVertexNormals<ModelVertex>({
     136            {{-0.5f, -0.5f,  0.0f}, {1.0f, 0.0f, 0.0f}, {0.0f, 1.0f}},
     137            {{ 0.5f, -0.5f,  0.0f}, {0.0f, 1.0f, 0.0f}, {1.0f, 1.0f}},
     138            {{ 0.5f,  0.5f,  0.0f}, {0.0f, 0.0f, 1.0f}, {1.0f, 0.0f}},
     139            {{ 0.5f,  0.5f,  0.0f}, {0.0f, 0.0f, 1.0f}, {1.0f, 0.0f}},
     140            {{-0.5f,  0.5f,  0.0f}, {1.0f, 1.0f, 1.0f}, {0.0f, 0.0f}},
     141            {{-0.5f, -0.5f,  0.0f}, {1.0f, 0.0f, 0.0f}, {0.0f, 1.0f}}
     142         })), {
     143            0, 1, 2, 3, 4, 5
     144         }, {
     145            mat4(1.0f)
     146         }, false);
    145147
    146148   texturedSquare->model_base =
     
    149151
    150152   texturedSquare = &addObject(modelObjects, modelPipeline,
    151       addObjectIndex<ModelVertex>(modelObjects.size(), {
    152          {{-0.5f, -0.5f,  0.0f}, {1.0f, 0.0f, 0.0f}, {0.0f, 1.0f}},
    153          {{ 0.5f, -0.5f,  0.0f}, {0.0f, 1.0f, 0.0f}, {1.0f, 1.0f}},
    154          {{ 0.5f,  0.5f,  0.0f}, {0.0f, 0.0f, 1.0f}, {1.0f, 0.0f}},
    155          {{ 0.5f,  0.5f,  0.0f}, {0.0f, 0.0f, 1.0f}, {1.0f, 0.0f}},
    156          {{-0.5f,  0.5f,  0.0f}, {1.0f, 1.0f, 1.0f}, {0.0f, 0.0f}},
    157          {{-0.5f, -0.5f,  0.0f}, {1.0f, 0.0f, 0.0f}, {0.0f, 1.0f}}
    158       }), {
    159          0, 1, 2, 3, 4, 5
    160       }, {
    161          mat4(1.0f)
    162       }, false);
     153      addObjectIndex<ModelVertex>(modelObjects.size(),
     154         addVertexNormals<ModelVertex>({
     155            {{-0.5f, -0.5f,  0.0f}, {1.0f, 0.0f, 0.0f}, {0.0f, 1.0f}},
     156            {{ 0.5f, -0.5f,  0.0f}, {0.0f, 1.0f, 0.0f}, {1.0f, 1.0f}},
     157            {{ 0.5f,  0.5f,  0.0f}, {0.0f, 0.0f, 1.0f}, {1.0f, 0.0f}},
     158            {{ 0.5f,  0.5f,  0.0f}, {0.0f, 0.0f, 1.0f}, {1.0f, 0.0f}},
     159            {{-0.5f,  0.5f,  0.0f}, {1.0f, 1.0f, 1.0f}, {0.0f, 0.0f}},
     160            {{-0.5f, -0.5f,  0.0f}, {1.0f, 0.0f, 0.0f}, {0.0f, 1.0f}}
     161         })), {
     162            0, 1, 2, 3, 4, 5
     163         }, {
     164            mat4(1.0f)
     165         }, false);
    163166
    164167   texturedSquare->model_base =
     
    534537   }
    535538
    536    window = (SDL_Window*) gui->createWindow("Vulkan Game", width, height, guiFlags & GUI_FLAGS_WINDOW_FULLSCREEN);
     539   window = (SDL_Window*)gui->createWindow("Vulkan Game", width, height, guiFlags & GUI_FLAGS_WINDOW_FULLSCREEN);
    537540   if (window == nullptr) {
    538541      cout << "Window could not be created!" << endl;
     
    703706                  SceneObject<ModelVertex, SSBO_ModelObject>& texturedSquare =
    704707                     addObject(modelObjects, modelPipeline,
    705                         addObjectIndex<ModelVertex>(modelObjects.size(), {
    706                            {{-0.5f, -0.5f,  0.0f}, {1.0f, 0.0f, 0.0f}, {0.0f, 1.0f}},
    707                            {{ 0.5f, -0.5f,  0.0f}, {0.0f, 1.0f, 0.0f}, {1.0f, 1.0f}},
    708                            {{ 0.5f,  0.5f,  0.0f}, {0.0f, 0.0f, 1.0f}, {1.0f, 0.0f}},
    709                            {{ 0.5f,  0.5f,  0.0f}, {0.0f, 0.0f, 1.0f}, {1.0f, 0.0f}},
    710                            {{-0.5f,  0.5f,  0.0f}, {1.0f, 1.0f, 1.0f}, {0.0f, 0.0f}},
    711                            {{-0.5f, -0.5f,  0.0f}, {1.0f, 0.0f, 0.0f}, {0.0f, 1.0f}}
    712                         }), {
    713                            0, 1, 2, 3, 4, 5
    714                         }, {
    715                            mat4(1.0f)
    716                         }, true);
     708                        addObjectIndex<ModelVertex>(modelObjects.size(),
     709                           addVertexNormals<ModelVertex>({
     710                              {{-0.5f, -0.5f,  0.0f}, {1.0f, 0.0f, 0.0f}, {0.0f, 1.0f}},
     711                              {{ 0.5f, -0.5f,  0.0f}, {0.0f, 1.0f, 0.0f}, {1.0f, 1.0f}},
     712                              {{ 0.5f,  0.5f,  0.0f}, {0.0f, 0.0f, 1.0f}, {1.0f, 0.0f}},
     713                              {{ 0.5f,  0.5f,  0.0f}, {0.0f, 0.0f, 1.0f}, {1.0f, 0.0f}},
     714                              {{-0.5f,  0.5f,  0.0f}, {1.0f, 1.0f, 1.0f}, {0.0f, 0.0f}},
     715                              {{-0.5f, -0.5f,  0.0f}, {1.0f, 0.0f, 0.0f}, {0.0f, 1.0f}}
     716                           })), {
     717                              0, 1, 2, 3, 4, 5
     718                           }, {
     719                              mat4(1.0f)
     720                           }, true);
    717721
    718722                  texturedSquare.model_base =
  • vulkan-game.hpp

    r914bb99 ra00eb06  
    4747   vec3 color;
    4848   vec2 texCoord;
     49   vec3 normal;
    4950   unsigned int objIndex;
    5051};
Note: See TracChangeset for help on using the changeset viewer.