Editor.ts 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. import EditorUI = require("ui/EditorUI");
  2. import UIEvents = require("ui/UIEvents");
  3. import PlayMode = require("ui/playmode/PlayMode");
  4. import EditorLicense = require("./EditorLicense");
  5. import EditorEvents = require("./EditorEvents");
  6. import Preferences = require("./Preferences");
  7. class Editor extends Atomic.ScriptObject {
  8. project: ToolCore.Project;
  9. editorLicense: EditorLicense;
  10. playMode: PlayMode;
  11. static instance: Editor;
  12. constructor() {
  13. super();
  14. // limit the framerate to limit CPU usage
  15. Atomic.getEngine().maxFps = 60;
  16. Editor.instance = this;
  17. this.initUI();
  18. this.editorLicense = new EditorLicense();
  19. Preferences.getInstance().read();
  20. EditorUI.initialize();
  21. this.playMode = new PlayMode();
  22. Atomic.getResourceCache().autoReloadResources = true;
  23. this.subscribeToEvent(EditorEvents.LoadProject, (data) => this.handleEditorLoadProject(data));
  24. this.subscribeToEvent(EditorEvents.CloseProject, (data) => this.handleEditorCloseProject(data));
  25. this.subscribeToEvent("ProjectUnloaded", (data) => {
  26. Atomic.graphics.windowTitle = "AtomicEditor";
  27. this.handleProjectUnloaded(data)
  28. });
  29. this.subscribeToEvent(EditorEvents.Quit, (data) => this.handleEditorEventQuit(data));
  30. this.subscribeToEvent("ExitRequested", (data) => this.handleExitRequested(data));
  31. this.subscribeToEvent("ProjectLoaded", (data) => {
  32. Atomic.graphics.windowTitle = "AtomicEditor - " + data.projectPath;
  33. Preferences.getInstance().registerRecentProject(data.projectPath);
  34. });
  35. this.parseArguments();
  36. }
  37. initUI() {
  38. var ui = Atomic.ui;
  39. ui.loadSkin("AtomicEditor/resources/default_skin/skin.tb.txt", "AtomicEditor/editor/skin/skin.tb.txt");
  40. ui.addFont("AtomicEditor/resources/vera.ttf", "Vera");
  41. ui.addFont("AtomicEditor/resources/MesloLGS-Regular.ttf", "Monaco");
  42. ui.setDefaultFont("Vera", 12);
  43. }
  44. handleEditorLoadProject(event: EditorEvents.LoadProjectEvent): boolean {
  45. var system = ToolCore.getToolSystem();
  46. if (system.project) {
  47. this.sendEvent(UIEvents.MessageModalEvent,
  48. { type: "error", title: "Project already loaded", message: "Project already loaded" });
  49. return false;
  50. }
  51. return system.loadProject(event.path);
  52. }
  53. handleEditorCloseProject(event) {
  54. var system = ToolCore.getToolSystem();
  55. if (system.project) {
  56. system.closeProject();
  57. }
  58. }
  59. handleProjectUnloaded(event) {
  60. this.sendEvent(EditorEvents.ActiveSceneChange, { scene: null });
  61. }
  62. parseArguments() {
  63. var args = Atomic.getArguments();
  64. var idx = 0;
  65. while (idx < args.length) {
  66. if (args[idx] == "--project") {
  67. this.sendEvent(EditorEvents.LoadProject, { path: args[idx + 1] });
  68. }
  69. idx++;
  70. }
  71. }
  72. // event handling
  73. handleExitRequested(data) {
  74. Preferences.getInstance().write();
  75. EditorUI.shutdown();
  76. }
  77. handleEditorEventQuit(data) {
  78. this.sendEvent("ExitRequested");
  79. }
  80. }
  81. export = Editor;