ModelInspector.ts 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. import InspectorWidget = require("./InspectorWidget");
  2. import ArrayEditWidget = require("./ArrayEditWidget");
  3. import InspectorUtils = require("./InspectorUtils");
  4. class ModelInspector extends InspectorWidget {
  5. constructor() {
  6. super();
  7. this.subscribeToEvent(this, "WidgetEvent", (data) => this.handleWidgetEvent(data));
  8. }
  9. handleWidgetEvent(ev: Atomic.UIWidgetEvent) {
  10. }
  11. onApply() {
  12. this.importer.scale = Number(this.scaleEdit.text);
  13. this.importer.importAnimations = this.importAnimationBox.value ? true : false;
  14. for (var i = 0; i < this.importer.animationCount; i++) {
  15. var info = this.importer.getAnimationInfo(i);
  16. var nameEdit = this.nameEdits[i];
  17. var startEdit = this.startEdits[i];
  18. var endEdit = this.endEdits[i];
  19. info.name = nameEdit.text;
  20. info.startTime = Number(startEdit.text);
  21. info.endTime = Number(endEdit.text);
  22. }
  23. this.importer.import(this.asset.guid);
  24. this.asset.save();
  25. }
  26. inspect(asset: ToolCore.Asset) {
  27. this.asset = asset;
  28. this.importer = <ToolCore.ModelImporter> asset.importer;
  29. // node attr layout
  30. var rootLayout = this.rootLayout;
  31. // Model Section
  32. var modelLayout = this.createSection(rootLayout, "Model", 1);
  33. this.scaleEdit = this.createAttrEditField("Scale", modelLayout);
  34. this.scaleEdit.text = this.importer.scale.toString();
  35. // Animations Section
  36. var animationLayout = this.createSection(rootLayout, "Animation", 1);
  37. this.importAnimationBox = this.createAttrCheckBox("Import Animations", animationLayout);
  38. this.importAnimationBox.value = this.importer.importAnimations ? 1 : 0;
  39. this.importAnimationArray = new ArrayEditWidget("Animation Count");
  40. animationLayout.addChild(this.importAnimationArray);
  41. this.importAnimationArray.onCountChanged = (count) => this.onAnimationCountChanged(count);
  42. var nlp = new Atomic.UILayoutParams();
  43. nlp.width = 310;
  44. var animLayout = this.animationInfoLayout = new Atomic.UILayout();
  45. animLayout.spacing = 4;
  46. animLayout.layoutDistribution = Atomic.UI_LAYOUT_DISTRIBUTION_GRAVITY;
  47. animLayout.layoutPosition = Atomic.UI_LAYOUT_POSITION_LEFT_TOP;
  48. animLayout.layoutParams = nlp;
  49. animLayout.axis = Atomic.UI_AXIS_Y;
  50. animLayout.gravity = Atomic.UI_GRAVITY_ALL;
  51. animationLayout.addChild(animLayout);
  52. this.createAnimationEntries();
  53. // apply button
  54. rootLayout.addChild(this.createApplyButton());
  55. }
  56. createAnimationEntries() {
  57. var layout = this.animationInfoLayout;
  58. layout.deleteAllChildren();
  59. var count = this.importer.animationCount;
  60. this.importAnimationArray.countEdit.text = count.toString();
  61. this.nameEdits = [];
  62. this.startEdits = [];
  63. this.endEdits = [];
  64. for (var i = 0; i < count; i++) {
  65. var animInfo = this.importer.getAnimationInfo(i);
  66. var name = InspectorUtils.createAttrName("Animation " + i.toString() + ":");
  67. layout.addChild(name);
  68. var nameEdit = InspectorUtils.createAttrEditField("Name", layout);
  69. nameEdit.text = animInfo.name;
  70. var startEdit = InspectorUtils.createAttrEditField("Start", layout);
  71. startEdit.text = animInfo.startTime.toString();
  72. var endEdit = InspectorUtils.createAttrEditField("End", layout);
  73. endEdit.text = animInfo.endTime.toString();
  74. this.nameEdits.push(nameEdit);
  75. this.startEdits.push(startEdit);
  76. this.endEdits.push(endEdit);
  77. InspectorUtils.createSeparator(layout);
  78. }
  79. }
  80. onAnimationCountChanged(count: number) {
  81. if (this.importer.animationCount == count) {
  82. return;
  83. }
  84. this.importer.animationCount = count;
  85. this.createAnimationEntries();
  86. }
  87. // model
  88. scaleEdit: Atomic.UIEditField;
  89. // animation
  90. importAnimationBox: Atomic.UICheckBox;
  91. importAnimationArray: ArrayEditWidget;
  92. animationInfoLayout: Atomic.UILayout;
  93. nameEdits: Atomic.UIEditField[];
  94. startEdits: Atomic.UIEditField[];
  95. endEdits: Atomic.UIEditField[];
  96. asset: ToolCore.Asset;
  97. importer: ToolCore.ModelImporter;
  98. }
  99. export = ModelInspector;