| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529 |
- let ui_view2d_pipe: gpu_pipeline_t;
- let ui_view2d_channel_loc: i32;
- let ui_view2d_text_input_hover: bool = false;
- let ui_view2d_uvmap_show: bool = false;
- let ui_view2d_tex_type: paint_tex_t = paint_tex_t.BASE;
- let ui_view2d_layer_mode: view_2d_layer_mode_t = view_2d_layer_mode_t.SELECTED;
- ///if is_paint
- let ui_view2d_type: view_2d_type_t = view_2d_type_t.LAYER;
- ///else
- let ui_view2d_type: view_2d_type_t = view_2d_type_t.ASSET;
- ///end
- let ui_view2d_show: bool = false;
- let ui_view2d_wx: i32;
- let ui_view2d_wy: i32;
- let ui_view2d_ww: i32;
- let ui_view2d_wh: i32;
- let ui_view2d_ui: ui_t;
- let ui_view2d_hwnd: ui_handle_t = ui_handle_create();
- let ui_view2d_pan_x: f32 = 0.0;
- let ui_view2d_pan_y: f32 = 0.0;
- let ui_view2d_pan_scale: f32 = 1.0;
- let ui_view2d_tiled_show: bool = false;
- let ui_view2d_controls_down: bool = false;
- let _ui_view2d_render_tex: gpu_texture_t;
- let _ui_view2d_render_x: f32;
- let _ui_view2d_render_y: f32;
- let _ui_view2d_render_tw: f32;
- let _ui_view2d_render_th: f32;
- let ui_view2d_grid: gpu_texture_t = null;
- let ui_view2d_grid_redraw: bool = true;
- function ui_view2d_init() {
- ///if is_paint
- ui_view2d_pipe = gpu_create_pipeline();
- ui_view2d_pipe.vertex_shader = sys_get_shader("layer_view.vert");
- ui_view2d_pipe.fragment_shader = sys_get_shader("layer_view.frag");
- let vs: gpu_vertex_structure_t = {};
- gpu_vertex_struct_add(vs, "pos", vertex_data_t.F32_2X);
- ui_view2d_pipe.input_layout = vs;
- ui_view2d_pipe.blend_source = blend_factor_t.BLEND_ONE;
- ui_view2d_pipe.blend_destination = blend_factor_t.BLEND_ZERO;
- ARRAY_ACCESS(ui_view2d_pipe.color_write_mask_alpha, 0) = false;
- gpu_pipeline_compile(ui_view2d_pipe);
- pipes_offset = 0;
- pipes_get_constant_location("mat4");
- pipes_get_constant_location("float4");
- pipes_get_constant_location("float4");
- pipes_get_constant_location("float4");
- ui_view2d_channel_loc = pipes_get_constant_location("int");
- ///end
- let scale: f32 = config_raw.window_scale;
- let ops: ui_options_t = {
- theme: base_theme,
- font: base_font,
- color_wheel: base_color_wheel,
- black_white_gradient: base_color_wheel_gradient,
- scale_factor: scale
- };
- ui_view2d_ui = ui_create(ops);
- ui_view2d_ui.scroll_enabled = false;
- }
- function ui_view2d_render() {
- ui_view2d_ww = config_raw.layout[layout_size_t.NODES_W];
- ///if is_paint
- ui_view2d_wx = math_floor(sys_w()) + ui_toolbar_w(true);
- ///else
- ui_view2d_wx = math_floor(sys_w());
- ///end
- ui_view2d_wy = 0;
- ///if is_paint
- if (!ui_base_show) {
- ui_view2d_ww += config_raw.layout[layout_size_t.SIDEBAR_W] + ui_toolbar_w(true);
- ui_view2d_wx -= ui_toolbar_w(true);
- }
- ///end
- if (!ui_view2d_show) {
- return;
- }
- if (iron_window_width() == 0 || iron_window_height() == 0) {
- return;
- }
- if (context_raw.pdirty >= 0) {
- ui_view2d_hwnd.redraws = 2; // Paint was active
- }
- // Cache grid
- if (ui_view2d_grid_redraw) {
- if (ui_view2d_grid != null) {
- iron_delete_texture(ui_view2d_grid);
- }
- ui_view2d_grid = ui_nodes_draw_grid(ui_view2d_pan_scale);
- ui_view2d_grid_redraw = false;
- }
- // Ensure UV map is drawn
- ///if is_paint
- if (ui_view2d_uvmap_show) {
- util_uv_cache_uv_map();
- }
- ///end
- // Ensure font image is drawn
- ///if is_paint
- if (context_raw.font.image == null) {
- util_render_make_font_preview();
- }
- ///end
- ui_begin(ui_view2d_ui);
- let headerh: i32 = config_raw.layout[layout_size_t.HEADER] == 1 ? ui_header_h * 2 : ui_header_h;
- let apph: i32 = iron_window_height() - config_raw.layout[layout_size_t.STATUS_H] + headerh;
- ui_view2d_wh = iron_window_height() - config_raw.layout[layout_size_t.STATUS_H];
- if (ui_nodes_show) {
- ui_view2d_wh -= config_raw.layout[layout_size_t.NODES_H];
- if (config_raw.touch_ui) {
- ui_view2d_wh += ui_header_h;
- }
- }
- if (ui_window(ui_view2d_hwnd, ui_view2d_wx, ui_view2d_wy, ui_view2d_ww, ui_view2d_wh)) {
- ui_tab(ui_handle(__ID__), tr("2D View"));
- // Grid
- draw_set_color(0xffffffff);
- let step: f32 = ui_nodes_grid_cell_w * ui_view2d_pan_scale;
- let x: f32 = math_fmod(ui_view2d_pan_x, step) - step;
- let y: f32 = math_fmod(ui_view2d_pan_y, step) - step;
- draw_image(ui_view2d_grid, x, y);
- // Texture
- let tex: gpu_texture_t = null;
- let l: slot_layer_t = context_raw.layer;
- let channel: i32 = 0;
- let tw: f32 = ui_view2d_ww * 0.95 * ui_view2d_pan_scale;
- let tx: f32 = ui_view2d_ww / 2 - tw / 2 + ui_view2d_pan_x;
- let ty: f32 = apph / 2 - tw / 2 + ui_view2d_pan_y;
- if (ui_view2d_type == view_2d_type_t.ASSET) {
- tex = project_get_image(context_raw.texture);
- }
- else if (ui_view2d_type == view_2d_type_t.NODE) {
- ///if is_paint
- tex = context_raw.node_preview;
- ///else
- let nodes: ui_nodes_t = ui_nodes_get_nodes();
- if (nodes.nodes_selected_id.length > 0) {
- let sel: ui_node_t = ui_get_node(ui_nodes_get_canvas(true).nodes, nodes.nodes_selected_id[0]);
- let brush_node: logic_node_ext_t = parser_logic_get_logic_node(sel);
- if (brush_node != null) {
- tex = logic_node_get_cached_image(brush_node.base);
- }
- }
- ///end
- }
- else if (ui_view2d_type == view_2d_type_t.LAYER) {
- let layer: slot_layer_t = l;
- if (config_raw.brush_live && render_path_paint_live_layer_drawn > 0) {
- layer = render_path_paint_live_layer;
- }
- if (ui_view2d_layer_mode == view_2d_layer_mode_t.VISIBLE) {
- let current: gpu_texture_t = _draw_current;
- let in_use: bool = gpu_in_use;
- if (in_use) draw_end();
- layer = layers_flatten();
- if (in_use) draw_begin(current);
- }
- else if (slot_layer_is_group(layer)) {
- let current: gpu_texture_t = _draw_current;
- let in_use: bool = gpu_in_use;
- if (in_use) draw_end();
- layer = layers_flatten(false, slot_layer_get_children(layer));
- if (in_use) draw_begin(current);
- }
- tex =
- slot_layer_is_mask(context_raw.layer) ? layer.texpaint :
- ui_view2d_tex_type == paint_tex_t.BASE ? layer.texpaint :
- ui_view2d_tex_type == paint_tex_t.OPACITY ? layer.texpaint :
- ui_view2d_tex_type == paint_tex_t.NORMAL ? layer.texpaint_nor :
- layer.texpaint_pack;
- channel =
- slot_layer_is_mask(context_raw.layer) ? 1 :
- ui_view2d_tex_type == paint_tex_t.OCCLUSION ? 1 :
- ui_view2d_tex_type == paint_tex_t.ROUGHNESS ? 2 :
- ui_view2d_tex_type == paint_tex_t.METALLIC ? 3 :
- ui_view2d_tex_type == paint_tex_t.OPACITY ? 4 :
- ui_view2d_tex_type == paint_tex_t.HEIGHT ? 4 :
- ui_view2d_tex_type == paint_tex_t.NORMAL ? 5 :
- 0;
- }
- else if (ui_view2d_type == view_2d_type_t.FONT) {
- tex = context_raw.font.image;
- }
- let th: f32 = tw;
- if (tex != null) {
- th = tw * (tex.height / tex.width);
- ty = apph / 2 - th / 2 + ui_view2d_pan_y;
- ///if is_paint
- if (ui_view2d_type == view_2d_type_t.LAYER) {
- draw_set_pipeline(ui_view2d_pipe);
- if (!context_raw.texture_filter) {
- draw_set_bilinear_filter(false);
- }
- gpu_set_int(ui_view2d_channel_loc, channel);
- }
- ///end
- draw_scaled_image(tex, tx, ty, tw, th);
- if (ui_view2d_tiled_show) {
- draw_scaled_image(tex, tx - tw, ty, tw, th);
- draw_scaled_image(tex, tx - tw, ty - th, tw, th);
- draw_scaled_image(tex, tx - tw, ty + th, tw, th);
- draw_scaled_image(tex, tx + tw, ty, tw, th);
- draw_scaled_image(tex, tx + tw, ty - th, tw, th);
- draw_scaled_image(tex, tx + tw, ty + th, tw, th);
- draw_scaled_image(tex, tx, ty - th, tw, th);
- draw_scaled_image(tex, tx, ty + th, tw, th);
- }
- ///if is_paint
- if (ui_view2d_type == view_2d_type_t.LAYER) {
- draw_set_pipeline(null);
- if (!context_raw.texture_filter) {
- draw_set_bilinear_filter(true);
- }
- }
- // Texture and node preview color picking
- if ((context_in_2d_view(view_2d_type_t.ASSET) || context_in_2d_view(view_2d_type_t.NODE)) && context_raw.tool == workspace_tool_t.PICKER && ui_view2d_ui.input_down) {
- _ui_view2d_render_tex = tex;
- _ui_view2d_render_x = ui_view2d_ui.input_x - tx - ui_view2d_wx;;
- _ui_view2d_render_y = ui_view2d_ui.input_y - ty - ui_view2d_wy;
- _ui_view2d_render_tw = tw;
- _ui_view2d_render_th = th;
- sys_notify_on_next_frame(function () {
- let rt: render_target_t = map_get(render_path_render_targets, "texpaint_picker");
- let texpaint_picker: gpu_texture_t = rt._image;
- draw_begin(texpaint_picker);
- draw_scaled_image(_ui_view2d_render_tex, -_ui_view2d_render_x, -_ui_view2d_render_y, _ui_view2d_render_tw, _ui_view2d_render_th);
- draw_end();
- let a: buffer_t = gpu_get_texture_pixels(texpaint_picker);
- ///if (arm_metal || arm_vulkan)
- let i0: i32 = 2;
- let i1: i32 = 1;
- let i2: i32 = 0;
- ///else
- let i0: i32 = 0;
- let i1: i32 = 1;
- let i2: i32 = 2;
- ///end
- context_raw.picked_color.base = color_set_rb(context_raw.picked_color.base, buffer_get_u8(a, i0));
- context_raw.picked_color.base = color_set_gb(context_raw.picked_color.base, buffer_get_u8(a, i1));
- context_raw.picked_color.base = color_set_bb(context_raw.picked_color.base, buffer_get_u8(a, i2));
- ui_header_handle.redraws = 2;
- });
- }
- ///end
- }
- ///if is_paint
- // UV map
- if (ui_view2d_type == view_2d_type_t.LAYER && ui_view2d_uvmap_show) {
- draw_scaled_image(util_uv_uvmap, tx, ty, tw, th);
- }
- ///end
- // Menu
- let ew: i32 = math_floor(ui_ELEMENT_W(ui_view2d_ui));
- draw_set_color(ui_view2d_ui.ops.theme.SEPARATOR_COL);
- draw_filled_rect(0, ui_ELEMENT_H(ui_view2d_ui), ui_view2d_ww, ui_ELEMENT_H(ui_view2d_ui) + ui_ELEMENT_OFFSET(ui_view2d_ui) * 2);
- draw_set_color(0xffffffff);
- let start_y: f32 = ui_ELEMENT_H(ui_view2d_ui) + ui_ELEMENT_OFFSET(ui_view2d_ui);
- ui_view2d_ui._x = 2;
- ui_view2d_ui._y = 2 + start_y;
- ui_view2d_ui._w = ew;
- // Editable layer name
- let h: ui_handle_t = ui_handle(__ID__);
- ///if is_paint
- let text: string = ui_view2d_type == view_2d_type_t.NODE ? context_raw.node_preview_name : h.text;
- ///else
- let text: string = h.text;
- ///end
- ui_view2d_ui._w = math_floor(math_min(draw_string_width(ui_view2d_ui.ops.font, ui_view2d_ui.font_size, text) + 15 * ui_SCALE(ui_view2d_ui), 100 * ui_SCALE(ui_view2d_ui)));
- if (ui_view2d_type == view_2d_type_t.ASSET) {
- let asset: asset_t = context_raw.texture;
- if (asset != null) {
- let asset_names: string[] = project_asset_names;
- let i: i32 = array_index_of(asset_names, asset.name);
- h.text = asset.name;
- asset.name = ui_text_input(h, "");
- asset_names[i] = asset.name;
- }
- }
- else if (ui_view2d_type == view_2d_type_t.NODE) {
- ///if is_paint
- ui_text(context_raw.node_preview_name);
- ///else
- let nodes: ui_nodes_t = ui_nodes_get_nodes();
- if (nodes.nodes_selected_id.length > 0) {
- ui_text(ui_get_node(ui_nodes_get_canvas(true).nodes, nodes.nodes_selected_id[0]).name);
- }
- ///end
- }
- ///if is_paint
- else if (ui_view2d_type == view_2d_type_t.LAYER) {
- h.text = l.name;
- l.name = ui_text_input(h, "");
- ui_view2d_text_input_hover = ui_view2d_ui.is_hovered;
- }
- else if (ui_view2d_type == view_2d_type_t.FONT) {
- h.text = context_raw.font.name;
- context_raw.font.name = ui_text_input(h, "");
- }
- ///end
- if (h.changed) {
- ui_base_hwnds[0].redraws = 2;
- }
- ui_view2d_ui._x += ui_view2d_ui._w + 3;
- ui_view2d_ui._y = 2 + start_y;
- ui_view2d_ui._w = ew;
- ///if is_paint
- if (ui_view2d_type == view_2d_type_t.LAYER) {
- let h_layer_mode: ui_handle_t = ui_handle(__ID__);
- if (h_layer_mode.init) {
- h_layer_mode.position = ui_view2d_layer_mode;
- }
- let layer_mode_combo: string[] = [tr("Visible"), tr("Selected")];
- ui_view2d_layer_mode = ui_combo(h_layer_mode, layer_mode_combo, tr("Layers"));
- ui_view2d_ui._x += ew + 3;
- ui_view2d_ui._y = 2 + start_y;
- if (!slot_layer_is_mask(context_raw.layer)) {
- let h_tex_type: ui_handle_t = ui_handle(__ID__);
- if (h_tex_type.init) {
- h_tex_type.position = ui_view2d_tex_type;
- }
- let tex_type_combo: string[] = [
- tr("Base Color"),
- tr("Normal Map"),
- tr("Occlusion"),
- tr("Roughness"),
- tr("Metallic"),
- tr("Opacity"),
- tr("Height"),
- ];
- ui_view2d_tex_type = ui_combo(h_tex_type, tex_type_combo, tr("Texture"));
- ui_view2d_ui._x += ew + 3;
- ui_view2d_ui._y = 2 + start_y;
- }
- ui_view2d_ui._w = math_floor(ew * 0.7 + 3);
- let h_uvmap_show: ui_handle_t = ui_handle(__ID__);
- if (h_uvmap_show.init) {
- h_uvmap_show.selected = ui_view2d_uvmap_show;
- }
- ui_view2d_uvmap_show = ui_check(h_uvmap_show, tr("UV Map"));
- ui_view2d_ui._x += ew * 0.7 + 3;
- ui_view2d_ui._y = 2 + start_y;
- }
- ///end
- let h_tiled_show: ui_handle_t = ui_handle(__ID__);
- if (h_tiled_show.init) {
- h_tiled_show.selected = ui_view2d_tiled_show;
- }
- ui_view2d_tiled_show = ui_check(h_tiled_show, tr("Tiled"));
- ui_view2d_ui._x += ew * 0.7 + 3;
- ui_view2d_ui._y = 2 + start_y;
- if (ui_view2d_type == view_2d_type_t.ASSET && tex != null) { // Texture resolution
- ui_text(tex.width + "x" + tex.height);
- }
- // Picked position
- ///if is_paint
- if (context_raw.tool == workspace_tool_t.PICKER && (ui_view2d_type == view_2d_type_t.LAYER || ui_view2d_type == view_2d_type_t.ASSET)) {
- let cursor_img: gpu_texture_t = resource_get("cursor.k");
- let hsize: f32 = 16 * ui_SCALE(ui_view2d_ui);
- let size: f32 = hsize * 2;
- draw_scaled_image(cursor_img, tx + tw * context_raw.uvx_picked - hsize, ty + th * context_raw.uvy_picked - hsize, size, size);
- }
- ///end
- }
- ui_end();
- }
- function ui_view2d_update() {
- let headerh: f32 = ui_ELEMENT_H(ui_view2d_ui) * 1.4;
- ///if is_paint
- context_raw.paint2d = false;
- ///end
- if (!base_ui_enabled ||
- !ui_view2d_show ||
- mouse_x < ui_view2d_wx ||
- mouse_x > ui_view2d_wx + ui_view2d_ww ||
- mouse_y < ui_view2d_wy + headerh ||
- mouse_y > ui_view2d_wy + ui_view2d_wh) {
- if (ui_view2d_controls_down) {
- let control: ui_canvas_control_t = ui_nodes_get_canvas_control(ui_view2d_ui, ui_view2d_controls_down);
- ui_view2d_controls_down = control.controls_down;
- }
- return;
- }
- let control: ui_canvas_control_t = ui_nodes_get_canvas_control(ui_view2d_ui, ui_view2d_controls_down);
- ui_view2d_pan_x += control.pan_x;
- ui_view2d_pan_y += control.pan_y;
- ui_view2d_controls_down = control.controls_down;
- if (control.zoom != 0.0) {
- let _pan_x: f32 = ui_view2d_pan_x / ui_view2d_pan_scale;
- let _pan_y: f32 = ui_view2d_pan_y / ui_view2d_pan_scale;
- ui_view2d_pan_scale += control.zoom;
- if (ui_view2d_pan_scale < 0.1) {
- ui_view2d_pan_scale = 0.1;
- }
- if (ui_view2d_pan_scale > 6.0) {
- ui_view2d_pan_scale = 6.0;
- }
- ui_view2d_pan_x = _pan_x * ui_view2d_pan_scale;
- ui_view2d_pan_y = _pan_y * ui_view2d_pan_scale;
- if (ui_touch_scroll) {
- // Zoom to finger location
- ui_view2d_pan_x -= (ui_view2d_ui.input_x - ui_view2d_ui._window_x - ui_view2d_ui._window_w / 2) * control.zoom;
- ui_view2d_pan_y -= (ui_view2d_ui.input_y - ui_view2d_ui._window_y - ui_view2d_ui._window_h / 2) * control.zoom;
- }
- ui_view2d_grid_redraw = true;
- }
- ///if is_paint
- let decal_mask: bool = context_is_decal_mask_paint();
- let set_clone_source: bool = context_raw.tool == workspace_tool_t.CLONE &&
- operator_shortcut(map_get(config_keymap, "set_clone_source") + "+" + map_get(config_keymap, "action_paint"), shortcut_type_t.DOWN);
- let bake: bool = context_raw.tool == workspace_tool_t.BAKE;
- if (ui_view2d_type == view_2d_type_t.LAYER &&
- !ui_view2d_text_input_hover &&
- !bake &&
- (operator_shortcut(map_get(config_keymap, "action_paint"), shortcut_type_t.DOWN) ||
- operator_shortcut(map_get(config_keymap, "brush_ruler") + "+" + map_get(config_keymap, "action_paint"), shortcut_type_t.DOWN) ||
- decal_mask ||
- set_clone_source ||
- config_raw.brush_live)) {
- context_raw.paint2d = true;
- }
- ///end
- if (ui_view2d_ui.is_typing) {
- return;
- }
- if (keyboard_started("left")) {
- ui_view2d_pan_x -= 5;
- }
- else if (keyboard_started("right")) {
- ui_view2d_pan_x += 5;
- }
- if (keyboard_started("up")) {
- ui_view2d_pan_y -= 5;
- }
- else if (keyboard_started("down")) {
- ui_view2d_pan_y += 5;
- }
- // Limit panning to keep texture in viewport
- let border: i32 = 32;
- let tw: f32 = ui_view2d_ww * 0.95 * ui_view2d_pan_scale;
- let tx: f32 = ui_view2d_ww / 2 - tw / 2 + ui_view2d_pan_x;
- let hh: f32 = sys_h();
- let ty: f32 = hh / 2 - tw / 2 + ui_view2d_pan_y;
- if (tx + border > ui_view2d_ww) {
- ui_view2d_pan_x = ui_view2d_ww / 2 + tw / 2 - border;
- }
- else if (tx - border < -tw) {
- ui_view2d_pan_x = -tw / 2 - ui_view2d_ww / 2 + border;
- }
- if (ty + border > hh) {
- ui_view2d_pan_y = hh / 2 + tw / 2 - border;
- }
- else if (ty - border < -tw) {
- ui_view2d_pan_y = -tw / 2 - hh / 2 + border;
- }
- if (operator_shortcut(map_get(config_keymap, "view_reset"))) {
- ui_view2d_pan_x = 0.0;
- ui_view2d_pan_y = 0.0;
- ui_view2d_pan_scale = 1.0;
- }
- }
|