Nelze vybrat více než 25 témat Téma musí začínat písmenem nebo číslem, může obsahovat pomlčky („-“) a může být dlouhé až 35 znaků.
 
 
 

131 řádky
4.9 KiB

  1. //
  2. // Lol Engine - EasyMesh tutorial
  3. //
  4. // Copyright: (c) 2011-2013 Sam Hocevar <sam@hocevar.net>
  5. // (c) 2012-2013 Benjamin "Touky" Huet <huet.benjamin@gmail.com>
  6. // This program is free software; you can redistribute it and/or
  7. // modify it under the terms of the Do What The Fuck You Want To
  8. // Public License, Version 2, as published by Sam Hocevar. See
  9. // http://www.wtfpl.net/ for more details.
  10. //
  11. #if defined HAVE_CONFIG_H
  12. # include "config.h"
  13. #endif
  14. #include "core.h"
  15. using namespace std;
  16. using namespace lol;
  17. class EasyMeshTutorial : public WorldEntity
  18. {
  19. public:
  20. EasyMeshTutorial()
  21. {
  22. m_gears.Push(EasyMesh(), mat4(1.0f), 0.0f);
  23. m_gears.Push(EasyMesh(), mat4(1.0f), 0.0f);
  24. m_gears.Push(EasyMesh(), mat4(1.0f), 180.0f / 18);
  25. m_gears.Push(EasyMesh(), mat4(1.0f), 180.0f / 18);
  26. m_gears.Push(EasyMesh(), mat4(1.0f), 180.0f / 18);
  27. m_gears[0].m1.Compile("[sc#00f ab 8 1 8 ty -.25]\
  28. [sc#f9f scb#f9f acg 12 10 5 5 20 20 5 5 0.1 0 s .1 .1 .1 ty -.1 csgu]\
  29. [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]\
  30. [sc#00f ab 5 3 9 tx 2.5 csgs]\
  31. [[ sc#fff ab 3 1.4 2 tx -2 tz -2 \
  32. [sc#fff ab 2.1 .7 1.1 ty .5 tx -1.4 tz -1.4 csgs] mz] csgu] \
  33. ");
  34. //m_gears[0].m1.Compile("[sc#f9f scb#f9f acg 12 10 5 5 20 20 5 5 0.1 0 s .1 .1 .1 [sc#00f ab 3 1 2 ty .25 tx 1 csgs]]");
  35. 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");
  36. //m_gears[2].m1.Compile("sc#9ff scb#9ff acg 18 10 5 5 30 30 5 5 0.1 0 s .1 .1 .1 [sc#00f scb#00f ab 2 2 2 tx 1.5]");
  37. //m_gears[3].m1.Compile("sc#9ff scb#9ff acg 18 10 5 5 30 30 5 5 0.1 0 s .1 .1 .1 [sc#00f scb#00f ab 2 2 2 tx 1.5]");
  38. //m_gears[4].m1.Compile("sc#9ff scb#9ff acg 18 10 5 5 30 30 5 5 0.1 0 s .1 .1 .1 [sc#00f scb#00f ab 2 2 2 tx 1.5]");
  39. 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]]");
  40. 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]]");
  41. 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]]");
  42. m_angle = 0;
  43. m_camera = new Camera(vec3(0.f, 600.f, 0.f),
  44. vec3(0.f, 0.f, 0.f),
  45. vec3(0, 1, 0));
  46. m_camera->SetPerspective(30.f, 960.f, 600.f, .1f, 1000.f);
  47. m_camera->SetTarget(vec3(0.f, -1.f, 0.f));
  48. m_camera->SetPosition(vec3(-15.f, 5.f, 0.f));
  49. Ticker::Ref(m_camera);
  50. m_ready = false;
  51. }
  52. ~EasyMeshTutorial()
  53. {
  54. Ticker::Unref(m_camera);
  55. }
  56. virtual void TickGame(float seconds)
  57. {
  58. WorldEntity::TickGame(seconds);
  59. m_angle += seconds * 70.0f;
  60. m_mat = mat4::rotate(10.0f, vec3(0, 0, 1))
  61. * mat4::rotate(100, vec3(0, 1, 0));
  62. // * mat4::rotate(m_angle, vec3(0, 1, 0));
  63. m_gears[0].m3 += seconds * 20.0f;
  64. m_gears[1].m3 += seconds * 20.0f * -2 / 9;
  65. m_gears[2].m3 += seconds * 20.0f * -2 / 3;
  66. m_gears[3].m3 += seconds * 20.0f * -2 / 3;
  67. m_gears[4].m3 += seconds * 20.0f * -2 / 3;
  68. m_gears[0].m2 = mat4::translate(vec3(0, -1, 0))
  69. * mat4::rotate(m_gears[0].m3 - 130.0f, vec3(0, 1, 0))
  70. * mat4::rotate(40.0f, vec3(0, 0, 1));
  71. m_gears[1].m2 = mat4::translate(vec3(0, 0, 0))
  72. * mat4::rotate(m_gears[1].m3, vec3(0, 1, 0));
  73. m_gears[2].m2 = mat4::translate(vec3(0, 0, 5.5f))
  74. * mat4::rotate(m_gears[2].m3 - 40.0f, vec3(0, 1, 0))
  75. * mat4::rotate(90.0f, vec3(0, 0, 1));
  76. m_gears[3].m2 = mat4::translate(vec3(5.5f * lol::sqrt(3.f) * 0.5f, 0, -5.5f * 0.5f))
  77. * mat4::rotate(m_gears[3].m3 - 140.0f, vec3(0, 1, 0))
  78. * mat4::rotate(-70.0f, vec3(0, 0, 1));
  79. m_gears[4].m2 = mat4::translate(vec3(-5.5f * lol::sqrt(3.f) * 0.5f, 0, -5.5f * 0.5f))
  80. * mat4::rotate(m_gears[4].m3 - 80.0f, vec3(0, 1, 0));
  81. }
  82. virtual void TickDraw(float seconds)
  83. {
  84. WorldEntity::TickDraw(seconds);
  85. if (!m_ready)
  86. {
  87. for (int i = 0; i < m_gears.Count(); i++)
  88. m_gears[i].m1.MeshConvert();
  89. m_ready = true;
  90. }
  91. Video::SetClearColor(vec4(0.0f, 0.0f, 0.0f, 1.0f));
  92. for (int i = 0; i < m_gears.Count(); i++)
  93. m_gears[i].m1.Render(m_mat * m_gears[i].m2);
  94. }
  95. private:
  96. Array<EasyMesh, mat4, float> m_gears;
  97. float m_angle;
  98. mat4 m_mat;
  99. Camera *m_camera;
  100. bool m_ready;
  101. };
  102. int main(int argc, char **argv)
  103. {
  104. Application app("Tutorial 5: EasyMesh", ivec2(960, 600), 60.0f);
  105. new EasyMeshTutorial();
  106. app.Run();
  107. return EXIT_SUCCESS;
  108. }