選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

238 行
11KB

  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>
  11. <strong id="title">Open Game Studio</strong>
  12. <div id="lang">
  13. <a href="../../en/news/2016-august-recap.html">EN</a>
  14. <a href="../../ru/news/2016-august-recap.html">RU</a>
  15. </div>
  16. </div>
  17. <div class="header2">
  18. <div class="menu">
  19. <a href="../../ru/news/index.html">Новости</a>
  20. <a href="../../ru/game/index.html">Игры</a>
  21. <a href="../../ru/tool/index.html">Инструменты</a>
  22. <a href="../../ru/page/about.html">О нас</a>
  23. </div>
  24. <a class="discord" href="https://discord.gg/3A6THQabNf">
  25. <img src="../../images/discord.png"></img>
  26. </a>
  27. <div class="clear"></div>
  28. </div>
  29. </div>
  30. <center>
  31. <h1>В новостях...</h1>
  32. <div class="news_item">
  33. <h2 class="news_item_title">
  34. <a href="2016-august-recap.html">Август 2016 кратко</a>
  35. </h2>
  36. <p class="news_item_date">
  37. 2016-09-03 00:00
  38. </p>
  39. <div class="news_item_contents">
  40. <p><img src="../../images/2016-09-03_august-recap.png" alt="Редактор со сферическим узлом сцены" /></p>
  41. <p>Эта статья описывает самые важные технические детали разработки за август: модуль UIQt, его переработку, новый подход к разработке на основе функционала и его преимущества.</p>
  42. <p><strong>Модуль UIQt</strong> - это коллекция компонент UI на основе Qt. Сейчас используем лишь для интерфейса редактора.</p>
  43. <p>Список компонент модуля UIQt с описанием и размером кода:<table>
  44. <tr>
  45. <th><strong>№</strong></th>
  46. <th><strong>Компонента</strong></th>
  47. <th><strong>Описание</strong></th>
  48. <th><strong>Размер (Б)</strong></th>
  49. <th><strong>Размер (%)</strong></th>
  50. </tr>
  51. <tr>
  52. <td>1</td>
  53. <td>UIQtAction</td>
  54. <td>Действия (события) для меню</td>
  55. <td>11224</td>
  56. <td>9</td>
  57. </tr>
  58. <tr>
  59. <td>2</td>
  60. <td>UIQtAux</td>
  61. <td>Инициализирует Qt и главное окно. Предоставляет поиск виджета по имени для других компонент</td>
  62. <td>15518</td>
  63. <td>12</td>
  64. </tr>
  65. <tr>
  66. <td>3</td>
  67. <td>UIQtDock</td>
  68. <td>Виджет стыковки</td>
  69. <td>5273</td>
  70. <td>4</td>
  71. </tr>
  72. <tr>
  73. <td>4</td>
  74. <td>UIQtFileDialog</td>
  75. <td>Диалог выбора файла</td>
  76. <td>8960</td>
  77. <td>7</td>
  78. </tr>
  79. <tr>
  80. <td>5</td>
  81. <td>UIQtMenu</td>
  82. <td>Меню для главного окна и на ПКМ (вроде меню по добавлению/копированию/вставке/удалению узла)</td>
  83. <td>4566</td>
  84. <td>3</td>
  85. </tr>
  86. <tr>
  87. <td>6</td>
  88. <td>UIQtMenuBar</td>
  89. <td>Панель меню для главного окна</td>
  90. <td>4222</td>
  91. <td>3</td>
  92. </tr>
  93. <tr>
  94. <td>7</td>
  95. <td>UIQtRunner</td>
  96. <td>Позволяет запустить QApplication</td>
  97. <td>2450</td>
  98. <td>2</td>
  99. </tr>
  100. <tr>
  101. <td>8</td>
  102. <td>UIQtThumbnailDialog</td>
  103. <td>Диалог с изображениями</td>
  104. <td>18615</td>
  105. <td>14</td>
  106. </tr>
  107. <tr>
  108. <td>9</td>
  109. <td>UIQtToolBar</td>
  110. <td>Панель инструментов для главого окна</td>
  111. <td>4276</td>
  112. <td>3</td>
  113. </tr>
  114. <tr>
  115. <td>10</td>
  116. <td>UIQtTree</td>
  117. <td>Предоставляет сложные виджеты вроде Дерева сцены и Редактора свойств</td>
  118. <td>51216</td>
  119. <td>39</td>
  120. </tr>
  121. <tr>
  122. <td>11</td>
  123. <td>UIQtWidget</td>
  124. <td>Общие свойства виджетов вроде фокуса и видимости</td>
  125. <td>5465</td>
  126. <td>4</td>
  127. </tr>
  128. </table></p>
  129. <p><strong>Мы переработали модуль UIQt</strong> для замены старого State API на новый Environment API, который позволяет делать то же самое лаконичнее, т.е. упрощает и ускоряет разработку.</p>
  130. <p>Переработку начали в июле и должны были закончить в том же месяце. Тем не менеe, работы завершили лишь в августе. Начальный план предполагал, что 28 часов должно хватить, но мы потратили 65. Мы оценивали необходимое время на основе количества вызовов публичного API каждой компоненты. Это хорошо сработало для небольших компонент, т.к. число вызовов их публичного API было примерно равно количеству их функционала, а сам функционал был очень маленький. Однако такой подход полностью провалился для компонеты UIQtTree, составляющей 39% кода модуля UIQt, потому что не было прямой связи между публичным API и функционалом.</p>
  131. <p><strong>Новый подход к разработке на основе функционала</strong> родился после решения проблем с переработкой UIQtTree. Т.к. Qt использует MVC, компонента UIQtTree состоит из нескольких классов. К тому моменту, когда UIQtTree могла отображать и управлять иерархией элементов, компонента уже имела размер в 27К. Мы заметили, что UIQtTree стала потреблять непомерное количество времени разработки даже для мелкого функционала. Это было явным проявлением <a href="http://rsdn.org/article/philosophy/Complexity.xml">количественной сложности</a>.</p>
  132. <p>Мы решили разбить UIQtTree на базовую часть и дополнительные. База содержит лишь необходимый минимум кода. Дополнение содержит код, специфичный для данного функционала, и может быть безболезненно изменено. В случае UIQtTree, отображение и управление иерархией элементов - это минимальный функционал, а переименование элементов - это дополнение.</p>
  133. <p>Текущий функционал UIQtTree состоит из следующих возможностей:</p>
  134. <table>
  135. <tr>
  136. <th>**№**</th>
  137. <th>**Функционал**</th>
  138. <th>**Описание**</th>
  139. <th>**Размер (Б)**</th>
  140. <th>**Размер (%)**</th>
  141. </tr>
  142. <tr>
  143. <td>1</td>
  144. <td>Base</td>
  145. <td>Создание, изменение, отображение иерархии элементов</td>
  146. <td>26966</td>
  147. <td>52</td>
  148. </tr>
  149. <tr>
  150. <td>2</td>
  151. <td>Item open state</td>
  152. <td>Хранит состояние свойства скрыто/отображено элемента</td>
  153. <td>3094</td>
  154. <td>6</td>
  155. </tr>
  156. <tr>
  157. <td>3</td>
  158. <td>Item renaming</td>
  159. <td>Переименование элемента</td>
  160. <td>3471</td>
  161. <td>7</td>
  162. </tr>
  163. <tr>
  164. <td>4</td>
  165. <td>Item selection</td>
  166. <td>Получение/установка выбранного элемента</td>
  167. <td>2338</td>
  168. <td>5</td>
  169. </tr>
  170. <tr>
  171. <td>5</td>
  172. <td>Item value</td>
  173. <td>Предоставляет второй и последующие столбцы для элементов, используется Редактором свойств</td>
  174. <td>1307</td>
  175. <td>3</td>
  176. </tr>
  177. <tr>
  178. <td>6</td>
  179. <td>Item value editing</td>
  180. <td>Редактирование значений элемента с помощью стандартного виджета</td>
  181. <td>1996</td>
  182. <td>4</td>
  183. </tr>
  184. <tr>
  185. <td>7</td>
  186. <td>Item value editing with combobox</td>
  187. <td>Редактирование значений элемента с помощью виджета combobox</td>
  188. <td>5819</td>
  189. <td>11</td>
  190. </tr>
  191. <tr>
  192. <td>8</td>
  193. <td>Item value editing with spinner</td>
  194. <td>Редактирование значений элемента с помощью виджета spinbox</td>
  195. <td>5290</td>
  196. <td>10</td>
  197. </tr>
  198. <tr>
  199. <td>9</td>
  200. <td>Menu</td>
  201. <td>Меню на ПКМ</td>
  202. <td>1248</td>
  203. <td>2</td>
  204. </tr>
  205. </table>
  206. <p>Пример файла функционала Menu для UIQtTree: <a href="https://bitbucket.org/ogstudio-history/mjin-pre-pre/src/0c4cc3c3213f4687c0f3bd6a5426a6054cadd79b/f/TREE_MENU.cpp?at=Studio+0.10&fileviewer=file-view-default">TREE_MENU</a>.</p>
  207. <p><strong>Преимущества подхода:</strong></p>
  208. <ol>
  209. <li>Более быстрое чтение/понимание благодаря небольшому размеру</li>
  210. <li>Более простое и безболезненное изменение благодаря изолированному коду</li>
  211. </ol>
  212. <p>Есть и недостаток: новый подход требует изучения.</p>
  213. <p>На этом мы заканчиваем описание самых важных технических деталей разработки за август: модуль UIQt, его переработку, новый подход к разработке на основе функционала и его преимущества.</p>
  214. </div>
  215. </div>
  216. <div id="disqus_thread"></div>
  217. <script>
  218. var disqus_config = function () {
  219. this.page.url = "https://opengamestudio.org/ru/news/2016-august-recap.html";
  220. this.page.identifier = "2016-august-recap.html";
  221. };
  222. (function() { // DON'T EDIT BELOW THIS LINE
  223. var d = document, s = d.createElement('script');
  224. s.src = 'https://opengamestudio.disqus.com/embed.js';
  225. s.setAttribute('data-timestamp', +new Date());
  226. (d.head || d.body).appendChild(s);
  227. })();
  228. </script>
  229. <noscript>Пожалуйста, включите JavaScript для просмотра <a href="https://disqus.com/?ref_noscript">комментариев на платформе Disqus.</a></noscript>
  230. <div id="footer">
  231. Сайт сгенерирован <a href="http://opengamestudio.org/pskov/ru">ПСКОВОМ</a>
  232. из <a href="http://github.com/ogstudio/site-opengamestudio">этого исходного кода</a>.
  233. Сайт размещён на <a href="https://pages.github.com">GitHub Pages</a>.
  234. </div>
  235. </center>
  236. </body>
  237. </html>