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
 */


THREE.STLLoader = function () {

23
	THREE.EventDispatcher.call( this );
24 25 26 27 28

};

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 42
			var geometry = scope.parse( event.target.responseText );

			scope.dispatchEvent( { type: 'load', content: geometry } );

			if ( callback ) callback( geometry );
43 44 45

		}, false );

M
Mr.doob 已提交
46
		request.addEventListener( 'progress', function ( event ) {
47 48 49 50 51

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

		}, false );

M
Mr.doob 已提交
52
		request.addEventListener( 'error', function () {
53 54 55 56 57

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

		}, false );

M
Mr.doob 已提交
58 59
		request.open( 'GET', url, true );
		request.send( null );
60

M
Mr.doob 已提交
61 62 63 64 65 66
	},

	parse: function ( data ) {

		var geometry = new THREE.Geometry();

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

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

72
			var text = result[ 0 ];
M
Mr.doob 已提交
73 74

			// Normal
75
			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 已提交
76

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

79
				var normal = new THREE.Vector3( parseFloat( result[ 1 ] ), parseFloat( result[ 3 ] ), parseFloat( result[ 5 ] ) );
80

M
Mr.doob 已提交
81
			}
82

M
Mr.doob 已提交
83
			// Vertex
84
			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;
85

86
			while ( ( result = patternVertex.exec( text ) ) != null ) {
87

88
				geometry.vertices.push( new THREE.Vector3( parseFloat( result[ 1 ] ), parseFloat( result[ 3 ] ), parseFloat( result[ 5 ] ) ) );
89

M
Mr.doob 已提交
90
			}
91

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

M
Mr.doob 已提交
95
		}
96

M
Mr.doob 已提交
97
		geometry.computeCentroids();
M
Mr.doob 已提交
98
		geometry.computeBoundingSphere();
99

100
		return geometry;
101

M
Mr.doob 已提交
102
	}
103 104

};