diff --git a/docs/api/extras/geometries/BoxBufferGeometry.html b/docs/api/extras/geometries/BoxBufferGeometry.html new file mode 100644 index 0000000000000000000000000000000000000000..8d3df72e1472b2ebcdf299d9a575ca5733e15292 --- /dev/null +++ b/docs/api/extras/geometries/BoxBufferGeometry.html @@ -0,0 +1,58 @@ + + +
+ +var geometry = new THREE.BoxBufferGeometry( 1, 1, 1 );
+ var material = new THREE.MeshBasicMaterial( {color: 0x00ff00} );
+ var cube = new THREE.Mesh( geometry, material );
+ scene.add( cube );
+
+
+ Using the above example code above as our basis:
+
+ geometry.parameters; // outputs an object {width: 1, height: 1, depth: 1, widthSegments: undefined, heightSegments: undefined}
+ cube.geometry.parameters; // as above
+ cube.geometry.parameters.width; // === 1
+ cube.geometry.parameters.widthSegments // === undefined.
+
+
+ var geometry = new THREE.CircleBufferGeometry( 5, 32 );
+ var material = new THREE.MeshBasicMaterial( { color: 0xffff00 } );
+ var circle = new THREE.Mesh( geometry, material );
+ scene.add( circle );
+
+
+
+ var material = new THREE.MeshBasicMaterial({
- color: 0x0000ff
- });
-
- var radius = 5;
- var segments = 32;
-
- var circleGeometry = new THREE.CircleGeometry( radius, segments );
- var circle = new THREE.Mesh( circleGeometry, material );
+
+ var geometry = new THREE.CircleGeometry( 5, 32 );
+ var material = new THREE.MeshBasicMaterial( { color: 0xffff00 } );
+ var circle = new THREE.Mesh( geometry, material );
scene.add( circle );
diff --git a/docs/api/extras/geometries/PlaneBufferGeometry.html b/docs/api/extras/geometries/PlaneBufferGeometry.html
new file mode 100644
index 0000000000000000000000000000000000000000..e10a388547c7e7c2df61a167fe135c3bbe668454
--- /dev/null
+++ b/docs/api/extras/geometries/PlaneBufferGeometry.html
@@ -0,0 +1,50 @@
+
+
+
+
+
+
+
+
+
+
+ [page:BufferGeometry] →
+
+ [name]
+
+ This is the [page:BufferGeometry] port of [page:PlaneGeometry].
+
+ Example
+
+
+
+ var geometry = new THREE.PlaneBufferGeometry( 5, 20, 32 );
+ var material = new THREE.MeshBasicMaterial( {color: 0xffff00, side: THREE.DoubleSide} );
+ var plane = new THREE.Mesh( geometry, material );
+ scene.add( plane );
+
+
+
+ Constructor
+
+
+ [name]([page:Float width], [page:Float height], [page:Integer widthSegments], [page:Integer heightSegments])
+
+ width — Width along the X axis.
+ height — Height along the Y axis.
+ widthSegments — Optional. Default is 1.
+ heightSegments — Optional. Default is 1.
+
+
+
+ Properties
+
+
+ Each of the contructor parameters is accessible as a property of the same name. Any modification of these properties after instantiation does not change the geometry.
+
+
+ Source
+
+ [link:https://github.com/mrdoob/three.js/blob/master/src/[path].js src/[path].js]
+
+
diff --git a/docs/api/extras/geometries/SphereBufferGeometry.html b/docs/api/extras/geometries/SphereBufferGeometry.html
new file mode 100644
index 0000000000000000000000000000000000000000..995266b53ed124a505d49eda3f8d820c110f54d4
--- /dev/null
+++ b/docs/api/extras/geometries/SphereBufferGeometry.html
@@ -0,0 +1,57 @@
+
+
+
+
+
+
+
+
+
+
+ [page:BufferGeometry] →
+
+ [name]
+
+ This is the [page:BufferGeometry] port of [page:SphereGeometry].
+
+ Example
+
+
+
+ var geometry = new THREE.SphereBufferGeometry( 5, 32, 32 );
+ var material = new THREE.MeshBasicMaterial( {color: 0xffff00} );
+ var sphere = new THREE.Mesh( geometry, material );
+ scene.add( sphere );
+
+
+ Constructor
+
+
+ [name]([page:Float radius], [page:Integer widthSegments], [page:Integer heightSegments], [page:Float phiStart], [page:Float phiLength], [page:Float thetaStart], [page:Float thetaLength])
+
+
+ radius — sphere radius. Default is 50.
+ widthSegments — number of horizontal segments. Minimum value is 3, and the default is 8.
+ heightSegments — number of vertical segments. Minimum value is 2, and the default is 6.
+ phiStart — specify horizontal starting angle. Default is 0.
+ phiLength — specify horizontal sweep angle size. Default is Math.PI * 2.
+ thetaStart — specify vertical starting angle. Default is 0.
+ thetaLength — specify vertical sweep angle size. Default is Math.PI.
+
+
+
+ The geometry is created by sweeping and calculating vertexes around the Y axis (horizontal sweep) and the Z axis (vertical sweep). Thus, incomplete spheres (akin to 'sphere slices') can be created through the use of different values of phiStart, phiLength, thetaStart and thetaLength, in order to define the points in which we start (or end) calculating those vertices.
+
+
+
+ Properties
+
+
+ Each of the contructor parameters is accessible as a property of the same name. Any modification of these properties after instantiation does not change the geometry.
+
+
+ Source
+
+ [link:https://github.com/mrdoob/three.js/blob/master/src/[path].js src/[path].js]
+
+
diff --git a/docs/api/extras/geometries/TorusBufferGeometry.html b/docs/api/extras/geometries/TorusBufferGeometry.html
new file mode 100644
index 0000000000000000000000000000000000000000..9cc3ace1f2f874cca24da1a29e07ce9b8ea16885
--- /dev/null
+++ b/docs/api/extras/geometries/TorusBufferGeometry.html
@@ -0,0 +1,51 @@
+
+
+
+
+
+
+
+
+
+
+ [page:BufferGeometry] →
+
+ [name]
+
+ This is the [page:BufferGeometry] port of [page:TorusGeometry].
+
+
+
+ Example
+
+ var geometry = new THREE.TorusBufferGeometry( 10, 3, 16, 100 );
+ var material = new THREE.MeshBasicMaterial( { color: 0xffff00 } );
+ var torus = new THREE.Mesh( geometry, material );
+ scene.add( torus );
+
+
+
+ Constructor
+
+
+ [name]([page:Float radius], [page:Float tube], [page:Integer radialSegments], [page:Integer tubularSegments], [page:Float arc])
+
+ radius — Default is 100.
+ tube — Diameter of the tube. Default is 40.
+ radialSegments — Default is 8
+ tubularSegments — Default is 6.
+ arc — Central angle. Default is Math.PI * 2.
+
+
+
+ Properties
+
+
+ Each of the contructor parameters is accessible as a property of the same name. Any modification of these properties after instantiation does not change the geometry.
+
+
+ Source
+
+ [link:https://github.com/mrdoob/three.js/blob/master/src/[path].js src/[path].js]
+
+
diff --git a/docs/list.js b/docs/list.js
index 92e47e221ff490b739130f7a892d00297967f8d2..78ac3d881588627ddc2760043ffbd5108a600266 100644
--- a/docs/list.js
+++ b/docs/list.js
@@ -191,7 +191,9 @@ var list = {
],
"Extras / Geometries": [
+ [ "BoxBufferGeometry", "api/extras/geometries/BoxBufferGeometry" ],
[ "BoxGeometry", "api/extras/geometries/BoxGeometry" ],
+ [ "CircleBufferGeometry", "api/extras/geometries/CircleBufferGeometry" ],
[ "CircleGeometry", "api/extras/geometries/CircleGeometry" ],
[ "CylinderGeometry", "api/extras/geometries/CylinderGeometry" ],
[ "DodecahedronGeometry", "api/extras/geometries/DodecahedronGeometry" ],
@@ -200,13 +202,16 @@ var list = {
[ "LatheGeometry", "api/extras/geometries/LatheGeometry" ],
[ "OctahedronGeometry", "api/extras/geometries/OctahedronGeometry" ],
[ "ParametricGeometry", "api/extras/geometries/ParametricGeometry" ],
+ [ "PlaneBufferGeometry", "api/extras/geometries/PlaneBufferGeometry" ],
[ "PlaneGeometry", "api/extras/geometries/PlaneGeometry" ],
[ "PolyhedronGeometry", "api/extras/geometries/PolyhedronGeometry" ],
[ "RingGeometry", "api/extras/geometries/RingGeometry" ],
[ "ShapeGeometry", "api/extras/geometries/ShapeGeometry" ],
+ [ "SphereBufferGeometry", "api/extras/geometries/SphereBufferGeometry" ],
[ "SphereGeometry", "api/extras/geometries/SphereGeometry" ],
[ "TetrahedronGeometry", "api/extras/geometries/TetrahedronGeometry" ],
[ "TextGeometry", "api/extras/geometries/TextGeometry" ],
+ [ "TorusBufferGeometry", "api/extras/geometries/TorusBufferGeometry" ],
[ "TorusGeometry", "api/extras/geometries/TorusGeometry" ],
[ "TorusKnotGeometry", "api/extras/geometries/TorusKnotGeometry" ],
[ "TubeGeometry", "api/extras/geometries/TubeGeometry" ]
diff --git a/docs/scenes/js/geometry.js b/docs/scenes/js/geometry.js
index dfc5393b09ce59d3620a5004ecb4fab619c39582..3a8c974035da8e30652f898d80da616b148bf309 100644
--- a/docs/scenes/js/geometry.js
+++ b/docs/scenes/js/geometry.js
@@ -93,6 +93,40 @@ function updateGroupGeometry( mesh, geometry ) {
var guis = {
+ BoxBufferGeometry : function( mesh ) {
+
+ var data = {
+ width : 15,
+ height : 15,
+ depth : 15,
+ widthSegments : 1,
+ heightSegments : 1,
+ depthSegments : 1
+ };
+
+ function generateGeometry() {
+
+ updateGroupGeometry( mesh,
+ new THREE.BoxBufferGeometry(
+ data.width, data.height, data.depth, data.widthSegments, data.heightSegments, data.depthSegments
+ )
+ );
+
+ }
+
+ var folder = gui.addFolder( 'THREE.BoxBufferGeometry' );
+
+ folder.add( data, 'width', 1, 30 ).onChange( generateGeometry );
+ folder.add( data, 'height', 1, 30 ).onChange( generateGeometry );
+ folder.add( data, 'depth', 1, 30 ).onChange( generateGeometry );
+ folder.add( data, 'widthSegments', 1, 10 ).step( 1 ).onChange( generateGeometry );
+ folder.add( data, 'heightSegments', 1, 10 ).step( 1 ).onChange( generateGeometry );
+ folder.add( data, 'depthSegments', 1, 10 ).step( 1 ).onChange( generateGeometry );
+
+ generateGeometry();
+
+ },
+
BoxGeometry : function( mesh ) {
var data = {
@@ -173,6 +207,36 @@ var guis = {
},
+ CircleBufferGeometry : function( mesh ) {
+
+ var data = {
+ radius : 10,
+ segments : 32,
+ thetaStart : 0,
+ thetaLength : twoPi,
+ };
+
+ function generateGeometry() {
+
+ updateGroupGeometry( mesh,
+ new THREE.CircleBufferGeometry(
+ data.radius, data.segments, data.thetaStart, data.thetaLength
+ )
+ );
+
+ }
+
+ var folder = gui.addFolder( 'THREE.CircleBufferGeometry' );
+
+ folder.add( data, 'radius', 1, 20 ).onChange( generateGeometry );
+ folder.add( data, 'segments', 0, 128 ).step( 1 ).onChange( generateGeometry );
+ folder.add( data, 'thetaStart', 0, twoPi ).onChange( generateGeometry );
+ folder.add( data, 'thetaLength', 0, twoPi ).onChange( generateGeometry );
+
+ generateGeometry();
+
+ },
+
CircleGeometry : function( mesh ) {
var data = {
@@ -281,6 +345,36 @@ var guis = {
},
+ PlaneBufferGeometry : function( mesh ) {
+
+ var data = {
+ width : 10,
+ height : 10,
+ widthSegments : 1,
+ heightSegments : 1
+ };
+
+ function generateGeometry() {
+
+ updateGroupGeometry( mesh,
+ new THREE.PlaneBufferGeometry(
+ data.width, data.height, data.widthSegments, data.heightSegments
+ )
+ );
+
+ }
+
+ var folder = gui.addFolder( 'THREE.PlaneBufferGeometry' );
+
+ folder.add( data, 'width', 1, 30 ).onChange( generateGeometry );
+ folder.add( data, 'height', 1, 30 ).onChange( generateGeometry );
+ folder.add( data, 'widthSegments', 1, 30 ).step( 1 ).onChange( generateGeometry );
+ folder.add( data, 'heightSegments', 1, 30 ).step( 1 ).onChange( generateGeometry );
+
+ generateGeometry();
+
+ },
+
PlaneGeometry : function( mesh ) {
var data = {
@@ -345,6 +439,42 @@ var guis = {
},
+ SphereBufferGeometry : function( mesh ) {
+
+ var data = {
+ radius : 15,
+ widthSegments : 8,
+ heightSegments : 6,
+ phiStart : 0,
+ phiLength : twoPi,
+ thetaStart : 0,
+ thetaLength : Math.PI,
+ };
+
+ function generateGeometry() {
+
+ updateGroupGeometry( mesh,
+ new THREE.SphereBufferGeometry(
+ data.radius, data.widthSegments, data.heightSegments, data.phiStart, data.phiLength, data.thetaStart, data.thetaLength
+ )
+ );
+
+ }
+
+ var folder = gui.addFolder( 'THREE.SphereBufferGeometry' );
+
+ folder.add( data, 'radius', 1, 30 ).onChange( generateGeometry );
+ folder.add( data, 'widthSegments', 3, 32 ).step( 1 ).onChange( generateGeometry );
+ folder.add( data, 'heightSegments', 2, 32 ).step( 1 ).onChange( generateGeometry );
+ folder.add( data, 'phiStart', 0, twoPi ).onChange( generateGeometry );
+ folder.add( data, 'phiLength', 0, twoPi ).onChange( generateGeometry );
+ folder.add( data, 'thetaStart', 0, twoPi ).onChange( generateGeometry );
+ folder.add( data, 'thetaLength', 0, twoPi ).onChange( generateGeometry );
+
+ generateGeometry();
+
+ },
+
SphereGeometry : function( mesh ) {
var data = {
@@ -473,6 +603,38 @@ var guis = {
},
+ TorusBufferGeometry : function( mesh ) {
+
+ var data = {
+ radius : 10,
+ tube : 3,
+ radialSegments : 16,
+ tubularSegments : 100,
+ arc : twoPi
+ };
+
+ function generateGeometry() {
+
+ updateGroupGeometry( mesh,
+ new THREE.TorusBufferGeometry(
+ data.radius, data.tube, data.radialSegments, data.tubularSegments, data.arc
+ )
+ );
+
+ }
+
+ var folder = gui.addFolder( 'THREE.TorusBufferGeometry' );
+
+ folder.add( data, 'radius', 1, 20 ).onChange( generateGeometry );
+ folder.add( data, 'tube', 0.1, 10 ).onChange( generateGeometry );
+ folder.add( data, 'radialSegments', 2, 30 ).step( 1 ).onChange( generateGeometry );
+ folder.add( data, 'tubularSegments', 3, 200 ).step( 1 ).onChange( generateGeometry );
+ folder.add( data, 'arc', 0.1, twoPi ).onChange( generateGeometry );
+
+ generateGeometry();
+
+ },
+
TorusGeometry : function( mesh ) {
var data = {