ui_toolbar.ts 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248
  1. ///if is_lab
  2. let ui_toolbar_default_w: i32 = 0;
  3. ///else
  4. let ui_toolbar_default_w: i32 = 36;
  5. ///end
  6. let ui_toolbar_handle: ui_handle_t = ui_handle_create();
  7. let ui_toolbar_last_tool: i32 = 0;
  8. let ui_toolbar_tool_names: string[] = [
  9. _tr("Brush"),
  10. _tr("Eraser"),
  11. _tr("Fill"),
  12. _tr("Decal"),
  13. _tr("Text"),
  14. _tr("Clone"),
  15. _tr("Blur"),
  16. _tr("Smudge"),
  17. _tr("Particle"),
  18. _tr("ColorID"),
  19. _tr("Picker"),
  20. _tr("Bake"),
  21. _tr("Gizmo"),
  22. _tr("Material"),
  23. ];
  24. let _ui_toolbar_i: i32;
  25. function ui_toolbar_init() {
  26. }
  27. function ui_toolbar_draw_tool(i: i32, ui: ui_t, img: gpu_texture_t, icon_accent: i32, keys: string[]) {
  28. ui._x += 2;
  29. if (context_raw.tool == i) {
  30. ui_toolbar_draw_highlight();
  31. }
  32. let tile_y: i32 = math_floor(i / 12);
  33. let tile_x: i32 = tile_y % 2 == 0 ? i % 12 : (11 - (i % 12));
  34. let rect: rect_t = resource_tile50(img, tile_x, tile_y);
  35. let _y: i32 = ui._y;
  36. let image_state: ui_state_t = ui_sub_image(img, icon_accent, -1.0, rect.x, rect.y, rect.w, rect.h);
  37. if (image_state == ui_state_t.STARTED) {
  38. _ui_toolbar_i = i;
  39. sys_notify_on_next_frame(function() {
  40. context_select_tool(_ui_toolbar_i);
  41. });
  42. }
  43. else if (image_state == ui_state_t.RELEASED && config_raw.layout[layout_size_t.HEADER] == 0) {
  44. if (ui_toolbar_last_tool == i) {
  45. ui_toolbar_tool_properties_menu();
  46. }
  47. ui_toolbar_last_tool = i;
  48. }
  49. ///if is_paint
  50. if (i == workspace_tool_t.COLORID && context_raw.colorid_picked) {
  51. let rt: render_target_t = map_get(render_path_render_targets, "texpaint_colorid");
  52. draw_scaled_sub_image(rt._image, 0, 0, 1, 1, 0, _y + 1.5 * ui_SCALE(ui), 5 * ui_SCALE(ui), 34 * ui_SCALE(ui));
  53. }
  54. ///end
  55. if (ui.is_hovered) {
  56. ui_tooltip(tr(ui_toolbar_tool_names[i]) + " " + keys[i]);
  57. }
  58. ui._x -= 2;
  59. ui._y += 2;
  60. }
  61. function ui_toolbar_w(screen_size_request: bool = false): i32 {
  62. if (screen_size_request && context_is_floating_toolbar()) {
  63. return 0;
  64. }
  65. let w: i32 = 0;
  66. if (config_raw.touch_ui) {
  67. w = ui_toolbar_default_w + 6;
  68. }
  69. else {
  70. w = ui_toolbar_default_w;
  71. }
  72. w = math_floor(w * config_raw.window_scale);
  73. return w;
  74. }
  75. function ui_toolbar_x(): i32 {
  76. let ui: ui_t = ui_base_ui;
  77. return 5 * ui_SCALE(ui);
  78. }
  79. function ui_toolbar_render_ui() {
  80. let ui: ui_t = ui_base_ui;
  81. let x: i32 = 0;
  82. let y: i32 = ui_header_h;
  83. let h: i32 = iron_window_height() - ui_header_h;
  84. let _WINDOW_BG_COL: i32 = ui.ops.theme.WINDOW_BG_COL;
  85. if (context_is_floating_toolbar()) {
  86. x += ui_toolbar_x();
  87. y += ui_toolbar_x();
  88. h = ui_toolbar_tool_names.length * (ui_toolbar_w() + 2);
  89. ui.ops.theme.WINDOW_BG_COL = ui.ops.theme.SEPARATOR_COL;
  90. }
  91. if (ui_window(ui_toolbar_handle, x, y, ui_toolbar_w(), h)) {
  92. ui._y -= 4 * ui_SCALE(ui);
  93. ui.image_scroll_align = false;
  94. let img: gpu_texture_t = resource_get("icons.k");
  95. let col: u32 = ui.ops.theme.WINDOW_BG_COL;
  96. let light: bool = col > 0xff666666;
  97. let icon_accent: i32 = light ? 0xff666666 : -1;
  98. // Properties icon
  99. if (config_raw.layout[layout_size_t.HEADER] == 1) {
  100. let rect: rect_t = resource_tile50(img, 7, 1);
  101. if (ui_sub_image(img, light ? 0xff666666 : ui.ops.theme.BUTTON_COL, -1.0, rect.x, rect.y, rect.w, rect.h) == ui_state_t.RELEASED) {
  102. config_raw.layout[layout_size_t.HEADER] = 0;
  103. }
  104. }
  105. // Draw ">>" button if header is hidden
  106. else {
  107. let _ELEMENT_H: i32 = ui.ops.theme.ELEMENT_H;
  108. let _BUTTON_H: i32 = ui.ops.theme.BUTTON_H;
  109. let _BUTTON_COL: i32 = ui.ops.theme.BUTTON_COL;
  110. let _fontOffsetY: i32 = ui.font_offset_y;
  111. ui.ops.theme.ELEMENT_H = math_floor(ui.ops.theme.ELEMENT_H * 1.5);
  112. ui.ops.theme.BUTTON_H = ui.ops.theme.ELEMENT_H;
  113. ui.ops.theme.BUTTON_COL = ui.ops.theme.WINDOW_BG_COL;
  114. let font_height: i32 = draw_font_height(ui.ops.font, ui.font_size);
  115. ui.font_offset_y = (ui_ELEMENT_H(ui) - font_height) / 2;
  116. let _w: i32 = ui._w;
  117. ui._w = ui_toolbar_w();
  118. if (ui_button(">>")) {
  119. ui_toolbar_tool_properties_menu();
  120. }
  121. ui._w = _w;
  122. ui.ops.theme.ELEMENT_H = _ELEMENT_H;
  123. ui.ops.theme.BUTTON_H = _BUTTON_H;
  124. ui.ops.theme.BUTTON_COL = _BUTTON_COL;
  125. ui.font_offset_y = _fontOffsetY;
  126. }
  127. if (ui.is_hovered) {
  128. ui_tooltip(tr("Toggle header"));
  129. }
  130. ui._y -= 4 * ui_SCALE(ui);
  131. let vars_brush: map_t<string, string> = map_create();
  132. map_set(vars_brush, "key", map_get(config_keymap, "brush_ruler"));
  133. map_set(vars_brush, "action_paint", map_get(config_keymap, "action_paint"));
  134. let vars_decal: map_t<string, string> = map_create();
  135. map_set(vars_decal, "key", map_get(config_keymap, "decal_mask"));
  136. let vars_clone: map_t<string, string> = map_create();
  137. map_set(vars_clone, "key", map_get(config_keymap, "set_clone_source"));
  138. let key_tool_brush: string = map_get(config_keymap, "tool_brush");
  139. let key_tool_eraser: string = map_get(config_keymap, "tool_eraser");
  140. let key_tool_fill: string = map_get(config_keymap, "tool_fill");
  141. let key_tool_decal: string = map_get(config_keymap, "tool_decal");
  142. let key_tool_text: string = map_get(config_keymap, "tool_text");
  143. let key_tool_clone: string = map_get(config_keymap, "tool_clone");
  144. let key_tool_blur: string = map_get(config_keymap, "tool_blur");
  145. let key_tool_smudge: string = map_get(config_keymap, "tool_smudge");
  146. let key_tool_particle: string = map_get(config_keymap, "tool_particle");
  147. let key_tool_colorid: string = map_get(config_keymap, "tool_colorid");
  148. let key_tool_picker: string = map_get(config_keymap, "tool_picker");
  149. let key_tool_bake: string = map_get(config_keymap, "tool_bake");
  150. let key_tool_gizmo: string = map_get(config_keymap, "tool_gizmo");
  151. let key_tool_material: string = map_get(config_keymap, "tool_material");
  152. key_tool_brush = "(" + key_tool_brush + ") - " + tr("Hold {action_paint} to paint\nHold {key} and press {action_paint} to paint a straight line (ruler mode)", vars_brush);
  153. key_tool_eraser = "(" + key_tool_eraser + ") - " + tr("Hold {action_paint} to erase\nHold {key} and press {action_paint} to erase a straight line (ruler mode)", vars_brush);
  154. key_tool_fill = "(" + key_tool_fill + ")";
  155. key_tool_decal = "(" + key_tool_decal + ") - " + tr("Hold {key} to paint on a decal mask", vars_decal);
  156. key_tool_text = "(" + key_tool_text + ") - " + tr("Hold {key} to use the text as a mask", vars_decal);
  157. key_tool_clone = "(" + key_tool_clone + ") - " + tr("Hold {key} to set source", vars_clone);
  158. key_tool_blur = "(" + key_tool_blur + ")";
  159. key_tool_smudge = "(" + key_tool_smudge + ")";
  160. key_tool_particle = "(" + key_tool_particle + ")";
  161. key_tool_colorid = "(" + key_tool_colorid + ")";
  162. key_tool_picker = "(" + key_tool_picker + ")";
  163. key_tool_bake = "(" + key_tool_bake + ")";
  164. key_tool_gizmo = "(" + key_tool_gizmo + ")";
  165. key_tool_material = "(" + key_tool_material + ")";
  166. let keys: string[] = [
  167. key_tool_brush,
  168. key_tool_eraser,
  169. key_tool_fill,
  170. key_tool_decal,
  171. key_tool_text,
  172. key_tool_clone,
  173. key_tool_blur,
  174. key_tool_smudge,
  175. key_tool_particle,
  176. key_tool_colorid,
  177. key_tool_picker,
  178. key_tool_bake,
  179. key_tool_gizmo,
  180. key_tool_material
  181. ];
  182. ui_toolbar_ext_draw_tools(ui, img, icon_accent, keys);
  183. ui.image_scroll_align = true;
  184. }
  185. if (context_is_floating_toolbar()) {
  186. ui.ops.theme.WINDOW_BG_COL = _WINDOW_BG_COL;
  187. }
  188. if (config_raw.touch_ui) {
  189. // Hide scrollbar
  190. let _SCROLL_W: i32 = ui.ops.theme.SCROLL_W;
  191. ui.ops.theme.SCROLL_W = 0;
  192. ui_end_window();
  193. ui.ops.theme.SCROLL_W = _SCROLL_W;
  194. }
  195. }
  196. function ui_toolbar_tool_properties_menu() {
  197. let ui: ui_t = ui_base_ui;
  198. ui_menu_draw(function (ui: ui_t) {
  199. ui.changed = false;
  200. ui_header_draw_tool_properties(ui);
  201. if (ui.changed) {
  202. ui_menu_keep_open = true;
  203. }
  204. if (ui_button(tr("Pin to Header"), ui_align_t.LEFT)) {
  205. config_raw.layout[layout_size_t.HEADER] = 1;
  206. }
  207. }, math_floor(ui._x + ui._w + 2), math_floor(ui._y - 6 * ui_SCALE(ui)));
  208. }
  209. function ui_toolbar_draw_highlight() {
  210. let ui: ui_t = ui_base_ui;
  211. let size: i32 = ui_toolbar_w() - 4;
  212. draw_set_color(ui.ops.theme.HIGHLIGHT_COL);
  213. ui_draw_rect(true, ui._x + -1, ui._y + 2, size + 2, size + 2);
  214. }