STLLoader.js 2.3 KB
Newer Older
1 2 3 4
/**
 * @author aleeper / http://adamleeper.com/
 * @author mrdoob / http://mrdoob.com/
 *
M
Mr.doob 已提交
5
 * Description: A THREE loader for STL ASCII files, as created by Solidworks and other CAD programs.
6 7 8 9
 *
 * Limitations: Currently supports ASCII format only
 *
 * Usage:
M
Mr.doob 已提交
10 11
 * 	var loader = new THREE.STLLoader();
 * 	loader.addEventListener( 'load', function ( event ) {
12
 *
13 14
 * 		var geometry = event.content;
 * 		scene.add( new THREE.Mesh( geometry ) );
M
Mr.doob 已提交
15 16 17
 *
 * 	} );
 * 	loader.load( './models/stl/slotted_disk.stl' );
18 19 20 21 22 23 24 25 26 27 28
 */


THREE.STLLoader = function () {

	THREE.EventTarget.call( this );

};

THREE.STLLoader.prototype = {

M
Mr.doob 已提交
29
	constructor: THREE.STLLoader,
30

M
Mr.doob 已提交
31
	load: function ( url ) {
32

M
Mr.doob 已提交
33 34
		var scope = this;
		var xhr = new XMLHttpRequest();
35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56

		xhr.addEventListener( 'load', function ( event ) {

			scope.dispatchEvent( { type: 'load', content: scope.parse( event.target.responseText ) } );

		}, false );

		xhr.addEventListener( 'progress', function ( event ) {

			scope.dispatchEvent( { type: 'progress', loaded: event.loaded, total: event.total } );

		}, false );

		xhr.addEventListener( 'error', function () {

			scope.dispatchEvent( { type: 'error', message: 'Couldn\'t load URL [' + url + ']' } );

		}, false );

		xhr.open( 'GET', url, true );
		xhr.send( null );

M
Mr.doob 已提交
57 58 59 60 61 62
	},

	parse: function ( data ) {

		var geometry = new THREE.Geometry();

63 64
		var patternFace = /facet([\s\S]*?)endfacet/g;
		var result;
M
Mr.doob 已提交
65

66
		while ( ( result = patternFace.exec( data ) ) != null ) {
M
Mr.doob 已提交
67

68
			var text = result[ 0 ];
M
Mr.doob 已提交
69 70

			// Normal
71
			var patternNormal = /normal[\s]+([-+]?[0-9]+\.?[0-9]*([eE][-+]?[0-9]+)?)+[\s]+([-+]?[0-9]*\.?[0-9]+([eE][-+]?[0-9]+)?)+[\s]+([-+]?[0-9]*\.?[0-9]+([eE][-+]?[0-9]+)?)+/g;
M
Mr.doob 已提交
72

73
			while( ( result = patternNormal.exec( text ) ) != null ) {
M
Mr.doob 已提交
74

75
				var normal = new THREE.Vector3( result[ 1 ], result[ 3 ], result[ 5 ] );
76

M
Mr.doob 已提交
77
			}
78

M
Mr.doob 已提交
79
			// Vertex
80
			var patternVertex = /vertex[\s]+([-+]?[0-9]+\.?[0-9]*([eE][-+]?[0-9]+)?)+[\s]+([-+]?[0-9]*\.?[0-9]+([eE][-+]?[0-9]+)?)+[\s]+([-+]?[0-9]*\.?[0-9]+([eE][-+]?[0-9]+)?)+/g;
81

82
			while( ( result = patternVertex.exec( text ) ) != null ) {
83

84 85 86
				geometry.vertices.push(
					new THREE.Vector3( result[ 1 ], result[ 3 ], result[ 5 ] )
				);
87

M
Mr.doob 已提交
88
			}
89

M
Mr.doob 已提交
90
			var len = geometry.vertices.length;
91
			geometry.faces.push( new THREE.Face3( len - 3, len - 2, len - 1, normal ) );
92

M
Mr.doob 已提交
93
		}
94

M
Mr.doob 已提交
95
		geometry.computeCentroids();
96

97
		return geometry;
98

M
Mr.doob 已提交
99
	}
100 101

};