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

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. Title: Начало воссоздания Маджонга
  2. Date: 2018-01-26 00:00
  3. Category: News
  4. Slug: mahjong-recreation-start
  5. Lang: ru
  6. ![Screenshot][screenshot]
  7. Эта статья описывает начало воссоздания игры Маджонг.
  8. **План**
  9. Мы начали воссоздание Маджонга с составления краткого плана реализации игровой механики с минимальной графикой:
  10. * Загрузить раскладку
  11. * Поместить фишки в позиции раскладки
  12. * Различить фишки
  13. * Реализовать выбор фишек
  14. * Реализовать сравнение фишек
  15. Как и любой другой план, этот выглядел вполне адекватно на первый взгляд. Тем не менее стоит начать разработку, как появляются новые детали. Этот план не был исключением. Ниже представлена пара проблем, вскрывшихся во время разработки.
  16. **Проблема №1: предоставить бинарные ресурсы на поддерживаемых платформах**
  17. Маджонг будет доступен для десктопа, мобилок и веба. Каждая платформа имеет ограничения на доступ к внешним файлам:
  18. * Десктоп позволяет получить доступ почти к любому файлу
  19. * Мобилки имеют ограниченный доступ к файловой системе
  20. * Веб не имеет файловой системы
  21. Мы решили сделать единый способ доступа к ресурсам путём их встраивания в исполняемый файл. Это решение привело к рождению проектов **mjin-resource** и **mahjong-data**.
  22. Проект [mjin-resource][mjin-resource] служит для:
  23. * перевода бинарных файлов в заголовочные файлы C с помощью утилиты **xxd**
  24. * создания проекта MJIN, состоящего из сгенерированных заголовочных файлов, который собирается в статическую библиотеку
  25. * предоставления интерфейса C++ для работы с ресурсами
  26. Проект [mahjong-data][mahjong-data] является примером подобного проекта MJIN, ресурсы из которого использует проект [mahjong][mahjong].
  27. **Проблема №2: загрузка изображений PNG на поддерживаемых платформах**
  28. Для загрузки PNG мы используем соответствующий плагин OpenSceneGraph. Мы собрали его без проблем для десктопа. Сборка же для веба (Emscripten) оказалась сложнее: Emscripten содержит собственную версию **libpng**, которую сборочный скрипт OpenSceneGraph не видит. Нам пришлось обойти несколько проверок OpenSceneGraph, чтобы успешно собрать плагин для Emscripten.
  29. Сборка плагина под мобилки ещё ждёт нас впереди. Как только мы разберёмся с плагином PNG на всех поддерживаемых платформах, мы опубликуем информацию о его сборке в новом самоучителе для [кросс-платформенного руководства OpenSceneGraph][osgcp_guide]. Нас уже [попросили это сделать][img_loading_issue].
  30. **Разработка**
  31. [Как вы знаете][lets-go], мы опубликовали кросс-платформенное руководство OpenSceneGraph для усиления сообщества OpenSceneGraph. Мы ценим обучение и любим делиться своими знаниями. Поэтому мы решили разрабатывать Маджонг небольшими воспроизводимыми частями, каждая из которых имеет уникальную внутреннюю версию. Эти версии доступны в [хранилище проекта mahjong][mahjong].
  32. Мы также предоставляем [историю версий, каждая из которых сопровождается сборкой под веб][web-releases], для следующих целей:
  33. * обучение: показать ход разработки изнутри
  34. * доступность: предоставить старые версии для сравнения
  35. **Текущее состояние игры Маджонг**
  36. На момент написания этой статьи мы закончили реализацию выбора фишек. [Проверьте в своём браузере!][mahjong-version-tile-selection]
  37. После реализации сравнения фишек мы опубликуем промежуточный результат для всех поддерживаемых платформ.
  38. На этом мы заканчиваем описание начала воссоздания игры Маджонг.
  39. [screenshot]: {attach}/images/2018-01-26-mahjong-recreation-start.png
  40. [mjin-resource]: https://bitbucket.org/ogstudio/mjin-resource
  41. [mahjong]: https://bitbucket.org/ogstudio-games/mahjong
  42. [mahjong-data]: https://bitbucket.org/ogstudio-games/mahjong-data
  43. [osgcp_guide]: https://github.com/ogstudio/openscenegraph-cross-platform-guide
  44. [img_loading_issue]: https://github.com/OGStudio/openscenegraph-cross-platform-guide/issues/4
  45. [lets-go]: {filename}/articles/2017-03-16_lets-go-ru.md
  46. [web-releases]: http://ogstudio.github.io/game-mahjong
  47. [mahjong-version-tile-selection]: https://ogstudio.github.io/game-mahjong/versions/010/mjin-player.html