| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873 |
- let render_path_paint_live_layer: slot_layer_t = null;
- let render_path_paint_live_layer_drawn: i32 = 0;
- let render_path_paint_live_layer_locked: bool = false;
- let render_path_paint_dilated: bool = true;
- let render_path_paint_push_undo_last: bool;
- let render_path_paint_painto: mesh_object_t = null;
- let render_path_paint_planeo: mesh_object_t = null;
- let render_path_paint_visibles: bool[] = null;
- let render_path_paint_merged_object_visible: bool = false;
- let render_path_paint_saved_fov: f32 = 0.0;
- let render_path_paint_baking: bool = false;
- let _render_path_paint_texpaint: render_target_t;
- let _render_path_paint_texpaint_nor: render_target_t;
- let _render_path_paint_texpaint_pack: render_target_t;
- let _render_path_paint_texpaint_undo: render_target_t;
- let _render_path_paint_texpaint_nor_undo: render_target_t;
- let _render_path_paint_texpaint_pack_undo: render_target_t;
- let render_path_paint_last_x: f32 = -1.0;
- let render_path_paint_last_y: f32 = -1.0;
- function render_path_paint_init() {
- {
- let t: render_target_t = render_target_create();
- t.name = "texpaint_blend0";
- t.width = config_get_texture_res_x();
- t.height = config_get_texture_res_y();
- t.format = "R8";
- render_path_create_render_target(t);
- }
- {
- let t: render_target_t = render_target_create();
- t.name = "texpaint_blend1";
- t.width = config_get_texture_res_x();
- t.height = config_get_texture_res_y();
- t.format = "R8";
- render_path_create_render_target(t);
- }
- {
- let t: render_target_t = render_target_create();
- t.name = "texpaint_colorid";
- t.width = 1;
- t.height = 1;
- t.format = "RGBA32";
- render_path_create_render_target(t);
- }
- {
- let t: render_target_t = render_target_create();
- t.name = "texpaint_picker";
- t.width = 1;
- t.height = 1;
- t.format = "RGBA32";
- render_path_create_render_target(t);
- }
- {
- let t: render_target_t = render_target_create();
- t.name = "texpaint_nor_picker";
- t.width = 1;
- t.height = 1;
- t.format = "RGBA32";
- render_path_create_render_target(t);
- }
- {
- let t: render_target_t = render_target_create();
- t.name = "texpaint_pack_picker";
- t.width = 1;
- t.height = 1;
- t.format = "RGBA32";
- render_path_create_render_target(t);
- }
- {
- let t: render_target_t = render_target_create();
- t.name = "texpaint_uv_picker";
- t.width = 1;
- t.height = 1;
- t.format = "RGBA32";
- render_path_create_render_target(t);
- }
- {
- let t: render_target_t = render_target_create();
- t.name = "texpaint_posnortex_picker0";
- t.width = 1;
- t.height = 1;
- t.format = "RGBA128";
- render_path_create_render_target(t);
- }
- {
- let t: render_target_t = render_target_create();
- t.name = "texpaint_posnortex_picker1";
- t.width = 1;
- t.height = 1;
- t.format = "RGBA128";
- render_path_create_render_target(t);
- }
- render_path_load_shader("shader_datas/copy_mrt3_pass/copy_mrt3_pass");
- render_path_load_shader("shader_datas/copy_mrt3_pass/copy_mrt3RGBA64_pass");
- render_path_load_shader("shader_datas/copy_mrt3_pass/copy_mrt3RGBA128_pass");
- render_path_load_shader("shader_datas/dilate_pass/dilate_pass");
- render_path_load_shader("shader_datas/dilate_pass/dilateRGBA64_pass");
- render_path_load_shader("shader_datas/dilate_pass/dilateRGBA128_pass");
- }
- function render_path_paint_draw_fullscreen_triangle(context: string) {
- // Note that vertices are mangled in vertex shader to form a fullscreen triangle,
- // so plane transform does not matter
- let plane: mesh_object_t = scene_get_child(".Plane").ext;
- let _visible: bool = plane.base.visible;
- plane.base.visible = true;
- mesh_object_render(plane, context, _render_path_bind_params);
- plane.base.visible = _visible;
- render_path_end();
- }
- function render_path_paint_commands_paint(dilation: bool = true) {
- let tid: i32 = context_raw.layer.id;
- if (context_raw.pdirty > 0) {
- if (context_raw.tool == workspace_tool_t.COLORID) {
- render_path_set_target("texpaint_colorid", null, null, clear_flag_t.COLOR, 0xff000000);
- render_path_bind_target("gbuffer2", "gbuffer2");
- render_path_paint_draw_fullscreen_triangle("paint");
- ui_header_handle.redraws = 2;
- }
- else if (context_raw.tool == workspace_tool_t.PICKER || context_raw.tool == workspace_tool_t.MATERIAL) {
- if (context_raw.pick_pos_nor_tex) {
- if (context_raw.paint2d) {
- let additional: string[] = ["gbuffer1", "gbuffer2"];
- render_path_set_target("gbuffer0", additional, "main");
- render_path_draw_meshes("mesh");
- }
- let additional: string[] = ["texpaint_posnortex_picker1"];
- render_path_set_target("texpaint_posnortex_picker0", additional);
- render_path_bind_target("gbuffer2", "gbuffer2");
- render_path_bind_target("main", "gbufferD");
- render_path_draw_meshes("paint");
- let picker0: render_target_t = map_get(render_path_render_targets, "texpaint_posnortex_picker0");
- let picker1: render_target_t = map_get(render_path_render_targets, "texpaint_posnortex_picker1");
- let texpaint_posnortex_picker0: gpu_texture_t = picker0._image;
- let texpaint_posnortex_picker1: gpu_texture_t = picker1._image;
- let a: buffer_t = gpu_get_texture_pixels(texpaint_posnortex_picker0);
- let b: buffer_t = gpu_get_texture_pixels(texpaint_posnortex_picker1);
- context_raw.posx_picked = buffer_get_f32(a, 0);
- context_raw.posy_picked = buffer_get_f32(a, 4);
- context_raw.posz_picked = buffer_get_f32(a, 8);
- context_raw.uvx_picked = buffer_get_f32(a, 12);
- context_raw.norx_picked = buffer_get_f32(b, 0);
- context_raw.nory_picked = buffer_get_f32(b, 4);
- context_raw.norz_picked = buffer_get_f32(b, 8);
- context_raw.uvy_picked = buffer_get_f32(b, 12);
- }
- else {
- let additional: string[] = ["texpaint_nor_picker", "texpaint_pack_picker", "texpaint_uv_picker"];
- render_path_set_target("texpaint_picker", additional);
- render_path_bind_target("gbuffer2", "gbuffer2");
- tid = context_raw.layer.id;
- let use_live_layer: bool = context_raw.tool == workspace_tool_t.MATERIAL;
- if (use_live_layer) {
- render_path_paint_use_live_layer(true);
- }
- render_path_bind_target("texpaint" + tid, "texpaint");
- render_path_bind_target("texpaint_nor" + tid, "texpaint_nor");
- render_path_bind_target("texpaint_pack" + tid, "texpaint_pack");
- render_path_paint_draw_fullscreen_triangle("paint");
- if (use_live_layer) {
- render_path_paint_use_live_layer(false);
- }
- ui_header_handle.redraws = 2;
- ui_base_hwnds[2].redraws = 2;
- let texpaint_picker: render_target_t = map_get(render_path_render_targets, "texpaint_picker");
- let texpaint_nor_picker: render_target_t = map_get(render_path_render_targets, "texpaint_nor_picker");
- let texpaint_pack_picker: render_target_t = map_get(render_path_render_targets, "texpaint_pack_picker");
- let texpaint_uv_picker: render_target_t = map_get(render_path_render_targets, "texpaint_uv_picker");
- let a: buffer_t = gpu_get_texture_pixels(texpaint_picker._image);
- let b: buffer_t = gpu_get_texture_pixels(texpaint_nor_picker._image);
- let c: buffer_t = gpu_get_texture_pixels(texpaint_pack_picker._image);
- let d: buffer_t = gpu_get_texture_pixels(texpaint_uv_picker._image);
- if (context_raw.color_picker_callback != null) {
- context_raw.color_picker_callback(context_raw.picked_color);
- }
- // Picked surface values
- ///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
- let i3: i32 = 3;
- 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));
- context_raw.picked_color.normal = color_set_rb(context_raw.picked_color.normal, buffer_get_u8(b, i0));
- context_raw.picked_color.normal = color_set_gb(context_raw.picked_color.normal, buffer_get_u8(b, i1));
- context_raw.picked_color.normal = color_set_bb(context_raw.picked_color.normal, buffer_get_u8(b, i2));
- context_raw.picked_color.occlusion = buffer_get_u8(c, i0) / 255;
- context_raw.picked_color.roughness = buffer_get_u8(c, i1) / 255;
- context_raw.picked_color.metallic = buffer_get_u8(c, i2) / 255;
- context_raw.picked_color.height = buffer_get_u8(c, i3) / 255;
- context_raw.picked_color.opacity = buffer_get_u8(a, i3) / 255;
- context_raw.uvx_picked = buffer_get_u8(d, i0) / 255;
- context_raw.uvy_picked = buffer_get_u8(d, i1) / 255;
- // Pick material
- if (context_raw.picker_select_material && context_raw.color_picker_callback == null) {
- // matid % 3 == 0 - normal, 1 - emission, 2 - subsurface
- let id: i32 = buffer_get_u8(b, 3);
- let matid: i32 = math_floor((id - (id % 3)) / 3);
- for (let i: i32 = 0; i < project_materials.length; ++i) {
- let m: slot_material_t = project_materials[i];
- if (m.id == matid) {
- context_set_material(m);
- context_raw.materialid_picked = matid;
- break;
- }
- }
- }
- }
- }
- else {
- let texpaint: string = "texpaint" + tid;
- if (context_raw.tool == workspace_tool_t.BAKE && context_raw.brush_time == sys_delta()) {
- // Clear to black on bake start
- render_path_set_target(texpaint, null, null, clear_flag_t.COLOR, 0xff000000);
- }
- render_path_set_target("texpaint_blend1");
- render_path_bind_target("texpaint_blend0", "tex");
- render_path_draw_shader("shader_datas/copy_pass/copyR8_pass");
- let is_mask: bool = slot_layer_is_mask(context_raw.layer);
- if (is_mask) {
- let ptid: i32 = context_raw.layer.parent.id;
- if (slot_layer_is_group(context_raw.layer.parent)) { // Group mask
- for (let i: i32 = 0; i < slot_layer_get_children(context_raw.layer.parent).length; ++i) {
- let c: slot_layer_t = slot_layer_get_children(context_raw.layer.parent)[i];
- ptid = c.id;
- break;
- }
- }
- let additional: string[] = ["texpaint_nor" + ptid, "texpaint_pack" + ptid, "texpaint_blend0"];
- render_path_set_target(texpaint, additional);
- }
- else {
- let additional: string[] = ["texpaint_nor" + tid, "texpaint_pack" + tid, "texpaint_blend0"];
- render_path_set_target(texpaint, additional);
- }
- render_path_bind_target("main", "gbufferD");
- if ((context_raw.xray || config_raw.brush_angle_reject) && config_raw.brush_3d) {
- render_path_bind_target("gbuffer0", "gbuffer0");
- }
- render_path_bind_target("texpaint_blend1", "paintmask");
- if (context_raw.colorid_picked) {
- render_path_bind_target("texpaint_colorid", "texpaint_colorid");
- }
- // Read texcoords from gbuffer
- let read_tc: bool = (context_raw.tool == workspace_tool_t.FILL && context_raw.fill_type_handle.position == fill_type_t.FACE) ||
- context_raw.tool == workspace_tool_t.CLONE ||
- context_raw.tool == workspace_tool_t.BLUR ||
- context_raw.tool == workspace_tool_t.SMUDGE;
- if (read_tc) {
- render_path_bind_target("gbuffer2", "gbuffer2");
- }
- render_path_draw_meshes("paint");
- if (context_raw.tool == workspace_tool_t.BAKE && context_raw.bake_type == bake_type_t.CURVATURE && context_raw.bake_curv_smooth > 0) {
- if (map_get(render_path_render_targets, "texpaint_blur") == null) {
- let t: render_target_t = render_target_create();
- t.name = "texpaint_blur";
- t.width = math_floor(config_get_texture_res_x() * 0.95);
- t.height = math_floor(config_get_texture_res_y() * 0.95);
- t.format = "RGBA32";
- render_path_create_render_target(t);
- }
- let blurs: i32 = math_round(context_raw.bake_curv_smooth);
- for (let i: i32 = 0; i < blurs; ++i) {
- render_path_set_target("texpaint_blur");
- render_path_bind_target(texpaint, "tex");
- render_path_draw_shader("shader_datas/copy_pass/copy_pass");
- render_path_set_target(texpaint);
- render_path_bind_target("texpaint_blur", "tex");
- render_path_draw_shader("shader_datas/copy_pass/copy_pass");
- }
- }
- if (dilation && config_raw.dilate == dilate_type_t.INSTANT) {
- render_path_paint_dilate(true, false);
- }
- }
- }
- }
- function render_path_paint_use_live_layer(use: bool) {
- let tid: i32 = context_raw.layer.id;
- let hid: i32 = history_undo_i - 1 < 0 ? config_raw.undo_steps - 1 : history_undo_i - 1;
- if (use) {
- _render_path_paint_texpaint = map_get(render_path_render_targets, "texpaint" + tid);
- _render_path_paint_texpaint_undo = map_get(render_path_render_targets, "texpaint_undo" + hid);
- _render_path_paint_texpaint_nor_undo = map_get(render_path_render_targets, "texpaint_nor_undo" + hid);
- _render_path_paint_texpaint_pack_undo = map_get(render_path_render_targets, "texpaint_pack_undo" + hid);
- _render_path_paint_texpaint_nor = map_get(render_path_render_targets, "texpaint_nor" + tid);
- _render_path_paint_texpaint_pack = map_get(render_path_render_targets, "texpaint_pack" + tid);
- map_set(render_path_render_targets, "texpaint_undo" + hid, map_get(render_path_render_targets, "texpaint" + tid));
- map_set(render_path_render_targets, "texpaint" + tid, map_get(render_path_render_targets, "texpaint_live"));
- if (slot_layer_is_layer(context_raw.layer)) {
- map_set(render_path_render_targets, "texpaint_nor_undo" + hid, map_get(render_path_render_targets, "texpaint_nor" + tid));
- map_set(render_path_render_targets, "texpaint_pack_undo" + hid, map_get(render_path_render_targets, "texpaint_pack" + tid));
- map_set(render_path_render_targets, "texpaint_nor" + tid, map_get(render_path_render_targets, "texpaint_nor_live"));
- map_set(render_path_render_targets, "texpaint_pack" + tid, map_get(render_path_render_targets, "texpaint_pack_live"));
- }
- }
- else {
- map_set(render_path_render_targets, "texpaint" + tid, _render_path_paint_texpaint);
- map_set(render_path_render_targets, "texpaint_undo" + hid, _render_path_paint_texpaint_undo);
- if (slot_layer_is_layer(context_raw.layer)) {
- map_set(render_path_render_targets, "texpaint_nor_undo" + hid, _render_path_paint_texpaint_nor_undo);
- map_set(render_path_render_targets, "texpaint_pack_undo" + hid, _render_path_paint_texpaint_pack_undo);
- map_set(render_path_render_targets, "texpaint_nor" + tid, _render_path_paint_texpaint_nor);
- map_set(render_path_render_targets, "texpaint_pack" + tid, _render_path_paint_texpaint_pack);
- }
- }
- render_path_paint_live_layer_locked = use;
- }
- function render_path_paint_commands_live_brush() {
- let tool: workspace_tool_t = context_raw.tool;
- if (tool != workspace_tool_t.BRUSH &&
- tool != workspace_tool_t.ERASER &&
- tool != workspace_tool_t.CLONE &&
- tool != workspace_tool_t.DECAL &&
- tool != workspace_tool_t.TEXT &&
- tool != workspace_tool_t.BLUR &&
- tool != workspace_tool_t.SMUDGE) {
- return;
- }
- if (render_path_paint_live_layer_locked) {
- return;
- }
- if (render_path_paint_live_layer == null) {
- render_path_paint_live_layer = slot_layer_create("_live");
- }
- let tid: i32 = context_raw.layer.id;
- if (slot_layer_is_mask(context_raw.layer)) {
- render_path_set_target("texpaint_live");
- render_path_bind_target("texpaint" + tid, "tex");
- render_path_draw_shader("shader_datas/copy_pass/copy_pass");
- }
- else {
- let additional: string[] = ["texpaint_nor_live", "texpaint_pack_live"];
- render_path_set_target("texpaint_live", additional);
- render_path_bind_target("texpaint" + tid, "tex0");
- render_path_bind_target("texpaint_nor" + tid, "tex1");
- render_path_bind_target("texpaint_pack" + tid, "tex2");
- render_path_draw_shader("shader_datas/copy_mrt3_pass/copy_mrt3_pass");
- }
- render_path_paint_use_live_layer(true);
- render_path_paint_live_layer_drawn = 2;
- ui_view2d_hwnd.redraws = 2;
- let _x: f32 = context_raw.paint_vec.x;
- let _y: f32 = context_raw.paint_vec.y;
- if (context_raw.brush_locked) {
- context_raw.paint_vec.x = (context_raw.lock_started_x - sys_x()) / sys_w();
- context_raw.paint_vec.y = (context_raw.lock_started_y - sys_y()) / sys_h();
- }
- let _last_x: f32 = context_raw.last_paint_vec_x;
- let _last_y: f32 = context_raw.last_paint_vec_y;
- let _pdirty: i32 = context_raw.pdirty;
- context_raw.last_paint_vec_x = context_raw.paint_vec.x;
- context_raw.last_paint_vec_y = context_raw.paint_vec.y;
- if (operator_shortcut(map_get(config_keymap, "brush_ruler"))) {
- context_raw.last_paint_vec_x = context_raw.last_paint_x;
- context_raw.last_paint_vec_y = context_raw.last_paint_y;
- }
- context_raw.pdirty = 2;
- render_path_paint_commands_symmetry();
- render_path_paint_commands_paint();
- render_path_paint_use_live_layer(false);
- context_raw.paint_vec.x = _x;
- context_raw.paint_vec.y = _y;
- context_raw.last_paint_vec_x = _last_x;
- context_raw.last_paint_vec_y = _last_y;
- context_raw.pdirty = _pdirty;
- context_raw.brush_blend_dirty = true;
- }
- function render_path_paint_commands_cursor() {
- if (!config_raw.brush_3d) {
- return;
- }
- let decal_mask: bool = context_is_decal_mask();
- let tool: workspace_tool_t = context_raw.tool;
- if (tool != workspace_tool_t.BRUSH &&
- tool != workspace_tool_t.ERASER &&
- tool != workspace_tool_t.CLONE &&
- tool != workspace_tool_t.BLUR &&
- tool != workspace_tool_t.SMUDGE &&
- tool != workspace_tool_t.PARTICLE &&
- !decal_mask) {
- return;
- }
- let fill_layer: bool = context_raw.layer.fill_layer != null;
- let group_layer: bool = slot_layer_is_group(context_raw.layer);
- if (!base_ui_enabled || base_is_dragging || fill_layer || group_layer) {
- return;
- }
- let mx: f32 = context_raw.paint_vec.x;
- let my: f32 = 1.0 - context_raw.paint_vec.y;
- if (context_raw.brush_locked) {
- mx = (context_raw.lock_started_x - sys_x()) / sys_w();
- my = 1.0 - (context_raw.lock_started_y - sys_y()) / sys_h();
- }
- let radius: f32 = decal_mask ? context_raw.brush_decal_mask_radius : context_raw.brush_radius;
- render_path_paint_draw_cursor(mx, my, context_raw.brush_nodes_radius * radius / 3.4);
- }
- function render_path_paint_draw_cursor(mx: f32, my: f32, radius: f32, tint_r: f32 = 1.0, tint_g: f32 = 1.0, tint_b: f32 = 1.0) {
- let plane: mesh_object_t = scene_get_child(".Plane").ext;
- let geom: mesh_data_t = plane.data;
- render_path_set_target("");
- gpu_set_pipeline(pipes_cursor);
- let rt: render_target_t = map_get(render_path_render_targets, "main");
- let main: gpu_texture_t = rt._image;
- gpu_set_texture(pipes_cursor_gbufferd, main);
- gpu_set_float2(pipes_cursor_mouse, mx, my);
- gpu_set_float2(pipes_cursor_tex_step, 1 / main.width, 1 / main.height);
- gpu_set_float(pipes_cursor_radius, radius);
- let right: vec4_t = vec4_norm(camera_object_right_world(scene_camera));
- gpu_set_float3(pipes_cursor_camera_right, right.x, right.y, right.z);
- gpu_set_float3(pipes_cursor_tint, tint_r, tint_g, tint_b);
- gpu_set_matrix4(pipes_cursor_vp, scene_camera.vp);
- let inv_vp: mat4_t = mat4_inv(scene_camera.vp);
- gpu_set_matrix4(pipes_cursor_inv_vp, inv_vp);
- gpu_set_vertex_buffer(geom._.vertex_buffer);
- gpu_set_index_buffer(geom._.index_buffers[0]);
- gpu_draw();
- render_path_end();
- }
- function render_path_paint_commands_symmetry() {
- if (context_raw.sym_x || context_raw.sym_y || context_raw.sym_z) {
- context_raw.ddirty = 2;
- let t: transform_t = context_raw.paint_object.base.transform;
- let sx: f32 = t.scale.x;
- let sy: f32 = t.scale.y;
- let sz: f32 = t.scale.z;
- if (context_raw.sym_x) {
- t.scale = vec4_create(-sx, sy, sz);
- transform_build_matrix(t);
- render_path_paint_commands_paint(false);
- }
- if (context_raw.sym_y) {
- t.scale = vec4_create(sx, -sy, sz);
- transform_build_matrix(t);
- render_path_paint_commands_paint(false);
- }
- if (context_raw.sym_z) {
- t.scale = vec4_create(sx, sy, -sz);
- transform_build_matrix(t);
- render_path_paint_commands_paint(false);
- }
- if (context_raw.sym_x && context_raw.sym_y) {
- t.scale = vec4_create(-sx, -sy, sz);
- transform_build_matrix(t);
- render_path_paint_commands_paint(false);
- }
- if (context_raw.sym_x && context_raw.sym_z) {
- t.scale = vec4_create(-sx, sy, -sz);
- transform_build_matrix(t);
- render_path_paint_commands_paint(false);
- }
- if (context_raw.sym_y && context_raw.sym_z) {
- t.scale = vec4_create(sx, -sy, -sz);
- transform_build_matrix(t);
- render_path_paint_commands_paint(false);
- }
- if (context_raw.sym_x && context_raw.sym_y && context_raw.sym_z) {
- t.scale = vec4_create(-sx, -sy, -sz);
- transform_build_matrix(t);
- render_path_paint_commands_paint(false);
- }
- t.scale = vec4_create(sx, sy, sz);
- transform_build_matrix(t);
- }
- }
- function render_path_paint_paint_enabled(): bool {
- let fill_layer: bool = context_raw.layer.fill_layer != null && context_raw.tool != workspace_tool_t.PICKER && context_raw.tool != workspace_tool_t.MATERIAL && context_raw.tool != workspace_tool_t.COLORID;
- let group_layer: bool = slot_layer_is_group(context_raw.layer);
- let gizmo: bool = context_raw.tool == workspace_tool_t.GIZMO;
- return !fill_layer && !group_layer && !context_raw.foreground_event && !gizmo;
- }
- function render_path_paint_live_brush_dirty() {
- let mx: f32 = render_path_paint_last_x;
- let my: f32 = render_path_paint_last_y;
- render_path_paint_last_x = mouse_view_x();
- render_path_paint_last_y = mouse_view_y();
- if (config_raw.brush_live && context_raw.pdirty <= 0) {
- let moved: bool = (mx != render_path_paint_last_x || my != render_path_paint_last_y) && (context_in_viewport() || context_in_2d_view());
- if (moved || context_raw.brush_locked) {
- context_raw.rdirty = 2;
- }
- }
- }
- function render_path_paint_begin() {
- if (!render_path_paint_dilated) {
- render_path_paint_dilate(config_raw.dilate == dilate_type_t.DELAYED, true);
- render_path_paint_dilated = true;
- }
- if (!render_path_paint_paint_enabled()) {
- return;
- }
- render_path_paint_push_undo_last = history_push_undo;
- if (history_push_undo && history_undo_layers != null) {
- history_paint();
- }
- if (context_raw.paint2d) {
- render_path_paint_set_plane_mesh();
- }
- if (render_path_paint_live_layer_drawn > 0) {
- render_path_paint_live_layer_drawn--;
- }
- if (config_raw.brush_live && context_raw.pdirty <= 0 && context_raw.ddirty <= 0 && context_raw.brush_time == 0) {
- // Depth is unchanged, draw before gbuffer gets updated
- render_path_paint_commands_live_brush();
- }
- }
- function render_path_paint_end() {
- context_raw.ddirty--;
- context_raw.rdirty--;
- if (!render_path_paint_paint_enabled()) {
- return;
- }
- context_raw.pdirty--;
- }
- let _render_path_paint_bake_type: bake_type_t;
- function _render_path_paint_final() {
- context_raw.bake_type = _render_path_paint_bake_type;
- make_material_parse_paint_material();
- context_raw.pdirty = 1;
- render_path_paint_commands_paint();
- context_raw.pdirty = 0;
- render_path_paint_baking = false;
- }
- function _render_path_paint_deriv() {
- context_raw.bake_type = bake_type_t.HEIGHT;
- make_material_parse_paint_material();
- context_raw.pdirty = 1;
- render_path_paint_commands_paint();
- context_raw.pdirty = 0;
- if (render_path_paint_push_undo_last) {
- history_paint();
- }
- sys_notify_on_init(_render_path_paint_final);
- }
- function render_path_paint_is_rt_bake(): bool {
- return (context_raw.bake_type == bake_type_t.AO ||
- context_raw.bake_type == bake_type_t.LIGHTMAP ||
- context_raw.bake_type == bake_type_t.BENT_NORMAL ||
- context_raw.bake_type == bake_type_t.THICKNESS);
- }
- function render_path_paint_update_bake_layer(bits: texture_bits_t) {
- // Use RGBA128 texture format for high poly to low poly baking to prevent artifacts
- // Existing undo layers are used during the baking process for now
- if (base_bits_handle.position != texture_bits_t.BITS32) {
- base_bits_handle.position = bits;
- slot_layer_resize_and_set_bits(context_raw.layer);
- for (let i: i32 = 0; i < history_undo_layers.length; ++i) {
- let l: slot_layer_t = history_undo_layers[i];
- slot_layer_resize_and_set_bits(l);
- }
- base_bits_handle.position = texture_bits_t.BITS8;
- }
- }
- function render_path_paint_draw() {
- if (!render_path_paint_paint_enabled()) {
- return;
- }
- ///if (!arm_ios) // No hover on iPad, decals are painted by pen release
- if (config_raw.brush_live && context_raw.pdirty <= 0 && context_raw.ddirty > 0 && context_raw.brush_time == 0) {
- // gbuffer has been updated now but brush will lag 1 frame
- render_path_paint_commands_live_brush();
- }
- ///end
- if (history_undo_layers != null) {
- render_path_paint_commands_symmetry();
- if (context_raw.pdirty > 0) {
- render_path_paint_dilated = false;
- }
- if (context_raw.tool == workspace_tool_t.BAKE) {
- if (context_raw.bake_type == bake_type_t.NORMAL || context_raw.bake_type == bake_type_t.HEIGHT || context_raw.bake_type == bake_type_t.DERIVATIVE) {
- if (!render_path_paint_baking && context_raw.pdirty > 0) {
- render_path_paint_update_bake_layer(texture_bits_t.BITS32);
- render_path_paint_baking = true;
- _render_path_paint_bake_type = context_raw.bake_type;
- context_raw.bake_type = context_raw.bake_type == bake_type_t.NORMAL ? bake_type_t.NORMAL_OBJECT : bake_type_t.POSITION; // Bake high poly data
- make_material_parse_paint_material();
- let _paint_object: mesh_object_t = context_raw.paint_object;
- let high_poly: mesh_object_t = project_paint_objects[context_raw.bake_high_poly];
- let _visible: bool = high_poly.base.visible;
- high_poly.base.visible = true;
- context_select_paint_object(high_poly);
- render_path_paint_commands_paint();
- high_poly.base.visible = _visible;
- if (render_path_paint_push_undo_last) {
- history_paint();
- }
- context_select_paint_object(_paint_object);
- if (context_raw.bake_type == bake_type_t.DERIVATIVE) {
- sys_notify_on_init(_render_path_paint_deriv);
- }
- else {
- sys_notify_on_init(_render_path_paint_final);
- }
- }
- }
- else if (context_raw.bake_type == bake_type_t.OBJECTID) {
- let _layer_filter: i32 = context_raw.layer_filter;
- let _paint_object: mesh_object_t = context_raw.paint_object;
- let is_merged: bool = context_raw.merged_object != null;
- let _visible: bool = is_merged && context_raw.merged_object.base.visible;
- context_raw.layer_filter = 1;
- if (is_merged) {
- context_raw.merged_object.base.visible = false;
- }
- for (let i: i32 = 0; i < project_paint_objects.length; ++i) {
- let p: mesh_object_t = project_paint_objects[i];
- context_select_paint_object(p);
- render_path_paint_commands_paint();
- }
- context_raw.layer_filter = _layer_filter;
- context_select_paint_object(_paint_object);
- if (is_merged) context_raw.merged_object.base.visible = _visible;
- }
- else if (render_path_paint_is_rt_bake()) {
- let dirty: bool = render_path_raytrace_bake_commands(make_material_parse_paint_material);
- if (dirty) ui_header_handle.redraws = 2;
- if (config_raw.dilate == dilate_type_t.INSTANT) { // && raw.pdirty == 1
- render_path_paint_dilate(true, false);
- }
- }
- else {
- render_path_paint_commands_paint();
- }
- }
- else { // Paint
- render_path_paint_commands_paint();
- }
- }
- if (context_raw.brush_blend_dirty) {
- context_raw.brush_blend_dirty = false;
- render_path_set_target("texpaint_blend0", null, null, clear_flag_t.COLOR, 0x00000000);
- render_path_set_target("texpaint_blend1", null, null, clear_flag_t.COLOR, 0x00000000);
- render_path_end();
- }
- if (context_raw.paint2d) {
- render_path_paint_restore_plane_mesh();
- }
- }
- function render_path_paint_set_plane_mesh() {
- context_raw.paint2d_view = true;
- render_path_paint_painto = context_raw.paint_object;
- render_path_paint_visibles = [];
- for (let i: i32 = 0; i < project_paint_objects.length; ++i) {
- let p: mesh_object_t = project_paint_objects[i];
- array_push(render_path_paint_visibles, p.base.visible);
- p.base.visible = false;
- }
- if (context_raw.merged_object != null) {
- render_path_paint_merged_object_visible = context_raw.merged_object.base.visible;
- context_raw.merged_object.base.visible = false;
- }
- let cam: camera_object_t = scene_camera;
- context_raw.saved_camera = mat4_clone(cam.base.transform.local);
- render_path_paint_saved_fov = cam.data.fov;
- viewport_update_camera_type(camera_type_t.PERSPECTIVE);
- let m: mat4_t = mat4_identity();
- m = mat4_translate(m, 0, 0, 0.5);
- transform_set_matrix(cam.base.transform, m);
- cam.data.fov = base_default_fov;
- camera_object_build_proj(cam);
- camera_object_build_mat(cam);
- let tw: f32 = 0.95 * ui_view2d_pan_scale;
- let tx: f32 = ui_view2d_pan_x / ui_view2d_ww;
- let ty: f32 = ui_view2d_pan_y / sys_h();
- m = mat4_identity();
- m = mat4_scale(m, vec4_create(tw, tw, 1));
- m = mat4_set_loc(m, vec4_create(tx, ty, 0));
- let m2: mat4_t = mat4_identity();
- m2 = mat4_inv(scene_camera.vp);
- m = mat4_mult_mat(m, m2);
- let tiled: bool = ui_view2d_tiled_show;
- if (tiled && scene_get_child(".PlaneTiled") == null) {
- // 3x3 planes
- let posa: i16[] = [32767,0,-32767,0,10922,0,-10922,0,10922,0,-32767,0,10922,0,-10922,0,-10922,0,10922,0,-10922,0,-10922,0,-10922,0,10922,0,-32767,0,32767,0,-32767,0,10922,0,10922,0,10922,0,-10922,0,32767,0,-10922,0,10922,0,32767,0,10922,0,10922,0,32767,0,10922,0,10922,0,-10922,0,-10922,0,-32767,0,10922,0,-32767,0,-10922,0,32767,0,-10922,0,10922,0,10922,0,10922,0,-10922,0,-10922,0,-32767,0,-32767,0,-10922,0,-32767,0,-32767,0,10922,0,-32767,0,-10922,0,-10922,0,-10922,0,-32767,0,32767,0,-32767,0,32767,0,-10922,0,10922,0,-10922,0,10922,0,-10922,0,10922,0,10922,0,-10922,0,10922,0,-10922,0,10922,0,-10922,0,32767,0,-32767,0,32767,0,10922,0,10922,0,10922,0,32767,0,-10922,0,32767,0,32767,0,10922,0,32767,0,32767,0,10922,0,32767,0,-10922,0,-10922,0,-10922,0,10922,0,-32767,0,10922,0,32767,0,-10922,0,32767,0,10922,0,10922,0,10922,0,-10922,0,-32767,0,-10922,0,-10922,0,-32767,0,-10922,0,10922,0,-32767,0,10922,0,-10922,0,-10922,0,-10922,0];
- let nora: i16[] = [0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767,0,-32767];
- let texa: i16[] = [32767,32767,0,0,0,32767,32767,32767,0,0,0,32767,32767,32767,0,0,0,32767,32767,32767,0,0,0,32767,32767,32767,0,0,0,32767,32767,32767,0,0,0,32767,32767,32767,0,0,0,32767,32767,32767,0,0,0,32767,32767,32767,0,0,0,32767,32767,32767,32767,0,0,0,32767,32767,32767,0,0,0,32767,32767,32767,0,0,0,32767,32767,32767,0,0,0,32767,32767,32767,0,0,0,32767,32767,32767,0,0,0,32767,32767,32767,0,0,0,32767,32767,32767,0,0,0,32767,32767,32767,0,0,0];
- let inda: u32[] = [0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53];
- let raw: mesh_data_t = {
- name: ".PlaneTiled",
- vertex_arrays: [
- { attrib: "pos", values: i16_array_create_from_array(posa), data: "short4norm" },
- { attrib: "nor", values: i16_array_create_from_array(nora), data: "short2norm" },
- { attrib: "tex", values: i16_array_create_from_array(texa), data: "short2norm" }
- ],
- index_arrays: [
- { values: u32_array_create_from_array(inda), material: 0 }
- ],
- scale_pos: 1.5,
- scale_tex: 1.0
- };
- let md: mesh_data_t = mesh_data_create(raw);
- let mo: mesh_object_t = scene_get_child(".Plane").ext;
- let materials: material_data_t[] = mo.materials;
- let o: mesh_object_t = scene_add_mesh_object(md, materials);
- o.base.name = ".PlaneTiled";
- }
- render_path_paint_planeo = scene_get_child(tiled ? ".PlaneTiled" : ".Plane").ext;
- render_path_paint_planeo.base.visible = true;
- context_raw.paint_object = render_path_paint_planeo;
- let v: vec4_t = vec4_create();
- v = vec4_create(m.m00, m.m01, m.m02);
- let sx: f32 = vec4_len(v);
- render_path_paint_planeo.base.transform.rot = quat_from_euler(-math_pi() / 2, 0, 0);
- render_path_paint_planeo.base.transform.scale = vec4_create(sx, 1.0, sx);
- render_path_paint_planeo.base.transform.scale.z *= config_get_texture_res_y() / config_get_texture_res_x();
- render_path_paint_planeo.base.transform.loc = vec4_create(m.m30, -m.m31, 0.0);
- transform_build_matrix(render_path_paint_planeo.base.transform);
- }
- function render_path_paint_restore_plane_mesh() {
- context_raw.paint2d_view = false;
- render_path_paint_planeo.base.visible = false;
- render_path_paint_planeo.base.transform.loc = vec4_create(0.0, 0.0, 0.0);
- for (let i: i32 = 0; i < project_paint_objects.length; ++i) {
- project_paint_objects[i].base.visible = render_path_paint_visibles[i];
- }
- if (context_raw.merged_object != null) {
- context_raw.merged_object.base.visible = render_path_paint_merged_object_visible;
- }
- context_raw.paint_object = render_path_paint_painto;
- transform_set_matrix(scene_camera.base.transform, context_raw.saved_camera);
- scene_camera.data.fov = render_path_paint_saved_fov;
- viewport_update_camera_type(context_raw.camera_type);
- camera_object_build_proj(scene_camera);
- camera_object_build_mat(scene_camera);
- render_path_base_draw_gbuffer();
- }
- function render_path_paint_bind_layers() {
- let is_live: bool = config_raw.brush_live && render_path_paint_live_layer_drawn > 0;
- let is_material_tool: bool = context_raw.tool == workspace_tool_t.MATERIAL;
- if (is_live || is_material_tool) {
- render_path_paint_use_live_layer(true);
- }
- for (let i: i32 = 0; i < project_layers.length; ++i) {
- let l: slot_layer_t = project_layers[i];
- render_path_bind_target("texpaint" + l.id, "texpaint" + l.id);
- if (slot_layer_is_layer(l)) {
- render_path_bind_target("texpaint_nor" + l.id, "texpaint_nor" + l.id);
- render_path_bind_target("texpaint_pack" + l.id, "texpaint_pack" + l.id);
- }
- }
- }
- function render_path_paint_unbind_layers() {
- let is_live: bool = config_raw.brush_live && render_path_paint_live_layer_drawn > 0;
- let is_material_tool: bool = context_raw.tool == workspace_tool_t.MATERIAL;
- if (is_live || is_material_tool) {
- render_path_paint_use_live_layer(false);
- }
- }
- function render_path_paint_dilate(base: bool, nor_pack: bool) {
- if (config_raw.dilate_radius > 0 && !context_raw.paint2d) {
- util_uv_cache_dilate_map();
- layers_make_temp_img();
- let tid: i32 = context_raw.layer.id;
- let format: string = base_bits_handle.position == texture_bits_t.BITS8 ? "RGBA32" :
- base_bits_handle.position == texture_bits_t.BITS16 ? "RGBA64" :
- "RGBA128";
- let copy_pass: string = format == "RGBA64" ? "copyRGBA64_pass" :
- format == "RGBA128" ? "copyRGBA128_pass" :
- "copy_pass";
- let dilate_pass: string = format == "RGBA64" ? "dilateRGBA64_pass" :
- format == "RGBA128" ? "dilateRGBA128_pass" :
- "dilate_pass";
- if (base) {
- let texpaint: string = "texpaint";
- render_path_set_target("temptex0");
- render_path_bind_target(texpaint + tid, "tex");
- render_path_draw_shader("shader_datas/copy_pass/" + copy_pass);
- render_path_set_target(texpaint + tid);
- render_path_bind_target("temptex0", "tex");
- render_path_draw_shader("shader_datas/dilate_pass/" + dilate_pass);
- }
- if (nor_pack && !slot_layer_is_mask(context_raw.layer)) {
- render_path_set_target("temptex0");
- render_path_bind_target("texpaint_nor" + tid, "tex");
- render_path_draw_shader("shader_datas/copy_pass/" + copy_pass);
- render_path_set_target("texpaint_nor" + tid);
- render_path_bind_target("temptex0", "tex");
- render_path_draw_shader("shader_datas/dilate_pass/" + dilate_pass);
- render_path_set_target("temptex0");
- render_path_bind_target("texpaint_pack" + tid, "tex");
- render_path_draw_shader("shader_datas/copy_pass/" + copy_pass);
- render_path_set_target("texpaint_pack" + tid);
- render_path_bind_target("temptex0", "tex");
- render_path_draw_shader("shader_datas/dilate_pass/" + dilate_pass);
- }
- }
- }
|