tab_plugins.ts 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. function tab_plugins_draw(htab: ui_handle_t) {
  2. if (ui_tab(htab, tr("Plugins"))) {
  3. ui_begin_sticky();
  4. ///if is_paint
  5. let row: f32[] = [1 / 4];
  6. ui_row(row);
  7. ///end
  8. ///if is_lab
  9. let row: f32[] = [1 / 14];
  10. ui_row(row);
  11. ///end
  12. if (ui_button(tr("Manager"))) {
  13. box_preferences_htab.position = 6; // Plugins
  14. box_preferences_show();
  15. }
  16. ui_end_sticky();
  17. // Draw plugins
  18. let keys: string[] = map_keys(plugin_map);
  19. for (let i: i32 = 0; i < keys.length; ++i) {
  20. let p: plugin_t = map_get(plugin_map, keys[i]);
  21. if (p.on_ui != null) {
  22. js_call(p.on_ui);
  23. }
  24. }
  25. ///if is_debug
  26. let rt_keys: string[] = map_keys(render_path_render_targets);
  27. array_sort(rt_keys, null);
  28. for (let i: i32 = 0; i < rt_keys.length; ++i) {
  29. let rt: render_target_t = map_get(render_path_render_targets, rt_keys[i]);
  30. ui_text(rt_keys[i]);
  31. ui_image(rt._image);
  32. }
  33. ///end
  34. }
  35. }
  36. function plugin_uv_unwrap_button() {
  37. let cb: any = map_get(util_mesh_unwrappers, "uv_unwrap.js"); // JSValue * -> (a: raw_mesh_t)=>void
  38. for (let i: i32 = 0; i < project_paint_objects.length; ++i) {
  39. let md: mesh_data_t = project_paint_objects[i].data;
  40. let mesh: raw_mesh_t = {
  41. posa: md.vertex_arrays[0].values,
  42. nora: md.vertex_arrays[1].values,
  43. texa: null,
  44. inda: md.index_array
  45. };
  46. js_call_ptr(cb, mesh);
  47. md.vertex_arrays[0].values = mesh.posa;
  48. md.vertex_arrays[1].values = mesh.nora;
  49. md.vertex_arrays[2].values = mesh.texa;
  50. md.index_array = mesh.inda;
  51. mesh_data_build(md);
  52. }
  53. util_mesh_merge();
  54. }