Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

177 lignes
6.4 KiB

  1. //
  2. // Lol Engine — EasyMesh tutorial
  3. //
  4. // Copyright © 2011—2019 Sam Hocevar <sam@hocevar.net>
  5. // © 2012—2013 Benjamin “Touky” Huet <huet.benjamin@gmail.com>
  6. //
  7. // Lol Engine is free software. It comes without any warranty, to
  8. // the extent permitted by applicable law. You can redistribute it
  9. // and/or modify it under the terms of the Do What the Fuck You Want
  10. // to Public License, Version 2, as published by the WTFPL Task Force.
  11. // See http://www.wtfpl.net/ for more details.
  12. //
  13. #if HAVE_CONFIG_H
  14. # include "config.h"
  15. #endif
  16. #include <lol/engine.h>
  17. #include <lol/lua.h>
  18. using namespace lol;
  19. #define USE_CUSTOM_SHADER 1
  20. #if USE_CUSTOM_SHADER
  21. LOLFX_RESOURCE_DECLARE(easymesh_shiny);
  22. #endif //USE_CUSTOM_SHADER
  23. class EasyMeshTutorial : public WorldEntity
  24. {
  25. public:
  26. EasyMeshTutorial()
  27. {
  28. EasyMeshLuaLoader EzMhLoader;
  29. EzMhLoader.ExecLuaFile("05_easymesh.lua");
  30. EasyMeshLuaObject* gears0 = EzMhLoader.GetPtr<EasyMeshLuaObject>("g0");
  31. EasyMeshLuaObject* gears1 = EzMhLoader.GetPtr<EasyMeshLuaObject>("g1");
  32. EasyMeshLuaObject* gears2 = EzMhLoader.GetPtr<EasyMeshLuaObject>("g2");
  33. EasyMeshLuaObject* gears3 = EzMhLoader.GetPtr<EasyMeshLuaObject>("g3");
  34. EasyMeshLuaObject* gears4 = EzMhLoader.GetPtr<EasyMeshLuaObject>("g4");
  35. m_gears.push(gears0->GetMesh(), mat4(1.0f), 0.0f);
  36. m_gears.push(gears1->GetMesh(), mat4(1.0f), 0.0f);
  37. m_gears.push(gears2->GetMesh(), mat4(1.0f), 180.0f / 18);
  38. m_gears.push(gears3->GetMesh(), mat4(1.0f), 180.0f / 18);
  39. m_gears.push(gears4->GetMesh(), mat4(1.0f), 180.0f / 18);
  40. /*
  41. m_gears[0].m1.Compile("[sc#00f ab 8 1 8 ty -.25]"
  42. "[sc#f9f scb#f9f acg 12 10 5 5 20 20 5 5 0.1 0 s .1 .1 .1 ty -.1 csgu]"
  43. "[sc#fff scb#000 acg 12 10 10 10 20 20 5 5 0.1 0 s .05 .05 .05 tx -1.5 ty .3 csgu]"
  44. "[sc#00f ab 5 3 9 tx 2.5 csgs]"
  45. "[[ sc#fff ab 3 1.4 2 tx -2 tz -2 "
  46. "[sc#fff ab 2.1 .7 1.1 ty .5 tx -1.4 tz -1.4 csgs] mz] csgu]");
  47. m_gears[1].m1.Compile("sc#ff9 scb#ff9 acg 54 10 95 95 90 90 -5 -5 0.1 0 s .1 .1 .1");
  48. m_gears[2].m1.Compile("[sc#0f0 ab 2 2 2 t .8 .8 .8 rx 20 ry 20 [sc#00f ab 2 2 2 tx 0 csgu]]");
  49. m_gears[3].m1.Compile("[sc#0f0 ab 2 2 2 t .8 .8 .8 rx 20 ry 20 [sc#00f ab 2 2 2 tx 0 csgs]]");
  50. m_gears[4].m1.Compile("[sc#0f0 ab 2 2 2 t .8 .8 .8 rx 20 ry 20 [sc#00f ab 2 2 2 tx 0 csga]]");
  51. */
  52. m_angle = 0;
  53. m_camera = new Camera();
  54. m_camera->SetProjection(mat4::perspective(radians(30.f), 960.f, 600.f, .1f, 1000.f));
  55. m_camera->SetView(mat4::lookat(vec3(-15.f, 5.f, 0.f),
  56. vec3(0.f, -1.f, 0.f),
  57. vec3(0.f, 1.f, 0.f)));
  58. /* Add a white directional light */
  59. m_light1 = new Light();
  60. m_light1->SetPosition(vec3(0.2f, 0.2f, 0.f));
  61. m_light1->SetColor(vec4(0.5f, 0.5f, 0.5f, 1.f));
  62. m_light1->SetType(LightType::Directional);
  63. Ticker::Ref(m_light1);
  64. /* Add an orangeish point light */
  65. m_light2 = new Light();
  66. m_light2->SetPosition(vec3(-15.f, 15.f, 15.f));
  67. m_light2->SetColor(vec4(0.4f, 0.3f, 0.2f, 1.f));
  68. m_light2->SetType(LightType::Point);
  69. Ticker::Ref(m_light2);
  70. }
  71. ~EasyMeshTutorial()
  72. {
  73. Ticker::Unref(m_light1);
  74. Ticker::Unref(m_light2);
  75. }
  76. virtual void tick_game(float seconds) override
  77. {
  78. WorldEntity::tick_game(seconds);
  79. m_angle += seconds * radians(70.0f);
  80. m_mat = mat4::rotate(radians(10.0f), vec3(0, 0, 1))
  81. * mat4::rotate(radians(100.f), vec3(0, 1, 0));
  82. // * mat4::rotate(m_angle, vec3(0, 1, 0));
  83. m_gears[0].m3 += seconds * radians(20.0f);
  84. m_gears[1].m3 += seconds * radians(20.0f) * -2 / 9;
  85. m_gears[2].m3 += seconds * radians(20.0f) * -2 / 3;
  86. m_gears[3].m3 += seconds * radians(20.0f) * -2 / 3;
  87. m_gears[4].m3 += seconds * radians(20.0f) * -2 / 3;
  88. m_gears[0].m2 = mat4::translate(vec3(0, -1, 0))
  89. * mat4::rotate(m_gears[0].m3 - 130.0f, vec3(0, 1, 0))
  90. * mat4::rotate(40.0f, vec3(0, 0, 1));
  91. m_gears[1].m2 = mat4::translate(vec3(0, 0, 0))
  92. * mat4::rotate(m_gears[1].m3, vec3(0, 1, 0));
  93. m_gears[2].m2 = mat4::translate(vec3(0, 0, 5.5f))
  94. * mat4::rotate(m_gears[2].m3 - 40.0f, vec3(0, 1, 0))
  95. * mat4::rotate(90.0f, vec3(0, 0, 1));
  96. m_gears[3].m2 = mat4::translate(vec3(5.5f * lol::sqrt(3.f) * 0.5f, 0, -5.5f * 0.5f))
  97. * mat4::rotate(m_gears[3].m3 - 140.0f, vec3(0, 1, 0))
  98. * mat4::rotate(-70.0f, vec3(0, 0, 1));
  99. m_gears[4].m2 = mat4::translate(vec3(-5.5f * lol::sqrt(3.f) * 0.5f, 0, -5.5f * 0.5f))
  100. * mat4::rotate(m_gears[4].m3 - 80.0f, vec3(0, 1, 0));
  101. }
  102. virtual bool init_draw() override
  103. {
  104. Scene& scene = Scene::GetScene();
  105. scene.PushCamera(m_camera);
  106. scene.get_renderer()->clear_color(vec4(0.0f, 0.0f, 0.0f, 1.0f));
  107. /* Upload vertex data to GPU */
  108. for (int i = 0; i < m_gears.count(); i++)
  109. m_gears[i].m1.MeshConvert();
  110. #if USE_CUSTOM_SHADER
  111. /* Custom Shader: Init the shader */
  112. auto custom_shader = Shader::Create(LOLFX_RESOURCE_NAME(easymesh_shiny));
  113. // any other shader stuf here (Get uniform, mostly, and set texture)
  114. for (int i = 0; i < m_gears.count(); i++)
  115. m_gears[i].m1.SetMaterial(custom_shader);
  116. #endif
  117. return true;
  118. }
  119. virtual void tick_draw(float seconds, Scene &scene) override
  120. {
  121. WorldEntity::tick_draw(seconds, scene);
  122. for (int i = 0; i < m_gears.count(); i++)
  123. m_gears[i].m1.Render(scene, m_mat * m_gears[i].m2);
  124. }
  125. virtual bool release_draw() override
  126. {
  127. Scene& scene = Scene::GetScene();
  128. scene.PopCamera(m_camera);
  129. m_gears.resize(0);
  130. return true;
  131. }
  132. private:
  133. array<EasyMesh, mat4, float> m_gears;
  134. float m_angle;
  135. mat4 m_mat;
  136. Camera *m_camera;
  137. Light *m_light1, *m_light2;
  138. };
  139. int main(int argc, char **argv)
  140. {
  141. sys::init(argc, argv);
  142. Application app("Tutorial 5: EasyMesh", ivec2(960, 600), 60.0f);
  143. new EasyMeshTutorial();
  144. app.Run();
  145. return EXIT_SUCCESS;
  146. }