Changeset 19c9338 in opengl-game
- Timestamp:
- Mar 9, 2018, 3:55:46 AM (7 years ago)
- Branches:
- feature/imgui-sdl, master, points-test
- Children:
- de1d7f6
- Parents:
- 64a70f4
- git-author:
- Dmitry Portnoy <dmp1488@…> (03/09/18 03:43:05)
- git-committer:
- Dmitry Portnoy <dmp1488@…> (03/09/18 03:55:46)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
new-game.cpp
r64a70f4 r19c9338 18 18 #include <cmath> 19 19 #include <string> 20 #include <array> 20 21 21 22 using namespace std; … … 30 31 vec3 cam_pos; 31 32 32 vec3 face_point1, face_point2, face_point3; 33 array<vec3, 3> triangle_face; 34 35 array<vec3,3> colored_triangle; 36 array<vec3, 3> square_triangle1; 37 array<vec3, 3> square_triangle2; 33 38 34 39 bool clicked = false; … … 37 42 bool clicked_square = false; 38 43 44 mat4 model_mat; 45 mat4 model_mat2; 46 39 47 mat4 view_mat; 40 48 mat4 proj_mat; 41 49 42 bool insideTriangle(vec3 p, vec3 v1, vec3 v2, vec3 v3);50 bool insideTriangle(vec3 p, array<vec3, 3> triangle); 43 51 44 52 GLuint loadShader(GLenum type, string file); … … 118 126 */ 119 127 120 vec3 fp1 = face_point1;121 vec3 fp2 = face_point2;122 vec3 fp3 = face_point3;128 vec3 fp1 = triangle_face[0]; 129 vec3 fp2 = triangle_face[1]; 130 vec3 fp3 = triangle_face[2]; 123 131 124 132 cout << "Points on the plane" << endl; … … 146 154 cout << "(" << i.x << "," << i.y << "," << i.z << ")" << endl; 147 155 148 clicked = insideTriangle(i, fp1, fp2, fp3);156 clicked = insideTriangle(i, triangle_face); 149 157 cout << (clicked ? "true" : "false") << endl; 150 158 } 151 159 } 160 161 /* REFACTORING PLAN: 162 * 163 * Have an array of object structs 164 * Each object struct has: 165 * -a model matrix 166 * -a selected boolean 167 * Eventually, maybe also want to store a reference to the correct shader 168 * or whatever other info I need to properly render it 169 * 170 * Have an array of face structs 171 * Each face struct has 172 * -an object index indicating which object it is a part of 173 * -an array of three points 174 * 175 * The mouse button callback will: 176 * -Set all selected flags in the objects array to false 177 * -iterate through the faces array 178 * -For each face, it will call faceClicked() with the following params: 179 * -Probably a world ray created from the mouse click coordinates 180 * -An array of 3 points representing the face 181 * -The object struct represnting the object the face is a part of 182 */ 152 183 153 184 void mouse_button_callback_new(GLFWwindow* window, int button, int action, int mods) { … … 161 192 float y = 1.0f - (2.0f*mouse_y) / height; 162 193 163 //x = -.1f;164 //x = -.25f;165 //x = -.5f;166 167 //y = .1f;168 169 194 cout << "x: " << x << ", y: " << y << endl; 170 171 // CHECK: Looks good up to here172 195 173 196 // Since the projection matrix gets applied before the view matrix, … … 182 205 // vec3 ray_world = normalize((inverse(view_mat) * ray_eye).xyz()); 183 206 184 //vec4 ray_clip = vec4(0.0f, 0.0f, NEAR_CLIP, 1.0f); // this should have a z equal to the near clipping plane185 207 vec4 ray_clip = vec4(x, y, NEAR_CLIP, 1.0f); // this should have a z equal to the near clipping plane 186 208 vec4 ray_eye = ray_clip; 187 vec3 ray_world = (inverse( view_mat) * ray_eye).xyz();209 vec3 ray_world = (inverse(model_mat) * inverse(view_mat) * ray_eye).xyz(); 188 210 189 211 /* LATEST NOTES: … … 191 213 * Normalizing the world ray caused issues, although it should make sense with the projection 192 214 * matrix, since the z coordinate has meaning there. 215 * Plus, we really want to normalize it only once we recompute it below as the difference of two points, 216 * although doing so shouldn't effect the results. Check the book to see if there is a good reason for doing so. 193 217 */ 194 218 … … 196 220 197 221 vec4 cam_pos_origin = vec4(x, y, 0.0f, 1.0f); 198 vec3 cam_pos_temp = (inverse( view_mat) * cam_pos_origin).xyz();222 vec3 cam_pos_temp = (inverse(model_mat) * inverse(view_mat) * cam_pos_origin).xyz(); 199 223 200 224 ray_world = ray_world-cam_pos_temp; … … 204 228 cout << "Camera -> (" << cam_pos_temp.x << "," << cam_pos_temp.y << "," << cam_pos_temp.z << ")" << endl; 205 229 206 vec3 fp1 = face_point1;207 vec3 fp2 = face_point2;208 vec3 fp3 = face_point3;230 vec3 fp1 = triangle_face[0]; 231 vec3 fp2 = triangle_face[1]; 232 vec3 fp3 = triangle_face[2]; 209 233 210 234 cout << "Points on the plane" << endl; … … 239 263 printVector("Intersection", intersection); 240 264 241 clicked = insideTriangle(intersection, fp1, fp2, fp3);265 clicked = insideTriangle(intersection, triangle_face); 242 266 cout << (clicked ? "true" : "false") << endl; 243 267 … … 328 352 glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); 329 353 330 /*331 354 GLfloat points[] = { 332 355 0.0f, 0.5f, 0.0f, … … 337 360 0.0f, 0.5f, 0.0f, 338 361 }; 339 */340 341 GLfloat points[] = {342 0.5f, 0.5f, 0.0f,343 0.0f, -0.5f, 0.0f,344 1.0f, -0.5f, 0.0f,345 1.0f, -0.5f, 0.0f,346 0.0f, -0.5f, 0.0f,347 0.5f, 0.5f, 0.0f,348 };349 350 // initialize global variables for click intersection test351 face_point1 = vec3(points[0], points[1], points[2]);352 face_point2 = vec3(points[3], points[4], points[5]);353 face_point3 = vec3(points[6], points[7], points[8]);354 362 355 363 GLfloat colors[] = { … … 374 382 int numPoints = (sizeof(points) / sizeof(float)) / 3; 375 383 376 /*377 384 GLfloat points2[] = { 378 385 0.5f, 0.5f, 0.0f, … … 383 390 0.5f, -0.5f, 0.0f, 384 391 }; 385 */386 387 GLfloat points2[] = {388 0.0f, 0.5f, 0.0f,389 -1.0f, 0.5f, 0.0f,390 -1.0f, -0.5f, 0.0f,391 0.0f, 0.5f, 0.0f,392 -1.0f, -0.5f, 0.0f,393 0.0f, -0.5f, 0.0f,394 };395 392 396 393 GLfloat colors2[] = { … … 415 412 int numPoints2 = (sizeof(points2) / sizeof(float)) / 3; 416 413 414 // initialize global variables for click intersection tests 415 416 colored_triangle = { 417 vec3(points[0], points[1], points[2]), 418 vec3(points[3], points[4], points[5]), 419 vec3(points[6], points[7], points[8]), 420 }; 421 422 square_triangle1 = { 423 vec3(points2[0], points2[1], points2[2]), 424 vec3(points2[3], points2[4], points2[5]), 425 vec3(points2[6], points2[7], points2[8]), 426 }; 427 428 square_triangle2 = { 429 vec3(points2[9], points2[10], points2[11]), 430 vec3(points2[12], points2[13], points2[14]), 431 vec3(points2[15], points2[16], points2[17]), 432 }; 433 434 triangle_face = colored_triangle; 435 417 436 /* 418 mat4 T_model = translate(mat4(), vec3(0.5f, 0.0f, 0.0f));419 437 mat4 R_model = rotate(mat4(), 4.0f, vec3(0.0f, 1.0f, 0.0f)); 420 438 */ 421 mat4 T_model = translate(mat4(), vec3(0. 0f, 0.0f, 0.0f));439 mat4 T_model = translate(mat4(), vec3(0.5f, 0.0f, 0.0f)); 422 440 mat4 R_model = rotate(mat4(), 0.0f, vec3(0.0f, 1.0f, 0.0f)); 423 m at4 model_mat = T_model*R_model;441 model_mat = T_model*R_model; 424 442 425 443 // mat4 T_model2 = translate(mat4(), vec3(-1.0f, 0.0f, 0.0f)); 426 mat4 T_model2 = translate(mat4(), vec3( 0.0f, 0.0f, 0.0f));444 mat4 T_model2 = translate(mat4(), vec3(-0.5f, 0.0f, 0.0f)); 427 445 mat4 R_model2 = rotate(mat4(), 0.0f, vec3(0.0f, 1.0f, 0.0f)); 428 m at4 model_mat2 = T_model2*R_model2;446 model_mat2 = T_model2*R_model2; 429 447 430 448 GLuint points_vbo = 0; … … 523 541 proj_mat = make_mat4(proj_arr); 524 542 543 GLint model_test_loc = glGetUniformLocation(shader_program, "model"); 544 GLint view_test_loc = glGetUniformLocation(shader_program, "view"); 545 GLint proj_test_loc = glGetUniformLocation(shader_program, "proj"); 546 525 547 GLint model_mat_loc = glGetUniformLocation(shader_program2, "model"); 526 548 GLint view_mat_loc = glGetUniformLocation(shader_program2, "view"); 527 549 GLint proj_mat_loc = glGetUniformLocation(shader_program2, "proj"); 528 550 529 GLint model_test_loc = glGetUniformLocation(shader_program, "model");530 GLint view_test_loc = glGetUniformLocation(shader_program, "view");531 GLint proj_test_loc = glGetUniformLocation(shader_program, "proj");532 533 551 glUseProgram(shader_program); 534 552 glUniformMatrix4fv(model_test_loc, 1, GL_FALSE, value_ptr(model_mat)); 553 glUniformMatrix4fv(view_test_loc, 1, GL_FALSE, value_ptr(view_mat)); 535 554 glUniformMatrix4fv(proj_test_loc, 1, GL_FALSE, value_ptr(proj_mat)); 536 555 537 556 glUseProgram(shader_program2); 538 557 glUniformMatrix4fv(model_mat_loc, 1, GL_FALSE, value_ptr(model_mat2)); 558 glUniformMatrix4fv(view_mat_loc, 1, GL_FALSE, value_ptr(view_mat)); 539 559 glUniformMatrix4fv(proj_mat_loc, 1, GL_FALSE, value_ptr(proj_mat)); 540 541 // glUniform1i(tex_loc, 0);542 560 543 561 bool cam_moved = false; … … 575 593 576 594 glUseProgram(shader_program); 577 glUniformMatrix4fv(view_test_loc, 1, GL_FALSE, value_ptr(view_mat)); 595 596 // this is temporary. 597 // It's needed to offset the code for the recoloring of the square working during click detection 598 glUniformMatrix4fv(model_test_loc, 1, GL_FALSE, value_ptr(model_mat)); 578 599 579 600 glBindVertexArray(vao); … … 583 604 if (clicked_square) { 584 605 glUseProgram(shader_program); 585 glUniformMatrix4fv(view_test_loc, 1, GL_FALSE, value_ptr(view_mat)); 606 607 // this is temporary. 608 // It's needed to get the recoloring of the square working during click detection 609 glUniformMatrix4fv(model_test_loc, 1, GL_FALSE, value_ptr(model_mat2)); 586 610 587 611 glBindVertexArray(vao2); … … 591 615 } else { 592 616 glUseProgram(shader_program2); 593 glUniformMatrix4fv(view_mat_loc, 1, GL_FALSE, value_ptr(view_mat));594 617 595 618 glBindVertexArray(vao2); … … 701 724 } 702 725 703 bool insideTriangle(vec3 p, vec3 v1, vec3 v2, vec3 v3) {704 vec3 v21 = v2-v1;705 vec3 v31 = v3-v1;706 vec3 pv1 = p- v1;726 bool insideTriangle(vec3 p, array<vec3,3> triangle) { 727 vec3 v21 = triangle[1]-triangle[0]; 728 vec3 v31 = triangle[2]-triangle[0]; 729 vec3 pv1 = p-triangle[0]; 707 730 708 731 float y = (pv1.y*v21.x - pv1.x*v21.y) / (v31.y*v21.x - v31.x*v21.y);
Note:
See TracChangeset
for help on using the changeset viewer.