ObjectExporter.js 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270
  1. /**
  2. * @author mrdoob / http://mrdoob.com/
  3. */
  4. THREE.ObjectExporter = function () {};
  5. THREE.ObjectExporter.prototype = {
  6. constructor: THREE.ObjectExporter,
  7. parse: function ( object ) {
  8. // console.log( object );
  9. var output = {
  10. metadata: {
  11. version: 4.0,
  12. type: 'object',
  13. generator: 'ObjectExporter'
  14. }
  15. };
  16. //
  17. var geometries = {};
  18. var geometryExporter = new THREE.GeometryExporter();
  19. var parseGeometry = function ( geometry ) {
  20. if ( geometries[ geometry.id ] === undefined ) {
  21. if ( output.geometries === undefined ) {
  22. output.geometries = [];
  23. }
  24. geometries[ geometry.id ] = output.geometries.length;
  25. var data = {};
  26. if ( geometry.name !== "" ) data.name = geometry.name;
  27. if ( geometry.uuid !== "" ) data.uuid = geometry.uuid;
  28. if ( geometry instanceof THREE.PlaneGeometry ) {
  29. data.type = 'PlaneGeometry';
  30. data.width = geometry.width;
  31. data.height = geometry.height;
  32. data.widthSegments = geometry.widthSegments;
  33. data.heightSegments = geometry.heightSegments;
  34. } else if ( geometry instanceof THREE.CubeGeometry ) {
  35. data.type = 'CubeGeometry';
  36. data.width = geometry.width;
  37. data.height = geometry.height;
  38. data.depth = geometry.depth;
  39. data.widthSegments = geometry.widthSegments;
  40. data.heightSegments = geometry.heightSegments;
  41. data.depthSegments = geometry.depthSegments;
  42. } else if ( geometry instanceof THREE.CylinderGeometry ) {
  43. data.type = 'CylinderGeometry';
  44. data.radiusTop = geometry.radiusTop;
  45. data.radiusBottom = geometry.radiusBottom;
  46. data.height = geometry.height;
  47. data.radiusSegments = geometry.radiusSegments;
  48. data.heightSegments = geometry.heightSegments;
  49. data.openEnded = data.openEnded;
  50. } else if ( geometry instanceof THREE.SphereGeometry ) {
  51. data.type = 'SphereGeometry';
  52. data.radius = geometry.radius;
  53. data.widthSegments = geometry.widthSegments;
  54. data.heightSegments = geometry.heightSegments;
  55. data.phiStart = geometry.phiStart;
  56. data.phiLength = geometry.phiLength;
  57. data.thetaStart = geometry.thetaStart;
  58. data.thetaLength = geometry.thetaLength;
  59. } else if ( geometry instanceof THREE.IcosahedronGeometry ) {
  60. data.type = 'IcosahedronGeometry';
  61. data.radius = geometry.radius;
  62. data.detail = geometry.detail;
  63. } else if ( geometry instanceof THREE.TorusGeometry ) {
  64. data.type = 'TorusGeometry';
  65. data.radius = geometry.radius;
  66. data.tube = geometry.tube;
  67. data.radialSegments = geometry.radialSegments;
  68. data.tubularSegments = geometry.tubularSegments;
  69. data.arc = geometry.arc;
  70. } else if ( geometry instanceof THREE.TorusKnotGeometry ) {
  71. data.type = 'TorusKnotGeometry';
  72. data.radius = geometry.radius;
  73. data.tube = geometry.tube;
  74. data.radialSegments = geometry.radialSegments;
  75. data.tubularSegments = geometry.tubularSegments;
  76. data.p = geometry.p;
  77. data.q = geometry.q;
  78. data.heightScale = geometry.heightScale;
  79. } else if ( geometry instanceof THREE.Geometry ) {
  80. data.type = 'Geometry';
  81. data.data = geometryExporter.parse( geometry );
  82. delete data.data.metadata;
  83. }
  84. output.geometries.push( data );
  85. }
  86. return geometries[ geometry.id ];
  87. };
  88. //
  89. var materials = {};
  90. var materialExporter = new THREE.MaterialExporter();
  91. var parseMaterial = function ( material ) {
  92. if ( materials[ material.id ] === undefined ) {
  93. if ( output.materials === undefined ) {
  94. output.materials = [];
  95. }
  96. materials[ material.id ] = output.materials.length;
  97. var data = materialExporter.parse( material );
  98. delete data.metadata;
  99. output.materials.push( data );
  100. }
  101. return materials[ material.id ];
  102. };
  103. //
  104. var parseObject = function ( object ) {
  105. var data = {};
  106. if ( object.name !== '' ) data.name = object.name;
  107. if ( object.uuid !== '' ) data.uuid = object.uuid;
  108. if ( JSON.stringify( object.userData ) !== '{}' ) data.userData = object.userData;
  109. if ( object.visible !== true ) data.visible = object.visible;
  110. if ( object instanceof THREE.Scene ) {
  111. data.type = 'Scene';
  112. } else if ( object instanceof THREE.PerspectiveCamera ) {
  113. data.type = 'PerspectiveCamera';
  114. data.fov = object.fov;
  115. data.aspect = object.aspect;
  116. data.near = object.near;
  117. data.far = object.far;
  118. data.position = object.position.toArray();
  119. data.rotation = object.rotation.toArray();
  120. } else if ( object instanceof THREE.OrthographicCamera ) {
  121. data.type = 'OrthographicCamera';
  122. data.left = object.left;
  123. data.right = object.right;
  124. data.top = object.top;
  125. data.bottom = object.bottom;
  126. data.near = object.near;
  127. data.far = object.far;
  128. data.position = object.position.toArray();
  129. data.rotation = object.rotation.toArray();
  130. } else if ( object instanceof THREE.AmbientLight ) {
  131. data.type = 'AmbientLight';
  132. data.color = object.color.getHex();
  133. } else if ( object instanceof THREE.DirectionalLight ) {
  134. data.type = 'DirectionalLight';
  135. data.color = object.color.getHex();
  136. data.intensity = object.intensity;
  137. data.position = object.position.toArray();
  138. } else if ( object instanceof THREE.PointLight ) {
  139. data.type = 'PointLight';
  140. data.color = object.color.getHex();
  141. data.intensity = object.intensity;
  142. data.distance = object.distance;
  143. data.position = object.position.toArray();
  144. } else if ( object instanceof THREE.SpotLight ) {
  145. data.type = 'SpotLight';
  146. data.color = object.color.getHex();
  147. data.intensity = object.intensity;
  148. data.distance = object.distance;
  149. data.angle = object.angle;
  150. data.exponent = object.exponent;
  151. data.position = object.position.toArray();
  152. } else if ( object instanceof THREE.HemisphereLight ) {
  153. data.type = 'HemisphereLight';
  154. data.color = object.color.getHex();
  155. data.groundColor = object.groundColor.getHex();
  156. data.position = object.position.toArray();
  157. } else if ( object instanceof THREE.Mesh ) {
  158. data.type = 'Mesh';
  159. data.position = object.position.toArray();
  160. data.rotation = object.rotation.toArray();
  161. data.scale = object.scale.toArray();
  162. data.geometry = parseGeometry( object.geometry );
  163. data.material = parseMaterial( object.material );
  164. } else {
  165. data.type = 'Object3D';
  166. data.position = object.position.toArray();
  167. data.rotation = object.rotation.toArray();
  168. data.scale = object.scale.toArray();
  169. }
  170. if ( object.children.length > 0 ) {
  171. data.children = [];
  172. for ( var i = 0; i < object.children.length; i ++ ) {
  173. data.children.push( parseObject( object.children[ i ] ) );
  174. }
  175. }
  176. return data;
  177. }
  178. output.object = parseObject( object );
  179. return output;
  180. }
  181. }