console.ts 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. let console_message: string = "";
  2. let console_message_timer: f32 = 0.0;
  3. let console_message_color: i32 = 0x00000000;
  4. let console_last_traces: string[] = [""];
  5. let console_progress_text: string = null;
  6. function console_draw_toast(s: string) {
  7. g2_set_color(0x55000000);
  8. g2_fill_rect(0, 0, sys_width(), sys_height());
  9. let scale: f32 = ui_SCALE(base_get_uis()[0]);
  10. let x: f32 = sys_width() / 2;
  11. let y: f32 = sys_height() - 200 * scale;
  12. g2_fill_rect(x - 200 * scale, y, 400 * scale, 80 * scale);
  13. g2_set_font(base_font);
  14. g2_set_font_size(math_floor(22 * scale));
  15. g2_set_color(0xffffffff);
  16. g2_draw_string(s, x - g2_font_width(_g2_font, _g2_font_size, s) / 2, y + 40 * scale - g2_font_height(_g2_font, _g2_font_size) / 2);
  17. }
  18. function _console_toast_render(s: string) {
  19. console_draw_toast(s);
  20. iron_g4_swap_buffers();
  21. app_remove_render_2d(_console_toast_render);
  22. }
  23. function console_toast(s: string) {
  24. // Show a popup message
  25. app_notify_on_render_2d(_console_toast_render, s);
  26. console_trace(s);
  27. iron_g4_swap_buffers();
  28. }
  29. function console_draw_progress() {
  30. console_draw_toast(console_progress_text);
  31. }
  32. function console_progress(s: string) {
  33. // Keep popup message displayed until s == null
  34. if (s == null) {
  35. app_remove_render_2d(console_draw_progress);
  36. }
  37. else if (console_progress_text == null) {
  38. app_notify_on_render_2d(console_draw_progress);
  39. }
  40. if (s != null) {
  41. console_trace(s);
  42. }
  43. console_progress_text = s;
  44. // Pass one frame to immediately show the message
  45. ///if (!arm_vulkan) // TODO
  46. ui_end_input();
  47. g2_end();
  48. app_render();
  49. g2_begin();
  50. iron_g4_swap_buffers();
  51. ///end
  52. }
  53. function console_info(s: string) {
  54. console_message_timer = 5.0;
  55. console_message = s;
  56. console_message_color = 0x00000000;
  57. base_redraw_status();
  58. console_trace(s);
  59. }
  60. function console_error(s: string) {
  61. console_message_timer = 8.0;
  62. console_message = s;
  63. console_message_color = 0xffaa0000;
  64. base_redraw_status();
  65. console_trace(s);
  66. }
  67. function console_log(s: string) {
  68. console_trace(s);
  69. }
  70. function console_trace(s: string) {
  71. iron_log(s);
  72. base_redraw_console();
  73. array_insert(console_last_traces, 0, s);
  74. if (console_last_traces.length > 100) {
  75. array_pop(console_last_traces);
  76. }
  77. }