ModelInspector.ts 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  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. // guard against NAN
  21. var _startTime = Number(startEdit.text);
  22. var _endTime = Number(endEdit.text);
  23. if (isNaN(_startTime)) _startTime = 0;
  24. if (isNaN(_endTime)) _endTime = 0;
  25. info.startTime = _startTime;
  26. info.endTime = _endTime;;
  27. }
  28. this.asset.import();
  29. this.asset.save();
  30. }
  31. inspect(asset: ToolCore.Asset) {
  32. this.asset = asset;
  33. this.importer = <ToolCore.ModelImporter> asset.importer;
  34. // node attr layout
  35. var rootLayout = this.rootLayout;
  36. // Model Section
  37. var modelLayout = this.createSection(rootLayout, "Model", 1);
  38. this.scaleEdit = this.createAttrEditField("Scale", modelLayout);
  39. this.scaleEdit.text = this.importer.scale.toString();
  40. // Animations Section
  41. var animationLayout = this.createSection(rootLayout, "Animation", 1);
  42. this.importAnimationBox = this.createAttrCheckBox("Import Animations", animationLayout);
  43. this.importAnimationBox.value = this.importer.importAnimations ? 1 : 0;
  44. this.importAnimationArray = new ArrayEditWidget("Animation Count");
  45. animationLayout.addChild(this.importAnimationArray);
  46. this.importAnimationArray.onCountChanged = (count) => this.onAnimationCountChanged(count);
  47. var nlp = new Atomic.UILayoutParams();
  48. nlp.width = 310;
  49. var animLayout = this.animationInfoLayout = new Atomic.UILayout();
  50. animLayout.spacing = 4;
  51. animLayout.layoutDistribution = Atomic.UI_LAYOUT_DISTRIBUTION_GRAVITY;
  52. animLayout.layoutPosition = Atomic.UI_LAYOUT_POSITION_LEFT_TOP;
  53. animLayout.layoutParams = nlp;
  54. animLayout.axis = Atomic.UI_AXIS_Y;
  55. animLayout.gravity = Atomic.UI_GRAVITY_ALL;
  56. animationLayout.addChild(animLayout);
  57. this.createAnimationEntries();
  58. // apply button
  59. rootLayout.addChild(this.createApplyButton());
  60. }
  61. createAnimationEntries() {
  62. var layout = this.animationInfoLayout;
  63. layout.deleteAllChildren();
  64. var count = this.importer.animationCount;
  65. this.importAnimationArray.countEdit.text = count.toString();
  66. this.nameEdits = [];
  67. this.startEdits = [];
  68. this.endEdits = [];
  69. for (var i = 0; i < count; i++) {
  70. var animInfo = this.importer.getAnimationInfo(i);
  71. var name = InspectorUtils.createAttrName("Animation " + i.toString() + ":");
  72. layout.addChild(name);
  73. var nameEdit = InspectorUtils.createAttrEditField("Name", layout);
  74. nameEdit.text = animInfo.name;
  75. var startEdit = InspectorUtils.createAttrEditField("Start", layout);
  76. startEdit.text = animInfo.startTime.toString();
  77. var endEdit = InspectorUtils.createAttrEditField("End", layout);
  78. endEdit.text = animInfo.endTime.toString();
  79. this.nameEdits.push(nameEdit);
  80. this.startEdits.push(startEdit);
  81. this.endEdits.push(endEdit);
  82. InspectorUtils.createSeparator(layout);
  83. }
  84. }
  85. onAnimationCountChanged(count: number) {
  86. if (this.importer.animationCount == count) {
  87. return;
  88. }
  89. this.importer.animationCount = count;
  90. this.createAnimationEntries();
  91. }
  92. // model
  93. scaleEdit: Atomic.UIEditField;
  94. // animation
  95. importAnimationBox: Atomic.UICheckBox;
  96. importAnimationArray: ArrayEditWidget;
  97. animationInfoLayout: Atomic.UILayout;
  98. nameEdits: Atomic.UIEditField[];
  99. startEdits: Atomic.UIEditField[];
  100. endEdits: Atomic.UIEditField[];
  101. asset: ToolCore.Asset;
  102. importer: ToolCore.ModelImporter;
  103. }
  104. export = ModelInspector;