tab_brushes.ts 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. ///if (is_paint || is_sculpt)
  2. let _tab_brushes_draw_i: i32;
  3. function tab_brushes_draw(htab: zui_handle_t) {
  4. let ui: zui_t = ui_base_ui;
  5. if (zui_tab(htab, tr("Brushes"))) {
  6. zui_begin_sticky();
  7. let row: f32[] = [1 / 4, 1 / 4, 1 / 4];
  8. zui_row(row);
  9. if (zui_button(tr("New"))) {
  10. context_raw.brush = slot_brush_create();
  11. array_push(project_brushes, context_raw.brush);
  12. make_material_parse_brush();
  13. ui_nodes_hwnd.redraws = 2;
  14. }
  15. if (zui_button(tr("Import"))) {
  16. project_import_brush();
  17. }
  18. if (zui_button(tr("Nodes"))) {
  19. ui_base_show_brush_nodes();
  20. }
  21. zui_end_sticky();
  22. zui_separator(3, false);
  23. let slotw: i32 = math_floor(51 * zui_SCALE(ui));
  24. let num: i32 = math_floor(config_raw.layout[layout_size_t.SIDEBAR_W] / slotw);
  25. for (let row: i32 = 0; row < math_floor(math_ceil(project_brushes.length / num)); ++row) {
  26. let mult: i32 = config_raw.show_asset_names ? 2 : 1;
  27. let ar: f32[] = [];
  28. for (let i: i32 = 0; i < num * mult; ++i) {
  29. array_push(ar, 1 / num);
  30. }
  31. zui_row(ar);
  32. ui._x += 2;
  33. let off: f32 = config_raw.show_asset_names ? zui_ELEMENT_OFFSET(ui) * 10.0 : 6;
  34. if (row > 0) {
  35. ui._y += off;
  36. }
  37. for (let j: i32 = 0; j < num; ++j) {
  38. let imgw: i32 = math_floor(50 * zui_SCALE(ui));
  39. let i: i32 = j + row * num;
  40. if (i >= project_brushes.length) {
  41. zui_end_element(imgw);
  42. if (config_raw.show_asset_names) zui_end_element(0);
  43. continue;
  44. }
  45. let img: image_t = zui_SCALE(ui) > 1 ? project_brushes[i].image : project_brushes[i].image_icon;
  46. let img_full: image_t = project_brushes[i].image;
  47. if (context_raw.brush == project_brushes[i]) {
  48. // Zui.fill(1, -2, img.width + 3, img.height + 3, ui.ops.theme.HIGHLIGHT_COL); // TODO
  49. let off: i32 = row % 2 == 1 ? 1 : 0;
  50. let w: i32 = 50;
  51. if (config_raw.window_scale > 1) {
  52. w += math_floor(config_raw.window_scale * 2);
  53. }
  54. zui_fill(-1, -2, w + 3, 2, ui.ops.theme.HIGHLIGHT_COL);
  55. zui_fill(-1, w - off, w + 3, 2 + off, ui.ops.theme.HIGHLIGHT_COL);
  56. zui_fill(-1, -2, 2, w + 3, ui.ops.theme.HIGHLIGHT_COL);
  57. zui_fill(w + 1, -2, 2, w + 4, ui.ops.theme.HIGHLIGHT_COL);
  58. }
  59. let uix: f32 = ui._x;
  60. //let uiy: f32 = ui._y;
  61. let tile: i32 = zui_SCALE(ui) > 1 ? 100 : 50;
  62. let state: zui_state_t = project_brushes[i].preview_ready ? zui_image(img) : zui_image(resource_get("icons.k"), -1, -1.0, tile * 5, tile, tile, tile);
  63. if (state == zui_state_t.STARTED) {
  64. if (context_raw.brush != project_brushes[i]) {
  65. context_select_brush(i);
  66. }
  67. if (time_time() - context_raw.select_time < 0.25) {
  68. ui_base_show_brush_nodes();
  69. }
  70. context_raw.select_time = time_time();
  71. // app_drag_off_x = -(mouse_x - uix - ui._windowX - 3);
  72. // app_drag_off_y = -(mouse_y - uiy - ui._windowY + 1);
  73. // app_drag_brush = raw.brush;
  74. }
  75. if (ui.is_hovered && ui.input_released_r) {
  76. context_select_brush(i);
  77. let add: i32 = project_brushes.length > 1 ? 1 : 0;
  78. _tab_brushes_draw_i = i;
  79. ui_menu_draw(function (ui: zui_t) {
  80. let i: i32 = _tab_brushes_draw_i;
  81. //let b: slot_brush_t = brushes[i];
  82. if (ui_menu_button(ui, tr("Export"))) {
  83. context_select_brush(i);
  84. box_export_show_brush();
  85. }
  86. if (ui_menu_button(ui, tr("Duplicate"))) {
  87. app_notify_on_init(function () {
  88. let i: i32 = _tab_brushes_draw_i;
  89. context_raw.brush = slot_brush_create();
  90. array_push(project_brushes, context_raw.brush);
  91. let cloned: any = json_parse(json_stringify(project_brushes[i].canvas));
  92. context_raw.brush.canvas = cloned;
  93. context_set_brush(context_raw.brush);
  94. util_render_make_brush_preview();
  95. });
  96. }
  97. if (project_brushes.length > 1 && ui_menu_button(ui, tr("Delete"), "delete")) {
  98. tab_brushes_delete_brush(project_brushes[i]);
  99. }
  100. }, 2 + add);
  101. }
  102. if (ui.is_hovered) {
  103. if (img_full == null) {
  104. _tab_brushes_draw_i = i;
  105. app_notify_on_init(function () {
  106. let i: i32 = _tab_brushes_draw_i;
  107. let _brush: slot_brush_t = context_raw.brush;
  108. context_raw.brush = project_brushes[i];
  109. make_material_parse_brush();
  110. util_render_make_brush_preview();
  111. context_raw.brush = _brush;
  112. });
  113. }
  114. else {
  115. zui_tooltip_image(img_full);
  116. zui_tooltip(project_brushes[i].canvas.name);
  117. }
  118. }
  119. if (config_raw.show_asset_names) {
  120. ui._x = uix;
  121. ui._y += slotw * 0.9;
  122. zui_text(project_brushes[i].canvas.name, zui_align_t.CENTER);
  123. if (ui.is_hovered) {
  124. zui_tooltip(project_brushes[i].canvas.name);
  125. }
  126. ui._y -= slotw * 0.9;
  127. if (i == project_brushes.length - 1) {
  128. ui._y += j == num - 1 ? imgw : imgw + zui_ELEMENT_H(ui) + zui_ELEMENT_OFFSET(ui);
  129. }
  130. }
  131. }
  132. ui._y += 6;
  133. }
  134. let in_focus: bool = ui.input_x > ui._window_x && ui.input_x < ui._window_x + ui._window_w &&
  135. ui.input_y > ui._window_y && ui.input_y < ui._window_y + ui._window_h;
  136. if (in_focus && ui.is_delete_down && project_brushes.length > 1) {
  137. ui.is_delete_down = false;
  138. tab_brushes_delete_brush(context_raw.brush);
  139. }
  140. }
  141. }
  142. function tab_brushes_delete_brush(b: slot_brush_t) {
  143. let i: i32 = array_index_of(project_brushes, b);
  144. context_select_brush(i == project_brushes.length - 1 ? i - 1 : i + 1);
  145. array_splice(project_brushes, i, 1);
  146. ui_base_hwnds[1].redraws = 2;
  147. }
  148. ///end