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.

295 lines
12KB

  1. <!DOCTYPE html>
  2. <html>
  3. <meta charset="utf-8">
  4. <head>
  5. <style>
  6. #header
  7. {
  8. background: #2BA6E3;
  9. padding: 0.7em;
  10. text-align: left;
  11. }
  12. #header a
  13. {
  14. color: white;
  15. text-decoration: none;
  16. padding: 0.5em 1em 0.5em 1em;
  17. }
  18. #lang
  19. {
  20. float: right;
  21. }
  22. .news_item
  23. {
  24. background: #FFFFFF;
  25. width: 720px;
  26. padding: 1em;
  27. margin-top: 2em;
  28. margin-bottom: 2em;
  29. border: 1px solid #E0E0E0;
  30. text-align: left;
  31. }
  32. .news_item_contents
  33. {
  34. color: #444;
  35. line-height: 1.5em;
  36. }
  37. .news_item_date
  38. {
  39. margin-bottom: 2em;
  40. color: #aaa;
  41. }
  42. html
  43. {
  44. font-family: sans-serif;
  45. }
  46. body
  47. {
  48. background: #FAFAFA;
  49. }
  50. code, pre
  51. {
  52. font-family: monospace, serif;
  53. font-size: 1em;
  54. color: #7f0a0c;
  55. }
  56. /*
  57. figure
  58. {
  59. margin: 0px;
  60. padding: 0px;
  61. }
  62. */
  63. img
  64. {
  65. width: 720px;
  66. }
  67. a
  68. {
  69. color: #3A91CB;
  70. }
  71. table
  72. {
  73. border-collapse: collapse;
  74. }
  75. table, th, td
  76. {
  77. border: 1px solid #aaa;
  78. padding: 0.5em;
  79. margin-top: 0.5em;
  80. margin-bottom: 0.5em;
  81. }
  82. </style>
  83. </head>
  84. <body>
  85. <script data-goatcounter="https://services.opengamestudio.org:443/count" async src="//services.opengamestudio.org:443/count.js"></script>
  86. <div id="header">
  87. <strong id="title">Open Game Studio</strong>
  88. <a href="../../ru/news/index.html">Новости</a>
  89. <a href="../../ru/game/index.html">Игры</a>
  90. <a href="../../ru/tool/index.html">Инструменты</a>
  91. <a href="../../ru/page/about.html">О нас</a>
  92. <div id="lang">
  93. <a href="../../en/news/2016-august-recap.html">EN</a>
  94. <a href="../../ru/news/2016-august-recap.html">RU</a>
  95. </div>
  96. </div>
  97. <center>
  98. <h1>В новостях...</h1>
  99. <div class="news_item">
  100. <h2 class="news_item_title">
  101. <a href="2016-august-recap.html">Август 2016 кратко</a>
  102. </h2>
  103. <p class="news_item_date">
  104. 2016-09-03 00:00
  105. </p>
  106. <div class="news_item_contents">
  107. <p><img src="../../images/2016-09-03_august-recap.png" alt="Редактор со сферическим узлом сцены" /></p>
  108. <p>Эта статья описывает самые важные технические детали разработки за август: модуль UIQt, его переработку, новый подход к разработке на основе функционала и его преимущества.</p>
  109. <p><strong>Модуль UIQt</strong> - это коллекция компонент UI на основе Qt. Сейчас используем лишь для интерфейса редактора.</p>
  110. <p>Список компонент модуля UIQt с описанием и размером кода:<table>
  111. <tr>
  112. <th><strong>№</strong></th>
  113. <th><strong>Компонента</strong></th>
  114. <th><strong>Описание</strong></th>
  115. <th><strong>Размер (Б)</strong></th>
  116. <th><strong>Размер (%)</strong></th>
  117. </tr>
  118. <tr>
  119. <td>1</td>
  120. <td>UIQtAction</td>
  121. <td>Действия (события) для меню</td>
  122. <td>11224</td>
  123. <td>9</td>
  124. </tr>
  125. <tr>
  126. <td>2</td>
  127. <td>UIQtAux</td>
  128. <td>Инициализирует Qt и главное окно. Предоставляет поиск виджета по имени для других компонент</td>
  129. <td>15518</td>
  130. <td>12</td>
  131. </tr>
  132. <tr>
  133. <td>3</td>
  134. <td>UIQtDock</td>
  135. <td>Виджет стыковки</td>
  136. <td>5273</td>
  137. <td>4</td>
  138. </tr>
  139. <tr>
  140. <td>4</td>
  141. <td>UIQtFileDialog</td>
  142. <td>Диалог выбора файла</td>
  143. <td>8960</td>
  144. <td>7</td>
  145. </tr>
  146. <tr>
  147. <td>5</td>
  148. <td>UIQtMenu</td>
  149. <td>Меню для главного окна и на ПКМ (вроде меню по добавлению/копированию/вставке/удалению узла)</td>
  150. <td>4566</td>
  151. <td>3</td>
  152. </tr>
  153. <tr>
  154. <td>6</td>
  155. <td>UIQtMenuBar</td>
  156. <td>Панель меню для главного окна</td>
  157. <td>4222</td>
  158. <td>3</td>
  159. </tr>
  160. <tr>
  161. <td>7</td>
  162. <td>UIQtRunner</td>
  163. <td>Позволяет запустить QApplication</td>
  164. <td>2450</td>
  165. <td>2</td>
  166. </tr>
  167. <tr>
  168. <td>8</td>
  169. <td>UIQtThumbnailDialog</td>
  170. <td>Диалог с изображениями</td>
  171. <td>18615</td>
  172. <td>14</td>
  173. </tr>
  174. <tr>
  175. <td>9</td>
  176. <td>UIQtToolBar</td>
  177. <td>Панель инструментов для главого окна</td>
  178. <td>4276</td>
  179. <td>3</td>
  180. </tr>
  181. <tr>
  182. <td>10</td>
  183. <td>UIQtTree</td>
  184. <td>Предоставляет сложные виджеты вроде Дерева сцены и Редактора свойств</td>
  185. <td>51216</td>
  186. <td>39</td>
  187. </tr>
  188. <tr>
  189. <td>11</td>
  190. <td>UIQtWidget</td>
  191. <td>Общие свойства виджетов вроде фокуса и видимости</td>
  192. <td>5465</td>
  193. <td>4</td>
  194. </tr>
  195. </table></p>
  196. <p><strong>Мы переработали модуль UIQt</strong> для замены старого State API на новый Environment API, который позволяет делать то же самое лаконичнее, т.е. упрощает и ускоряет разработку.</p>
  197. <p>Переработку начали в июле и должны были закончить в том же месяце. Тем не менеe, работы завершили лишь в августе. Начальный план предполагал, что 28 часов должно хватить, но мы потратили 65. Мы оценивали необходимое время на основе количества вызовов публичного API каждой компоненты. Это хорошо сработало для небольших компонент, т.к. число вызовов их публичного API было примерно равно количеству их функционала, а сам функционал был очень маленький. Однако такой подход полностью провалился для компонеты UIQtTree, составляющей 39% кода модуля UIQt, потому что не было прямой связи между публичным API и функционалом.</p>
  198. <p><strong>Новый подход к разработке на основе функционала</strong> родился после решения проблем с переработкой UIQtTree. Т.к. Qt использует MVC, компонента UIQtTree состоит из нескольких классов. К тому моменту, когда UIQtTree могла отображать и управлять иерархией элементов, компонента уже имела размер в 27К. Мы заметили, что UIQtTree стала потреблять непомерное количество времени разработки даже для мелкого функционала. Это было явным проявлением <a href="http://rsdn.org/article/philosophy/Complexity.xml">количественной сложности</a>.</p>
  199. <p>Мы решили разбить UIQtTree на базовую часть и дополнительные. База содержит лишь необходимый минимум кода. Дополнение содержит код, специфичный для данного функционала, и может быть безболезненно изменено. В случае UIQtTree, отображение и управление иерархией элементов - это минимальный функционал, а переименование элементов - это дополнение.</p>
  200. <p>Текущий функционал UIQtTree состоит из следующих возможностей:</p>
  201. <table>
  202. <tr>
  203. <th>**№**</th>
  204. <th>**Функционал**</th>
  205. <th>**Описание**</th>
  206. <th>**Размер (Б)**</th>
  207. <th>**Размер (%)**</th>
  208. </tr>
  209. <tr>
  210. <td>1</td>
  211. <td>Base</td>
  212. <td>Создание, изменение, отображение иерархии элементов</td>
  213. <td>26966</td>
  214. <td>52</td>
  215. </tr>
  216. <tr>
  217. <td>2</td>
  218. <td>Item open state</td>
  219. <td>Хранит состояние свойства скрыто/отображено элемента</td>
  220. <td>3094</td>
  221. <td>6</td>
  222. </tr>
  223. <tr>
  224. <td>3</td>
  225. <td>Item renaming</td>
  226. <td>Переименование элемента</td>
  227. <td>3471</td>
  228. <td>7</td>
  229. </tr>
  230. <tr>
  231. <td>4</td>
  232. <td>Item selection</td>
  233. <td>Получение/установка выбранного элемента</td>
  234. <td>2338</td>
  235. <td>5</td>
  236. </tr>
  237. <tr>
  238. <td>5</td>
  239. <td>Item value</td>
  240. <td>Предоставляет второй и последующие столбцы для элементов, используется Редактором свойств</td>
  241. <td>1307</td>
  242. <td>3</td>
  243. </tr>
  244. <tr>
  245. <td>6</td>
  246. <td>Item value editing</td>
  247. <td>Редактирование значений элемента с помощью стандартного виджета</td>
  248. <td>1996</td>
  249. <td>4</td>
  250. </tr>
  251. <tr>
  252. <td>7</td>
  253. <td>Item value editing with combobox</td>
  254. <td>Редактирование значений элемента с помощью виджета combobox</td>
  255. <td>5819</td>
  256. <td>11</td>
  257. </tr>
  258. <tr>
  259. <td>8</td>
  260. <td>Item value editing with spinner</td>
  261. <td>Редактирование значений элемента с помощью виджета spinbox</td>
  262. <td>5290</td>
  263. <td>10</td>
  264. </tr>
  265. <tr>
  266. <td>9</td>
  267. <td>Menu</td>
  268. <td>Меню на ПКМ</td>
  269. <td>1248</td>
  270. <td>2</td>
  271. </tr>
  272. </table>
  273. <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>
  274. <p><strong>Преимущества подхода:</strong></p>
  275. <ol>
  276. <li>Более быстрое чтение/понимание благодаря небольшому размеру</li>
  277. <li>Более простое и безболезненное изменение благодаря изолированному коду</li>
  278. </ol>
  279. <p>Есть и недостаток: новый подход требует изучения.</p>
  280. <p>На этом мы заканчиваем описание самых важных технических деталей разработки за август: модуль UIQt, его переработку, новый подход к разработке на основе функционала и его преимущества.</p>
  281. </div>
  282. </div>
  283. <div id="footer">
  284. Сайт сгенерирован <a href="http://opengamestudio.org/pskov/ru">ПСКОВОМ</a>
  285. из <a href="http://github.com/ogstudio/site-opengamestudio">этого исходного кода</a>.
  286. Сайт размещён на <a href="https://pages.github.com">GitHub Pages</a>.
  287. </div>
  288. </center>
  289. </body>
  290. </html>