CmdSetGeometry.js 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. /**
  2. * Created by Daniel on 21.07.15.
  3. */
  4. CmdSetGeometry = function ( object, newGeometry ) {
  5. Cmd.call( this );
  6. this.type = 'CmdSetGeometry';
  7. this.updatable = true;
  8. this.object = object;
  9. this.objectUuid = object !== undefined ? object.uuid : undefined;
  10. this.newGeometry = newGeometry; // only needed for update(cmd)
  11. this.oldGeometryJSON = object !== undefined ? object.geometry.toJSON() : undefined;
  12. this.newGeometryJSON = newGeometry !== undefined ? newGeometry.toJSON() : undefined;
  13. };
  14. CmdSetGeometry.prototype = {
  15. execute: function () {
  16. this.object.geometry.dispose();
  17. this.object.geometry = this.parseGeometry( this.newGeometryJSON );
  18. this.object.geometry.computeBoundingSphere();
  19. this.editor.signals.geometryChanged.dispatch( this.object );
  20. this.editor.signals.sceneGraphChanged.dispatch();
  21. },
  22. undo: function () {
  23. this.object.geometry.dispose();
  24. this.object.geometry = this.parseGeometry( this.oldGeometryJSON );
  25. this.object.geometry.computeBoundingSphere();
  26. this.editor.signals.geometryChanged.dispatch( this.object );
  27. this.editor.signals.sceneGraphChanged.dispatch();
  28. },
  29. update: function ( cmd ) {
  30. this.newGeometryJSON = cmd.newGeometry.toJSON();
  31. },
  32. toJSON: function () {
  33. var output = Cmd.prototype.toJSON.call( this );
  34. output.objectUuid = this.objectUuid;
  35. output.oldGeometryJSON = this.oldGeometryJSON;
  36. output.newGeometryJSON = this.newGeometryJSON;
  37. return output;
  38. },
  39. fromJSON: function ( json ) {
  40. Cmd.prototype.fromJSON.call( this, json );
  41. this.object = this.editor.objectByUuid( json.objectUuid );
  42. this.objectUuid = json.objectUuid;
  43. this.oldGeometryJSON = json.oldGeometryJSON;
  44. this.newGeometryJSON = json.newGeometryJSON;
  45. },
  46. parseGeometry: function ( data ) {
  47. var geometryLoader = new THREE.JSONLoader();
  48. var bufferGeometryLoader = new THREE.BufferGeometryLoader();
  49. var geometry;
  50. switch ( data.type ) {
  51. case 'PlaneGeometry':
  52. case 'PlaneBufferGeometry':
  53. geometry = new THREE[ data.type ](
  54. data.width,
  55. data.height,
  56. data.widthSegments,
  57. data.heightSegments
  58. );
  59. break;
  60. case 'BoxGeometry':
  61. case 'CubeGeometry': // backwards compatible
  62. geometry = new THREE.BoxGeometry(
  63. data.width,
  64. data.height,
  65. data.depth,
  66. data.widthSegments,
  67. data.heightSegments,
  68. data.depthSegments
  69. );
  70. break;
  71. case 'CircleGeometry':
  72. geometry = new THREE.CircleGeometry(
  73. data.radius,
  74. data.segments
  75. );
  76. break;
  77. case 'CylinderGeometry':
  78. geometry = new THREE.CylinderGeometry(
  79. data.radiusTop,
  80. data.radiusBottom,
  81. data.height,
  82. data.radialSegments,
  83. data.heightSegments,
  84. data.openEnded
  85. );
  86. break;
  87. case 'SphereGeometry':
  88. geometry = new THREE.SphereGeometry(
  89. data.radius,
  90. data.widthSegments,
  91. data.heightSegments,
  92. data.phiStart,
  93. data.phiLength,
  94. data.thetaStart,
  95. data.thetaLength
  96. );
  97. break;
  98. case 'IcosahedronGeometry':
  99. geometry = new THREE.IcosahedronGeometry(
  100. data.radius,
  101. data.detail
  102. );
  103. break;
  104. case 'TorusGeometry':
  105. geometry = new THREE.TorusGeometry(
  106. data.radius,
  107. data.tube,
  108. data.radialSegments,
  109. data.tubularSegments,
  110. data.arc
  111. );
  112. break;
  113. case 'TorusKnotGeometry':
  114. geometry = new THREE.TorusKnotGeometry(
  115. data.radius,
  116. data.tube,
  117. data.radialSegments,
  118. data.tubularSegments,
  119. data.p,
  120. data.q,
  121. data.heightScale
  122. );
  123. break;
  124. case 'BufferGeometry':
  125. geometry = bufferGeometryLoader.parse( data );
  126. break;
  127. case 'Geometry':
  128. geometry = geometryLoader.parse( data.data ).geometry;
  129. break;
  130. }
  131. geometry.uuid = data.uuid;
  132. geometry.name = data.name !== undefined ? data.name : '';
  133. return geometry;
  134. }
  135. };