Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

110 строки
2.8 KiB

  1. //
  2. // Lol Engine — Sprite tutorial
  3. //
  4. // Copyright © 2011—2019 Sam Hocevar <sam@hocevar.net>
  5. // © 2012 Daniel Stephens (artwork)
  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. using namespace lol;
  18. class SpriteTutorial : public WorldEntity
  19. {
  20. public:
  21. SpriteTutorial()
  22. {
  23. m_camera = new Camera();
  24. m_camera->SetView(mat4(1.f));
  25. m_camera->SetProjection(mat4::ortho(0.f, 640.f, 0.f, 480.f, -100.f, 100.f));
  26. Scene& scene = Scene::GetScene();
  27. scene.PushCamera(m_camera);
  28. Ticker::Ref(m_camera);
  29. m_tileset = TileSet::create("06_sprite.png");
  30. for (int i = 0; i < FRAME_COUNT; ++i)
  31. m_tileset->define_tile(ibox2(i * 24, 376, 24 + i * 24, 24 + 376));
  32. for (int i = 0; i < SPRITE_COUNT; ++i)
  33. {
  34. m_sprites.push(vec3((float)rand(-96, 640), (float)rand(-96, 480), 0.f),
  35. rand(0.f, 1.f));
  36. }
  37. m_ready = false;
  38. }
  39. ~SpriteTutorial()
  40. {
  41. TileSet::destroy(m_tileset);
  42. Scene& scene = Scene::GetScene();
  43. scene.PopCamera(m_camera);
  44. Ticker::Unref(m_camera);
  45. }
  46. virtual void tick_game(float seconds)
  47. {
  48. for (int i = 0; i < SPRITE_COUNT; ++i)
  49. {
  50. m_sprites[i].m1.y += 50.f * seconds;
  51. m_sprites[i].m2 = lol::fmod(m_sprites[i].m2 + seconds, 1.f);
  52. if (m_sprites[i].m1.y > 480 + 48)
  53. m_sprites[i].m1.y = (float)rand(-96, -48);
  54. }
  55. WorldEntity::tick_game(seconds);
  56. }
  57. virtual void tick_draw(float seconds, Scene &scene)
  58. {
  59. WorldEntity::tick_draw(seconds, scene);
  60. if (!m_ready)
  61. {
  62. scene.get_renderer()->SetClearColor(vec4(0.0f, 0.0f, 0.0f, 1.0f));
  63. m_ready = true;
  64. }
  65. for (int i = 0; i < SPRITE_COUNT; ++i)
  66. {
  67. int frame = (int)(m_sprites[i].m2 * FRAME_COUNT);
  68. // m_sprites[i].m1.z = frame;
  69. scene.AddTile(m_tileset, frame,
  70. m_sprites[i].m1, vec2(2.f), 0.f);
  71. }
  72. }
  73. private:
  74. Camera *m_camera;
  75. TileSet *m_tileset;
  76. static int const SPRITE_COUNT = 192;
  77. static int const FRAME_COUNT = 16;
  78. array<vec3, float> m_sprites;
  79. bool m_ready;
  80. };
  81. int main(int argc, char **argv)
  82. {
  83. sys::init(argc, argv);
  84. Application app("Tutorial 6: Sprite", ivec2(640, 480), 60.0f);
  85. new SpriteTutorial();
  86. app.Run();
  87. return EXIT_SUCCESS;
  88. }