OBJLoader.js 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. /**
  2. * @author mrdoob / http://mrdoob.com/
  3. */
  4. THREE.OBJLoader = function () {};
  5. THREE.OBJLoader.prototype.load = function ( url, callback ) {
  6. var xhr = new XMLHttpRequest();
  7. xhr.onreadystatechange = function () {
  8. if ( xhr.readyState == 4 ) {
  9. if ( xhr.status == 200 || xhr.status == 0 ) {
  10. THREE.OBJLoader.prototype.parse( xhr.responseText, callback );
  11. } else {
  12. console.error( 'THREE.OBJLoader: Couldn\'t load ' + url + ' (' + xhr.status + ')' );
  13. }
  14. }
  15. };
  16. xhr.open( "GET", url, true );
  17. xhr.send( null );
  18. };
  19. THREE.OBJLoader.prototype.parse = function ( data, callback ) {
  20. var geometry = new THREE.Geometry();
  21. console.time( 'THREE.OBJLoader.parse()' );
  22. function vertex( a, b, c ) {
  23. return new THREE.Vector3( parseFloat( a ), parseFloat( b ), parseFloat( c ) );
  24. }
  25. function face3( a, b, c ) {
  26. return new THREE.Face3( parseInt( a ) - 1, parseInt( b ) - 1, parseInt( c ) - 1 );
  27. }
  28. function face4( a, b, c, d ) {
  29. return new THREE.Face4( parseInt( a ) - 1, parseInt( b ) - 1, parseInt( c ) - 1, parseInt( d ) - 1 );
  30. }
  31. var pattern, result;
  32. // v float float float
  33. // ["v 1.0 2.0 3.0", "1.0", "2.0", "3.0"]
  34. pattern = /v( [\-|\d|.]+)( [\-|\d|.]+)( [\-|\d|.]+)/g;
  35. while ( ( result = pattern.exec( data ) ) != null ) {
  36. geometry.vertices.push( vertex( result[ 1 ], result[ 2 ], result[ 3 ] ) );
  37. }
  38. // f vertex vertex vertex ...
  39. // ["f 1 2 3", "1", "2", "3", undefined]
  40. pattern = /f( [\d]+)( [\d]+)( [\d]+)( [\d]+)?/g;
  41. while ( ( result = pattern.exec( data ) ) != null ) {
  42. geometry.faces.push(
  43. result[ 4 ] === undefined ?
  44. face3( result[ 1 ], result[ 2 ], result[ 3 ] ) :
  45. face4( result[ 1 ], result[ 2 ], result[ 3 ], result[ 4 ] )
  46. );
  47. }
  48. // f vertex/uv vertex/uv vertex/uv ...
  49. // ["f 1/1 2/2 3/3", " 1/1", "1", "1", " 2/2", "2", "2", " 3/3", "3", "3", undefined, undefined, undefined]
  50. pattern = /f( ([\d]+)\/([\d]+))( ([\d]+)\/([\d]+))( ([\d]+)\/([\d]+))( ([\d]+)\/([\d]+))?/g;
  51. while ( ( result = pattern.exec( data ) ) != null ) {
  52. geometry.faces.push(
  53. result[ 10 ] === undefined ?
  54. face3( result[ 2 ], result[ 5 ], result[ 8 ] ) :
  55. face4( result[ 2 ], result[ 5 ], result[ 8 ], result[ 11 ] )
  56. );
  57. }
  58. // f vertex/uv/normal vertex/uv/normal vertex/uv/normal ...
  59. // ["f 1/1/1 2/2/2 3/3/3", " 1/1/1", "1", "1", "1", " 2/2/2", "2", "2", "2", " 3/3/3", "3", "3", "3", undefined, undefined, undefined, undefined]
  60. pattern = /f( ([\d]+)\/([\d]+)\/([\d]+))( ([\d]+)\/([\d]+)\/([\d]+))( ([\d]+)\/([\d]+)\/([\d]+))( ([\d]+)\/([\d]+)\/([\d]+))?/g;
  61. while ( ( result = pattern.exec( data ) ) != null ) {
  62. geometry.faces.push(
  63. result[ 13 ] === undefined ?
  64. face3( result[ 2 ], result[ 6 ], result[ 10 ] ) :
  65. face4( result[ 2 ], result[ 6 ], result[ 10 ], result[ 14 ] )
  66. );
  67. }
  68. // f vertex//normal vertex//normal vertex//normal ...
  69. // ["f 1//1 2//2 3//3", " 1//1", "1", "1", " 2//2", "2", "2", " 3//3", "3", "3", undefined, undefined, undefined]
  70. pattern = /f( ([\d]+)\/\/([\d]+))( ([\d]+)\/\/([\d]+))( ([\d]+)\/\/([\d]+))( ([\d]+)\/\/([\d]+))?/g;
  71. while ( ( result = pattern.exec( data ) ) != null ) {
  72. geometry.faces.push(
  73. result[ 10 ] === undefined ?
  74. face3( result[ 2 ], result[ 5 ], result[ 8 ] ) :
  75. face4( result[ 2 ], result[ 5 ], result[ 8 ], result[ 11 ] )
  76. );
  77. }
  78. console.timeEnd( 'THREE.OBJLoader.parse()' );
  79. geometry.computeCentroids();
  80. callback( geometry );
  81. }