Advertisement
Kirabo

Untitled

Jul 31st, 2016
362
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 12.16 KB | None | 0 0
  1. /*
  2. OUR FIRST VIDEO GAME
  3.  
  4. This is our first attempt at creating a video game using OpenGL and C++.
  5. The team members are, from youngest to oldest:
  6. - Toni, Ugo, Vanja.
  7.  
  8. The project started on Saturday, July 30, 2016, after a straight week of learning OpenGL without stopping.
  9. After a short discussion in a local cafe, we decided what the main concepts of the game would be, and what
  10. problems we'll be looking to solve while developing the game. The game is basically a prototype for our
  11. upcoming gargantuan project, (codename: Sektor Exitium) so it leaves much to be desired for, which is fine.
  12.  
  13. The basic premise is that you're a jailbird on a prison colony planet, with the goal of fleeing from the
  14. facility. This way, we get to experiment with various game mechanics, while avoiding the more complicated
  15. issues such as AI, procedural generation of open worlds, complex combat and crafting systems, etc...
  16.  
  17. Here's to a successful first project!
  18. */
  19.  
  20. #include <iostream> // STD includes
  21. #include <cstdlib>
  22. #include <math.h>
  23. #include <string>
  24. #include <conio.h>
  25.  
  26. #define GLEW_STATIC
  27.  
  28. #include <GL/glew.h> // GLEW includes
  29.  
  30. #include <GLFW/glfw3.h> // GLFW includes
  31.  
  32. #include "Shader.h" // GL includes
  33.  
  34. #include <glm/glm.hpp> // GLM Mathematics
  35. #include <glm/gtc/matrix_transform.hpp>
  36. #include <glm/gtc/type_ptr.hpp>
  37.  
  38. #include <SOIL.h> // Other Libs
  39.  
  40. using namespace std;
  41. using namespace glm;
  42.  
  43. // Window properties
  44. GLuint screenWidth = 1200, screenHeight = 675;
  45.  
  46. // Function prototypes
  47. void key_callback(GLFWwindow* window, int key, int scancode, int action, int mode);
  48. void mouse_callback(GLFWwindow* window, double xpos, double ypos);
  49.  
  50. int nextTile, previousTile;
  51. int h = 20, w = 36, a, b;
  52. int x = 2, y = 2;
  53. int Matrix[20][36] =
  54. {
  55. { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1 },
  56. { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 },
  57. { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 },
  58. { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 },
  59. { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 },
  60. { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 },
  61. { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 },
  62. { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 },
  63. { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 },
  64. { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 },
  65. { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 },
  66. { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 },
  67. { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 },
  68. { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 },
  69. { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 },
  70. { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 },
  71. { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 },
  72. { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 },
  73. { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1 },
  74. { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1 }
  75. };
  76.  
  77. int main() {
  78.  
  79. system("COLOR 0B");
  80.  
  81. Matrix[x][y] = 5;
  82. previousTile = 0;
  83.  
  84. for (a = 0; a < h; a++) {
  85. cout << endl;
  86. for (b = 0; b < w; b++) {
  87. cout << Matrix[a][b] << ' ';
  88. }
  89. }
  90.  
  91. // Sets up everything window related using GLFW
  92. glfwInit();
  93. glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 3);
  94. glfwWindowHint(GLFW_CONTEXT_VERSION_MINOR, 3);
  95. glfwWindowHint(GLFW_OPENGL_PROFILE, GLFW_OPENGL_CORE_PROFILE);
  96. glfwWindowHint(GLFW_RESIZABLE, GL_FALSE);
  97. glfwWindowHint(GLFW_SAMPLES, 4);
  98.  
  99. GLFWwindow* window = glfwCreateWindow(screenWidth, screenHeight, "Sektor Exitium: Escape", nullptr, nullptr);
  100. glfwMakeContextCurrent(window); // Start the application windowed
  101.  
  102. glfwSetKeyCallback(window, key_callback); // Set the required callback functions
  103. glfwSetCursorPosCallback(window, mouse_callback);
  104.  
  105.  
  106. glfwSetInputMode(window, GLFW_CURSOR, GLFW_CURSOR_NORMAL); // Cursor options
  107.  
  108.  
  109. glewExperimental = GL_TRUE; // Initialize GLEW to setup the OpenGL Function pointers
  110. glewInit();
  111.  
  112. glViewport(0, 0, screenWidth, screenHeight); // Define the viewport dimensions
  113.  
  114. Shader ourShader("shader.vs", "shader.frag"); // Shader setup
  115.  
  116. // Set up vertex data (and buffer(s)) and attribute pointers
  117. GLfloat vertices[] = {
  118. // Positions // Colors // Texture Coords
  119. 0.5f, 0.5f, 0.0f, 1.0f, 0.0f, 0.0f, 1.0f, 1.0f, // Top Right
  120. 0.5f, -0.5f, 0.0f, 0.0f, 1.0f, 0.0f, 1.0f, 0.0f, // Bottom Right
  121. -0.5f, -0.5f, 0.0f, 0.0f, 0.0f, 1.0f, 0.0f, 0.0f, // Bottom Left
  122. -0.5f, 0.5f, 0.0f, 1.0f, 1.0f, 0.0f, 0.0f, 1.0f // Top Left
  123. };
  124. GLuint indices[] = { // Note that we start from 0!
  125. 0, 1, 3, // First Triangle
  126. 1, 2, 3 // Second Triangle
  127. };
  128. GLuint VBO, VAO, EBO;
  129. glGenVertexArrays(1, &VAO);
  130. glGenBuffers(1, &VBO);
  131. glGenBuffers(1, &EBO);
  132.  
  133. glBindVertexArray(VAO);
  134.  
  135. glBindBuffer(GL_ARRAY_BUFFER, VBO);
  136. glBufferData(GL_ARRAY_BUFFER, sizeof(vertices), vertices, GL_STATIC_DRAW);
  137.  
  138. glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, EBO);
  139. glBufferData(GL_ELEMENT_ARRAY_BUFFER, sizeof(indices), indices, GL_STATIC_DRAW);
  140.  
  141. // Position attribute
  142. glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, 8 * sizeof(GLfloat), (GLvoid*)0);
  143. glEnableVertexAttribArray(0);
  144. // Color attribute
  145. glVertexAttribPointer(1, 3, GL_FLOAT, GL_FALSE, 8 * sizeof(GLfloat), (GLvoid*)(3 * sizeof(GLfloat)));
  146. glEnableVertexAttribArray(1);
  147. // TexCoord attribute
  148. glVertexAttribPointer(2, 2, GL_FLOAT, GL_FALSE, 8 * sizeof(GLfloat), (GLvoid*)(6 * sizeof(GLfloat)));
  149. glEnableVertexAttribArray(2);
  150.  
  151. glBindVertexArray(0); // Unbind VAO
  152.  
  153.  
  154. // Load and create a texture
  155. GLuint texture1;
  156. GLuint texture2;
  157.  
  158.  
  159. // TEXTURE 1
  160.  
  161. glGenTextures(1, &texture1);
  162. glBindTexture(GL_TEXTURE_2D, texture1); // All upcoming GL_TEXTURE_2D operations now have effect on our texture object
  163. // Set our texture parameters
  164. glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_REPEAT); // Set texture wrapping to GL_REPEAT
  165. glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_REPEAT);
  166. // Set texture filtering
  167. glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
  168. glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
  169. // Load, create texture and generate mipmaps
  170. int width, height;
  171. unsigned char* image = SOIL_load_image("Door.png", &width, &height, 0, SOIL_LOAD_RGB);
  172. glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, width, height, 0, GL_RGB, GL_UNSIGNED_BYTE, image);
  173. glGenerateMipmap(GL_TEXTURE_2D);
  174. SOIL_free_image_data(image);
  175. glBindTexture(GL_TEXTURE_2D, 0); // Unbind texture when done, so we won't accidentily mess up our texture.
  176.  
  177.  
  178. // TEXTURE 2
  179.  
  180. glGenTextures(1, &texture2);
  181. glBindTexture(GL_TEXTURE_2D, texture2);
  182. // Set our texture parameters
  183. glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_REPEAT);
  184. glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_REPEAT);
  185. // Set texture filtering
  186. glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
  187. glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
  188. // Load, create texture and generate mipmaps
  189. image = SOIL_load_image("Wallpng.png", &width, &height, 0, SOIL_LOAD_RGB);
  190. glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, width, height, 0, GL_RGB, GL_UNSIGNED_BYTE, image);
  191. glGenerateMipmap(GL_TEXTURE_2D);
  192. SOIL_free_image_data(image);
  193. glBindTexture(GL_TEXTURE_2D, 0);
  194.  
  195. // GAME LOOP STARTS HERE
  196. while (!glfwWindowShouldClose(window))
  197. {
  198.  
  199. glfwPollEvents();
  200.  
  201. glClearColor(0.1f, 0.1f, 0.1f, 1.0f);
  202. glClear(GL_COLOR_BUFFER_BIT);
  203.  
  204. // Bind Textures using texture units
  205. glActiveTexture(GL_TEXTURE0);
  206. glBindTexture(GL_TEXTURE_2D, texture1);
  207. glUniform1i(glGetUniformLocation(ourShader.Program, "ourTexture1"), 0);
  208. glActiveTexture(GL_TEXTURE1);
  209. glBindTexture(GL_TEXTURE_2D, texture2);
  210. glUniform1i(glGetUniformLocation(ourShader.Program, "ourTexture2"), 1);
  211.  
  212. ourShader.Use();
  213.  
  214. // Create transformations
  215. glm::mat4 model;
  216. glm::mat4 view;
  217. glm::mat4 projection;
  218. model = glm::translate(model, glm::vec3(-2.0f, 0.0f, 0.0f));
  219. model = glm::scale(model, glm::vec3(0.05f));
  220. view = glm::translate(view, glm::vec3(0.0f, 0.0f, -1.0f));
  221. projection = glm::perspective(45.0f, (GLfloat)screenWidth / (GLfloat)screenHeight, 0.1f, 100.0f);
  222.  
  223. // Get their uniform locations and pass to shaders
  224. GLint modelLoc = glGetUniformLocation(ourShader.Program, "model");
  225. glUniformMatrix4fv(modelLoc, 1, GL_FALSE, glm::value_ptr(model));
  226.  
  227. GLint viewLoc = glGetUniformLocation(ourShader.Program, "view");
  228. glUniformMatrix4fv(viewLoc, 1, GL_FALSE, glm::value_ptr(view));
  229.  
  230. GLint projLoc = glGetUniformLocation(ourShader.Program, "projection");
  231. glUniformMatrix4fv(projLoc, 1, GL_FALSE, glm::value_ptr(projection));
  232.  
  233. glBindVertexArray(VAO);
  234. for (GLuint i = 0; i < 10; i++)
  235. {
  236. // Calculate the model matrix for each object and pass it to shader before drawing
  237. glm::mat4 model;
  238. model = glm::scale(model, glm::vec3(0.05f));
  239. model = glm::translate(model, vec3((GLfloat)(i - 5.0f), (GLfloat)(i), 0.0f));
  240. glUniformMatrix4fv(modelLoc, 1, GL_FALSE, glm::value_ptr(model));
  241.  
  242. glDrawElements(GL_TRIANGLES, 6, GL_UNSIGNED_INT, 0);
  243. }
  244.  
  245. // Draw container
  246. glBindVertexArray(VAO);
  247. glDrawElements(GL_TRIANGLES, 6, GL_UNSIGNED_INT, 0);
  248. glBindVertexArray(0);
  249.  
  250. glfwSwapBuffers(window);
  251. }
  252. // GAME LOOP ENDS HERE
  253.  
  254. // Properly de-allocate all resources once they've outlived their purpose
  255. glDeleteVertexArrays(1, &VAO);
  256. glDeleteBuffers(1, &VBO);
  257. glDeleteBuffers(1, &EBO);
  258. // Terminate GLFW, clearing any resources allocated by GLFW.
  259. glfwTerminate();
  260. return 0;
  261. }
  262.  
  263. // Function for keyboard input
  264.  
  265. void key_callback(GLFWwindow * window, int key, int scancode, int action, int mode)
  266. {
  267. if (key == GLFW_KEY_ESCAPE && action == GLFW_PRESS)
  268. glfwSetWindowShouldClose(window, GL_TRUE);
  269. if (key == GLFW_KEY_UP && action == GLFW_PRESS) {
  270. if (Matrix[y - 1][x] == 1) {
  271. cout << "You hit a wall!";
  272. }
  273. else {
  274. Matrix[y][x] = 0;
  275. Matrix[y - 1][x] = 5;
  276. y = y - 1;
  277. for (a = 0; a < h; a++) {
  278. cout << endl;
  279. for (b = 0; b < w; b++) {
  280. cout << Matrix[a][b] << ' ';
  281. }
  282. }
  283. }
  284. }
  285. if (key == GLFW_KEY_DOWN && action == GLFW_PRESS) {
  286.  
  287. if (Matrix[y + 1][x] == 1) {
  288. cout << "You hit a wall!";
  289. }
  290. else {
  291. Matrix[y][x] = 0;
  292. Matrix[y + 1][x] = 5;
  293. y = y + 1;
  294. for (a = 0; a < h; a++) {
  295. cout << endl;
  296. for (b = 0; b < w; b++) {
  297. cout << Matrix[a][b] << ' ';
  298. }
  299. }
  300. }
  301. }
  302. if (key == GLFW_KEY_LEFT && action == GLFW_PRESS) {
  303. if (Matrix[y][x - 1] == 1) {
  304. cout << "You hit a wall!";
  305. }
  306. else {
  307. Matrix[y][x] = 0;
  308. Matrix[y][x - 1] = 5;
  309. x = x - 1;
  310. for (a = 0; a < h; a++) {
  311. cout << endl;
  312. for (b = 0; b < w; b++) {
  313. cout << Matrix[a][b] << ' ';
  314. }
  315. }
  316. }
  317. }
  318. if (key == GLFW_KEY_RIGHT && action == GLFW_PRESS) {
  319. if (Matrix[y][x + 1] == 1) {
  320. cout << "You hit a wall!";
  321. }
  322. else {
  323. Matrix[y][x] = 0;
  324. Matrix[y][x + 1] = 5;
  325. x = x + 1;
  326. for (a = 0; a < h; a++) {
  327. cout << endl;
  328. for (b = 0; b < w; b++) {
  329. cout << Matrix[a][b] << ' ';
  330. }
  331. }
  332. }
  333. }
  334. }
  335.  
  336. // Function for mouse input
  337. void mouse_callback(GLFWwindow * window, double xpos, double ypos)
  338. {
  339.  
  340. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement