| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231 |
- ///if (is_paint || is_sculpt)
- let ui_toolbar_default_w: i32 = 36;
- let ui_toolbar_handle: zui_handle_t = zui_handle_create();
- let ui_toolbar_w: i32 = ui_toolbar_default_w;
- let ui_toolbar_last_tool: i32 = 0;
- let ui_toolbar_tool_names: string[] = [
- _tr("Brush"),
- _tr("Eraser"),
- _tr("Fill"),
- _tr("Decal"),
- _tr("Text"),
- _tr("Clone"),
- _tr("Blur"),
- _tr("Smudge"),
- _tr("Particle"),
- _tr("ColorID"),
- _tr("Picker"),
- _tr("Bake"),
- _tr("Gizmo"),
- _tr("Material"),
- ];
- function ui_toolbar_init() {
- }
- let _ui_toolbar_i: i32;
- function ui_toolbar_draw_tool(i: i32, ui: zui_t, img: image_t, icon_accent: i32, keys: string[]) {
- ui._x += 2;
- if (context_raw.tool == i) {
- ui_toolbar_draw_highlight();
- }
- let tile_y: i32 = math_floor(i / 12);
- let tile_x: i32 = tile_y % 2 == 0 ? i % 12 : (11 - (i % 12));
- let rect: rect_t = resource_tile50(img, tile_x, tile_y);
- let _y: i32 = ui._y;
- let image_state: zui_state_t = zui_image(img, icon_accent, -1.0, rect.x, rect.y, rect.w, rect.h);
- if (image_state == zui_state_t.STARTED) {
- _ui_toolbar_i = i;
- app_notify_on_next_frame(function() {
- context_select_tool(_ui_toolbar_i);
- });
- }
- else if (image_state == zui_state_t.RELEASED && config_raw.layout[layout_size_t.HEADER] == 0) {
- if (ui_toolbar_last_tool == i) {
- ui_toolbar_tool_properties_menu();
- }
- ui_toolbar_last_tool = i;
- }
- ///if is_paint
- if (i == workspace_tool_t.COLORID && context_raw.colorid_picked) {
- g2_draw_scaled_sub_image(map_get(render_path_render_targets, "texpaint_colorid")._image, 0, 0, 1, 1, 0, _y + 1.5 * zui_SCALE(ui), 5 * zui_SCALE(ui), 34 * zui_SCALE(ui));
- }
- ///end
- if (ui.is_hovered) {
- zui_tooltip(tr(ui_toolbar_tool_names[i]) + " " + keys[i]);
- }
- ui._x -= 2;
- ui._y += 2;
- }
- function ui_toolbar_render_ui() {
- let ui: zui_t = ui_base_ui;
- if (config_raw.touch_ui) {
- ui_toolbar_w = ui_toolbar_default_w + 6;
- }
- else {
- ui_toolbar_w = ui_toolbar_default_w;
- }
- ui_toolbar_w = math_floor(ui_toolbar_w * zui_SCALE(ui));
- if (zui_window(ui_toolbar_handle, 0, ui_header_h, ui_toolbar_w, sys_height() - ui_header_h)) {
- ui._y -= 4 * zui_SCALE(ui);
- ui.image_scroll_align = false;
- let img: image_t = resource_get("icons.k");
- let col: i32 = ui.ops.theme.WINDOW_BG_COL;
- if (col < 0) {
- col += 4294967296;
- }
- let light: bool = col > (0xff666666 + 4294967296);
- let icon_accent: i32 = light ? 0xff666666 : -1;
- // Properties icon
- if (config_raw.layout[layout_size_t.HEADER] == 1) {
- let rect: rect_t = resource_tile50(img, 7, 1);
- if (zui_image(img, light ? 0xff666666 : ui.ops.theme.BUTTON_COL, -1.0, rect.x, rect.y, rect.w, rect.h) == zui_state_t.RELEASED) {
- config_raw.layout[layout_size_t.HEADER] = 0;
- }
- }
- // Draw ">>" button if header is hidden
- else {
- let _ELEMENT_H: i32 = ui.ops.theme.ELEMENT_H;
- let _BUTTON_H: i32 = ui.ops.theme.BUTTON_H;
- let _BUTTON_COL: i32 = ui.ops.theme.BUTTON_COL;
- let _fontOffsetY: i32 = ui.font_offset_y;
- ui.ops.theme.ELEMENT_H = math_floor(ui.ops.theme.ELEMENT_H * 1.5);
- ui.ops.theme.BUTTON_H = ui.ops.theme.ELEMENT_H;
- ui.ops.theme.BUTTON_COL = ui.ops.theme.WINDOW_BG_COL;
- let font_height: i32 = g2_font_height(ui.ops.font, ui.font_size);
- ui.font_offset_y = (zui_ELEMENT_H(ui) - font_height) / 2;
- let _w: i32 = ui._w;
- ui._w = ui_toolbar_w;
- if (zui_button(">>")) {
- ui_toolbar_tool_properties_menu();
- }
- ui._w = _w;
- ui.ops.theme.ELEMENT_H = _ELEMENT_H;
- ui.ops.theme.BUTTON_H = _BUTTON_H;
- ui.ops.theme.BUTTON_COL = _BUTTON_COL;
- ui.font_offset_y = _fontOffsetY;
- }
- if (ui.is_hovered) {
- zui_tooltip(tr("Toggle header"));
- }
- ui._y -= 4 * zui_SCALE(ui);
- let vars_brush: map_t<string, string> = map_create();
- map_set(vars_brush, "key", map_get(config_keymap, "brush_ruler"));
- map_set(vars_brush, "action_paint", map_get(config_keymap, "action_paint"));
- let vars_decal: map_t<string, string> = map_create();
- map_set(vars_decal, "key", map_get(config_keymap, "decal_mask"));
- let vars_clone: map_t<string, string> = map_create();
- map_set(vars_clone, "key", map_get(config_keymap, "set_clone_source"));
- let keys: string[] = [
- "(" + map_get(config_keymap, "tool_brush") + ") - " + tr("Hold {action_paint} to paint\nHold {key} and press {action_paint} to paint a straight line (ruler mode)", vars_brush),
- "(" + map_get(config_keymap, "tool_eraser") + ") - " + tr("Hold {action_paint} to erase\nHold {key} and press {action_paint} to erase a straight line (ruler mode)", vars_brush),
- "(" + map_get(config_keymap, "tool_fill") + ")",
- "(" + map_get(config_keymap, "tool_decal") + ") - " + tr("Hold {key} to paint on a decal mask", vars_decal),
- "(" + map_get(config_keymap, "tool_text") + ") - " + tr("Hold {key} to use the text as a mask", vars_decal),
- "(" + map_get(config_keymap, "tool_clone") + ") - " + tr("Hold {key} to set source", vars_clone),
- "(" + map_get(config_keymap, "tool_blur") + ")",
- "(" + map_get(config_keymap, "tool_smudge") + ")",
- "(" + map_get(config_keymap, "tool_particle") + ")",
- "(" + map_get(config_keymap, "tool_colorid") + ")",
- "(" + map_get(config_keymap, "tool_picker") + ")",
- "(" + map_get(config_keymap, "tool_bake") + ")",
- "(" + map_get(config_keymap, "tool_gizmo") + ")",
- "(" + map_get(config_keymap, "tool_material") + ")",
- ];
- ui_toolbar_draw_tool(workspace_tool_t.BRUSH, ui, img, icon_accent, keys);
- ///if is_paint
- ui_toolbar_draw_tool(workspace_tool_t.ERASER, ui, img, icon_accent, keys);
- ui_toolbar_draw_tool(workspace_tool_t.FILL, ui, img, icon_accent, keys);
- ui_toolbar_draw_tool(workspace_tool_t.DECAL, ui, img, icon_accent, keys);
- ui_toolbar_draw_tool(workspace_tool_t.TEXT, ui, img, icon_accent, keys);
- ui_toolbar_draw_tool(workspace_tool_t.CLONE, ui, img, icon_accent, keys);
- ui_toolbar_draw_tool(workspace_tool_t.BLUR, ui, img, icon_accent, keys);
- ui_toolbar_draw_tool(workspace_tool_t.SMUDGE, ui, img, icon_accent, keys);
- ui_toolbar_draw_tool(workspace_tool_t.PARTICLE, ui, img, icon_accent, keys);
- ui_toolbar_draw_tool(workspace_tool_t.COLORID, ui, img, icon_accent, keys);
- ui_toolbar_draw_tool(workspace_tool_t.PICKER, ui, img, icon_accent, keys);
- ui_toolbar_draw_tool(workspace_tool_t.BAKE, ui, img, icon_accent, keys);
- ui_toolbar_draw_tool(workspace_tool_t.MATERIAL, ui, img, icon_accent, keys);
- ///end
- ///if is_forge
- ui_toolbar_draw_tool(workspace_tool_t.GIZMO, ui, img, icon_accent, keys);
- ///end
- ui.image_scroll_align = true;
- }
- if (config_raw.touch_ui) {
- // Hide scrollbar
- let _SCROLL_W: i32 = ui.ops.theme.SCROLL_W;
- ui.ops.theme.SCROLL_W = 0;
- zui_end_window();
- ui.ops.theme.SCROLL_W = _SCROLL_W;
- }
- }
- let _ui_toolbar_tool_properties_menu_x: i32;
- let _ui_toolbar_tool_properties_menu_y: i32;
- let _ui_toolbar_tool_properties_menu_w: i32;
- function ui_toolbar_tool_properties_menu() {
- let ui: zui_t = ui_base_ui;
- _ui_toolbar_tool_properties_menu_x = ui._x;
- _ui_toolbar_tool_properties_menu_y = ui._y;
- _ui_toolbar_tool_properties_menu_w = ui._w;
- ui_menu_draw(function (ui: zui_t) {
- let start_y: i32 = ui._y;
- ui.changed = false;
- ui_header_draw_tool_properties(ui);
- if (ui.changed) {
- ui_menu_keep_open = true;
- }
- if (zui_button(tr("Pin to Header"), zui_align_t.LEFT)) {
- config_raw.layout[layout_size_t.HEADER] = 1;
- }
- let h: i32 = ui._y - start_y;
- ui_menu_elements = math_floor(h / zui_ELEMENT_H(ui));
- ui_menu_x = math_floor(_ui_toolbar_tool_properties_menu_x + _ui_toolbar_tool_properties_menu_w + 2);
- ui_menu_y = math_floor(_ui_toolbar_tool_properties_menu_y - 6 * zui_SCALE(ui));
- ui_menu_fit_to_screen();
- }, 0);
- // First draw out of screen, then align the menu based on menu height
- ui_menu_x = -sys_width();
- ui_menu_y = -sys_height();
- }
- function ui_toolbar_draw_highlight() {
- let ui: zui_t = ui_base_ui;
- let size: i32 = ui_toolbar_w - 4;
- g2_set_color(ui.ops.theme.HIGHLIGHT_COL);
- zui_draw_rect(true, ui._x + -1, ui._y + 2, size + 2, size + 2);
- }
- ///end
|