STLLoader.js 2.5 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

31
	load: function ( url, callback ) {
32

M
Mr.doob 已提交
33
		var scope = this;
M
Mr.doob 已提交
34
		var request = new XMLHttpRequest();
35

M
Mr.doob 已提交
36
		request.addEventListener( 'load', function ( event ) {
37 38 39 40 41

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

		}, false );

M
Mr.doob 已提交
42
		request.addEventListener( 'progress', function ( event ) {
43 44 45 46 47

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

		}, false );

M
Mr.doob 已提交
48
		request.addEventListener( 'error', function () {
49 50 51 52 53

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

		}, false );

54 55 56 57 58 59 60 61 62 63
		if ( callback ) {

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

				callback( event.content );

			} );

		}

M
Mr.doob 已提交
64 65
		request.open( 'GET', url, true );
		request.send( null );
66

M
Mr.doob 已提交
67 68 69 70 71 72
	},

	parse: function ( data ) {

		var geometry = new THREE.Geometry();

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

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

78
			var text = result[ 0 ];
M
Mr.doob 已提交
79 80

			// Normal
81
			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 已提交
82

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

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

M
Mr.doob 已提交
87
			}
88

M
Mr.doob 已提交
89
			// Vertex
90
			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;
91

92
			while( ( result = patternVertex.exec( text ) ) != null ) {
93

94 95 96
				geometry.vertices.push(
					new THREE.Vector3( result[ 1 ], result[ 3 ], result[ 5 ] )
				);
97

M
Mr.doob 已提交
98
			}
99

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

M
Mr.doob 已提交
103
		}
104

M
Mr.doob 已提交
105
		geometry.computeCentroids();
M
Mr.doob 已提交
106
		geometry.computeBoundingSphere();
107

108
		return geometry;
109

M
Mr.doob 已提交
110
	}
111 112

};