You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

205 lines
6.4 KiB

5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
  1. #include <windows.h>
  2. #include "glew.h"
  3. #include "Glm/glm.hpp"
  4. #include "Glm/ext.hpp"
  5. #include <stdio.h>
  6. #include "misc.h"
  7. #include "model.h"
  8. #pragma comment(lib,"opengl32.lib")
  9. #pragma comment(lib, "glew32.lib")
  10. /**
  11. * @hwnd ϢĴ
  12. * @msg Ϣ
  13. */
  14. LRESULT CALLBACK GLWindowProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam) {
  15. switch (msg) {
  16. case WM_CLOSE:
  17. PostQuitMessage(0);
  18. return 0;
  19. }
  20. return DefWindowProc(hwnd, msg, wParam, lParam);//������Ϣ����windowĬ�ϴ�������
  21. }
  22. /**
  23. * @hinstance Ӧóʵ
  24. * @hPrevInstance һӦóʽʵ
  25. * @IpCmdLine еIJ
  26. * @ShowCmd ôʾ
  27. */
  28. INT WINAPI WinMain(HINSTANCE hinstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nShowCmd)
  29. {
  30. /*ע�ᴰ��*/
  31. WNDCLASSEX wndclass;
  32. wndclass.cbClsExtra = 0; //�������͵Ķ����ռ䣬���ﲻ��Ҫ
  33. wndclass.cbSize = sizeof(WNDCLASSEX); //����ʵ��ռ�õ��ڴ�
  34. wndclass.cbWndExtra = 0; //���ڵĶ����ռ䣬���ﲻ��Ҫ
  35. wndclass.hbrBackground = NULL; //���ڱ���
  36. wndclass.hCursor = LoadCursor(NULL, IDC_ARROW); //������������
  37. wndclass.hIcon = NULL; //Ӧ�ó���exe�ļ���ʾͼ��
  38. wndclass.hIconSm = NULL; //Ӧ�ó�������ʱ���Ͻ�ͼ��
  39. wndclass.hInstance = hinstance; //��Ӧ�ó���ʵ��
  40. wndclass.lpfnWndProc = GLWindowProc; //�����û������˴��ڣ��������ᱻ����
  41. wndclass.lpszClassName = L"GLWindow";//��������
  42. wndclass.lpszMenuName = NULL;//�˵�����
  43. wndclass.style = CS_VREDRAW | CS_HREDRAW;//���ڸ���ʱ���ػ淽ʽ������ʹ�ô�ֱ�ػ���ˮƽ�ػ�
  44. ATOM atom = RegisterClassEx(&wndclass);
  45. if (!atom) {
  46. MessageBox(NULL, L"Register failed", L"Error", MB_OK);
  47. return 0;
  48. }
  49. /*��������*/
  50. int windowWidth = 800;
  51. int windowHeight = 600;
  52. //��������һ��Ҫ�͸ղ�ע�ᴰ�ڵı���һ��
  53. HWND hwnd = CreateWindowEx(NULL, L"GLWindow", L"OpenGL Window", WS_OVERLAPPEDWINDOW, 100, 100, windowWidth, windowHeight, NULL, NULL, hinstance, NULL);
  54. //��ȡʵ�ʴ��ڴ�С
  55. RECT rect;
  56. GetClientRect(hwnd, &rect);
  57. windowWidth = rect.right - rect.left;
  58. windowHeight = rect.bottom - rect.top;
  59. //������Ⱦ����
  60. HDC dc = GetDC(hwnd);//��ȡ�豸������
  61. PIXELFORMATDESCRIPTOR pfd;
  62. memset(&pfd, 0, sizeof(PIXELFORMATDESCRIPTOR));
  63. pfd.nVersion = 1;
  64. pfd.nSize = sizeof(PIXELFORMATDESCRIPTOR);
  65. pfd.cColorBits = 32; //��ɫ������ÿ������Ϊ32����4ͨ��RGBA
  66. pfd.cDepthBits = 24; //���Ȼ�����ÿ�����ش�С��24���ر�ʾһ��������
  67. pfd.cStencilBits = 8; //�ɰ建����ÿ����Ϊ8����
  68. pfd.iPixelType = PFD_TYPE_RGBA; //������������ΪRGBA
  69. pfd.dwFlags = PFD_DRAW_TO_WINDOW | PFD_SUPPORT_OPENGL | PFD_DOUBLEBUFFER; //��ʾ������������������
  70. //�������ظ�ʽ
  71. int pixelFormat = ChoosePixelFormat(dc, &pfd);
  72. SetPixelFormat(dc, pixelFormat, &pfd);
  73. //����OpenGL��Ⱦ����
  74. HGLRC rc = wglCreateContext(dc);
  75. wglMakeCurrent(dc, rc);//����OpenGL��Ⱦ������Ч
  76. /*glew��ʼ��*/
  77. glewInit();
  78. /*����program*/
  79. GLuint program = CreateGPUProgram("res/shader/UI.vs", "res/shader/UI.fs");
  80. GLuint posLocation, texcoordLocation, normalLocation, MLocation, VLocation, PLocation, NMLocation, textureLocation;
  81. posLocation = glGetAttribLocation(program, "pos");
  82. texcoordLocation = glGetAttribLocation(program, "texcoord");
  83. normalLocation = glGetAttribLocation(program, "normal");
  84. MLocation = glGetUniformLocation(program, "M");
  85. VLocation = glGetUniformLocation(program, "V");
  86. PLocation = glGetUniformLocation(program, "P");
  87. NMLocation = glGetUniformLocation(program, "NM");
  88. textureLocation = glGetUniformLocation(program, "U_MainTexture");
  89. /*load model*/
  90. unsigned int *indexes = nullptr;
  91. int vertexCount = 0, indexCount = 0;
  92. VertexData* vertexes = LoadObjModel("res/model/Quad.obj", &indexes, vertexCount, indexCount);
  93. if (vertexes == nullptr) {
  94. printf("load obj model fail\n");
  95. }
  96. float z = 4.0f;
  97. float halfFOV = 22.5f;
  98. float randianHalfFOV = 3.14 * halfFOV / 180.0f;//�Ƕ�ת����
  99. float tanHalfFOV = sinf(randianHalfFOV) / cosf(randianHalfFOV);
  100. float y = tanHalfFOV * z;
  101. float aspect = (float)windowWidth / (float)windowHeight;
  102. float x = y * aspect;
  103. vertexes[0].position[0] = -x;
  104. vertexes[0].position[1] = -y;
  105. vertexes[1].position[0] = x;
  106. vertexes[1].position[1] = -y;
  107. vertexes[2].position[0] = -x;
  108. vertexes[2].position[1] = y;
  109. vertexes[3].position[0] = x;
  110. vertexes[3].position[1] = y;
  111. /*����vbo*/
  112. GLuint vbo = CreateBufferObject(GL_ARRAY_BUFFER, sizeof(VertexData) * vertexCount, GL_STATIC_DRAW, vertexes);
  113. /*����IBO*/
  114. GLuint ibo = CreateBufferObject(GL_ELEMENT_ARRAY_BUFFER, sizeof(unsigned int) * indexCount, GL_STATIC_DRAW, indexes);
  115. /*��������*/
  116. GLuint mainTexture = CreateTextureFromFile("res/image/stone.jpg");
  117. GLuint secondTexture = CreateTextureFromDds("res/image/150001.dds");
  118. glClearColor(0.0f, 0.0f, 0.0f, 1.0f);
  119. glEnable(GL_DEPTH_TEST);
  120. glViewport(0,0, windowWidth, windowHeight);
  121. //����һ����λ������һ��ͶӰ���󣬺����������ݵ�shader
  122. float identify[] = {
  123. 1,0,0,0,
  124. 0,1,0,0,
  125. 0,0,1,0,
  126. 0,0,0,1
  127. };
  128. glm::mat4 model = glm::translate(0.0f, 0.0f, -4.0f);
  129. glm::mat4 projection = glm::perspective(45.0f, (float)windowWidth / (float)windowHeight, 0.1f, 1000.0f);
  130. glm::mat4 normalMatrix = glm::inverseTranspose(model);
  131. /*��ʾ����*/
  132. ShowWindow(hwnd, SW_SHOW);
  133. UpdateWindow(hwnd);
  134. /*�����������û�����*/
  135. MSG msg;
  136. while (true) {
  137. if (PeekMessage(&msg, NULL, NULL, NULL, PM_REMOVE)) {
  138. if (msg.message == WM_QUIT) {
  139. break;
  140. }
  141. TranslateMessage(&msg);
  142. DispatchMessage(&msg);
  143. }
  144. glm::mat4 normalMatrix = glm::inverseTranspose(model);
  145. glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
  146. glUseProgram(program);
  147. glUniformMatrix4fv(MLocation, 1, GL_FALSE, glm::value_ptr(model));
  148. glUniformMatrix4fv(VLocation, 1, GL_FALSE, identify);
  149. glUniformMatrix4fv(PLocation, 1, GL_FALSE, glm::value_ptr(projection));
  150. glUniformMatrix4fv(NMLocation, 1, GL_FALSE, glm::value_ptr(normalMatrix));
  151. glBindTexture(GL_TEXTURE_2D, mainTexture);
  152. glUniform1i(textureLocation, 0);
  153. glBindBuffer(GL_ARRAY_BUFFER, vbo);
  154. glEnableVertexAttribArray(posLocation);
  155. glVertexAttribPointer(posLocation, 3, GL_FLOAT, GL_FALSE, sizeof(VertexData), (void*)0);
  156. glEnableVertexAttribArray(texcoordLocation);
  157. glVertexAttribPointer(texcoordLocation, 2, GL_FLOAT, GL_FALSE, sizeof(VertexData), (void*)(sizeof(float) * 3));
  158. glEnableVertexAttribArray(normalLocation);
  159. glVertexAttribPointer(normalLocation, 3, GL_FLOAT, GL_FALSE, sizeof(VertexData), (void*)(sizeof(float) * 5));
  160. glBindBuffer(GL_ARRAY_BUFFER, 0);
  161. glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, ibo);
  162. glDrawElements(GL_TRIANGLES, indexCount, GL_UNSIGNED_INT, 0);
  163. glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, 0);
  164. glUseProgram(0);
  165. SwapBuffers(dc);
  166. }
  167. return 0;
  168. }