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.

mahjong-recreation-start.html 8.9KB

2 months ago
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. <!DOCTYPE html>
  2. <html>
  3. <meta charset="utf-8">
  4. <head>
  5. <link rel="stylesheet" href="../../style.css">
  6. </head>
  7. <body>
  8. <script data-goatcounter="https://services.opengamestudio.org:443/count" async src="//services.opengamestudio.org:443/count.js"></script>
  9. <div id="header">
  10. <div class="header2">
  11. <div class="menu">
  12. <a href="../../ru/news/index.html">Новости</a>
  13. <a href="../../ru/game/index.html">Игры</a>
  14. <a href="../../ru/tool/index.html">Инструменты</a>
  15. <a href="../../ru/page/about.html">О нас</a>
  16. </div>
  17. <div id="lang">
  18. <a href="../../en/news/mahjong-recreation-start.html">EN</a>
  19. <a href="../../ru/news/mahjong-recreation-start.html">RU</a>
  20. </div>
  21. <div class="clear"></div>
  22. </div>
  23. </div>
  24. <h3 class="left_item_title">В новостях...</h3>
  25. <center>
  26. <div class="news_item">
  27. <h2 class="news_item_title">
  28. <a href="mahjong-recreation-start.html">Начало воссоздания Маджонга</a>
  29. </h2>
  30. <p class="news_item_date">
  31. 2018-01-26 00:00
  32. </p>
  33. <div class="news_item_contents">
  34. <p><img src="../../images/2018-01-26-mahjong-recreation-start.png" alt="Сферические фишки в раскладке Маджонг" /></p>
  35. <p>Эта статья описывает начало воссоздания игры Маджонг.</p>
  36. <p><strong>План</strong></p>
  37. <p>Мы начали воссоздание Маджонга с составления краткого плана реализации игровой механики с минимальной графикой:</p>
  38. <ul>
  39. <li>Загрузить раскладку</li>
  40. <li>Поместить фишки в позиции раскладки</li>
  41. <li>Различить фишки</li>
  42. <li>Реализовать выбор фишек</li>
  43. <li>Реализовать сравнение фишек</li>
  44. </ul>
  45. <p>Как и любой другой план, этот выглядел вполне адекватно на первый взгляд. Тем не менее стоит начать разработку, как появляются новые детали. Этот план не был исключением. Ниже представлена пара проблем, вскрывшихся во время разработки.</p>
  46. <p><strong>Проблема №1: предоставить бинарные ресурсы на поддерживаемых платформах</strong></p>
  47. <p>Маджонг будет доступен для десктопа, мобилок и веба. Каждая платформа имеет ограничения на доступ к внешним файлам:</p>
  48. <ul>
  49. <li>Десктоп позволяет получить доступ почти к любому файлу</li>
  50. <li>Мобилки имеют ограниченный доступ к файловой системе</li>
  51. <li>Веб не имеет файловой системы</li>
  52. </ul>
  53. <p>Мы решили сделать единый способ доступа к ресурсам путём их встраивания в исполняемый файл. Это решение привело к рождению проектов <strong>mjin-resource</strong> и <strong>mahjong-data</strong>.</p>
  54. <p>Проект <a href="https://bitbucket.org/ogstudio/mjin-resource">mjin-resource</a> служит для:</p>
  55. <ul>
  56. <li>перевода бинарных файлов в заголовочные файлы C с помощью утилиты <strong>xxd</strong></li>
  57. <li>создания проекта MJIN, состоящего из сгенерированных заголовочных файлов, который собирается в статическую библиотеку</li>
  58. <li>предоставления интерфейса C++ для работы с ресурсами</li>
  59. </ul>
  60. <p>Проект <a href="https://bitbucket.org/ogstudio-games/mahjong-data">mahjong-data</a> является примером подобного проекта MJIN, ресурсы из которого использует проект <a href="https://bitbucket.org/ogstudio-games/ogs-mahjong">mahjong</a>.</p>
  61. <p><strong>Проблема №2: загрузка изображений PNG на поддерживаемых платформах</strong></p>
  62. <p>Для загрузки PNG мы используем соответствующий плагин OpenSceneGraph. Мы собрали его без проблем для десктопа. Сборка же для веба (Emscripten) оказалась сложнее: Emscripten содержит собственную версию <strong>libpng</strong>, которую сборочный скрипт OpenSceneGraph не видит. Нам пришлось обойти несколько проверок OpenSceneGraph, чтобы успешно собрать плагин для Emscripten.
  63. Сборка плагина под мобилки ещё ждёт нас впереди. Как только мы разберёмся с плагином PNG на всех поддерживаемых платформах, мы опубликуем информацию о его сборке в новом самоучителе для <a href="https://github.com/ogstudio/openscenegraph-cross-platform-guide">кросс-платформенного руководства OpenSceneGraph</a>. Нас уже <a href="https://github.com/OGStudio/openscenegraph-cross-platform-guide/issues/4">попросили это сделать</a>.</p>
  64. <p><strong>Разработка</strong></p>
  65. <p><a href="lets-go.html">Как вы знаете</a>, мы опубликовали кросс-платформенное руководство OpenSceneGraph для усиления сообщества OpenSceneGraph. Мы ценим обучение и любим делиться своими знаниями. Поэтому мы решили разрабатывать Маджонг небольшими воспроизводимыми частями, каждая из которых имеет уникальную внутреннюю версию. Эти версии доступны в <a href="https://bitbucket.org/ogstudio-games/ogs-mahjong">хранилище проекта mahjong</a>.</p>
  66. <p>Мы также предоставляем <a href="http://ogstudio.github.io/game-mahjong">историю версий, каждая из которых сопровождается сборкой под веб</a>, для следующих целей:</p>
  67. <ul>
  68. <li>обучение: показать ход разработки изнутри</li>
  69. <li>доступность: предоставить старые версии для сравнения</li>
  70. </ul>
  71. <p><strong>Текущее состояние игры Маджонг</strong></p>
  72. <p>На момент написания этой статьи мы закончили реализацию выбора фишек. <a href="https://ogstudio.github.io/game-mahjong/versions/010/mjin-player.html">Проверьте в своём браузере!</a></p>
  73. <p>После реализации сравнения фишек мы опубликуем промежуточный результат для всех поддерживаемых платформ.</p>
  74. <p>На этом мы заканчиваем описание начала воссоздания игры Маджонг.</p>
  75. </div>
  76. </div>
  77. <div id="disqus_thread"></div>
  78. <script>
  79. var disqus_config = function () {
  80. this.page.url = "https://opengamestudio.org/ru/news/mahjong-recreation-start.html";
  81. this.page.identifier = "mahjong-recreation-start.html";
  82. };
  83. (function() { // DON'T EDIT BELOW THIS LINE
  84. var d = document, s = d.createElement('script');
  85. s.src = 'https://opengamestudio.disqus.com/embed.js';
  86. s.setAttribute('data-timestamp', +new Date());
  87. (d.head || d.body).appendChild(s);
  88. })();
  89. </script>
  90. <noscript>Пожалуйста, включите JavaScript для просмотра <a href="https://disqus.com/?ref_noscript">комментариев на платформе Disqus.</a></noscript>
  91. <div id="footer">
  92. Сайт сгенерирован <a href="http://opengamestudio.org/pskov/ru">ПСКОВОМ</a>
  93. из <a href="http://github.com/ogstudio/site-opengamestudio">этого исходного кода</a>.
  94. </div>
  95. </center>
  96. </body>
  97. </html>