summaryrefslogtreecommitdiffstats
path: root/o3d/samples
diff options
context:
space:
mode:
authorkbr@google.com <kbr@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2009-08-20 23:40:08 +0000
committerkbr@google.com <kbr@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2009-08-20 23:40:08 +0000
commit7b7ce9d8e46d33664449c940b3e95ede0aecb3e9 (patch)
tree179b8d9ddc954d37800bd53b8b70b34ac9eb9909 /o3d/samples
parentffc90a1e716e6bbc54eb719862a1fd7932d53510 (diff)
downloadchromium_src-7b7ce9d8e46d33664449c940b3e95ede0aecb3e9.zip
chromium_src-7b7ce9d8e46d33664449c940b3e95ede0aecb3e9.tar.gz
chromium_src-7b7ce9d8e46d33664449c940b3e95ede0aecb3e9.tar.bz2
Generalized cylinder code in primitives.js to handle truncated cones.
o3djs.primitives.createCylinderVertices now delegates to createTruncatedConeVertices. Updated primitives.html. Added o3djs.primitives.VertexInfo.append to allow multiple VertexInfos to be placed in a single Shape for efficiency; this functionality has been tested but is not yet demonstrated in a sample. Review URL: http://codereview.chromium.org/174186 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@23917 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'o3d/samples')
-rw-r--r--o3d/samples/o3djs/primitives.js199
-rw-r--r--o3d/samples/primitives.html36
2 files changed, 203 insertions, 32 deletions
diff --git a/o3d/samples/o3djs/primitives.js b/o3d/samples/o3djs/primitives.js
index 52621d5..54c9cfd 100644
--- a/o3d/samples/o3djs/primitives.js
+++ b/o3d/samples/o3djs/primitives.js
@@ -359,7 +359,7 @@ o3djs.primitives.VertexInfo.prototype.getTriangle = function(
};
/**
- * Sets the vertex indices of thye triangle at the given triangle index.
+ * Sets the vertex indices of the triangle at the given triangle index.
* @param {number} triangleIndex The index of the triangle.
* @param {number} index1 The index of the first vertex of the triangle.
* @param {number} index2 The index of the second vertex of the triangle.
@@ -374,6 +374,74 @@ o3djs.primitives.VertexInfo.prototype.setTriangle = function(
};
/**
+ * Appends all of the information in the passed VertexInfo on to the
+ * end of this one. This is useful for putting multiple primitives'
+ * vertices, appropriately transformed, into a single Shape. Both
+ * VertexInfo objects must contain the same number of streams, with
+ * the same semantics and number of components.
+ * @param {!o3djs.primitives.VertexInfo} info The VertexInfo whose
+ * information should be appended to this one.
+ */
+o3djs.primitives.VertexInfo.prototype.append = function(info) {
+ if (this.streams.length == 0 && info.streams.length != 0) {
+ // Special case
+ for (var i = 0; i < info.streams.length; i++) {
+ var srcStream = info.streams[i];
+ var stream = this.addStream(srcStream.numComponents,
+ srcStream.semantic,
+ srcStream.semanticIndex);
+ stream.elements = stream.elements.concat(srcStream.elements);
+ }
+ this.indices = this.indices.concat(info.indices);
+ return;
+ }
+
+ // First verify that both have the same streams
+ if (this.streams.length != info.streams.length) {
+ throw 'Number of VertexInfoStreams did not match';
+ }
+ for (var i = 0; i < this.streams.length; i++) {
+ var found = false;
+ var semantic = this.streams[i].semantic;
+ var numComponents = this.streams[i].numComponents;
+ var semanticIndex = this.streams[i].semanticIndex;
+ for (var j = 0; j < info.streams.length; j++) {
+ var otherStream = info.streams[j];
+ if (otherStream.semantic === semantic &&
+ otherStream.numComponents == numComponents &&
+ otherStream.semanticIndex == semanticIndex) {
+ found = true;
+ break;
+ }
+ }
+ if (!found) {
+ throw 'Did not find stream with semantic=' + semantic +
+ ', numComponents=' + numComponents +
+ ', and semantic index=' + semanticIndex +
+ ' in given VertexInfo';
+ }
+ }
+
+ // Compute the number of vertices currently in the shape
+ var positionStream = this.findStream(o3djs.base.o3d.Stream.POSITION);
+ if (!positionStream)
+ throw 'POSITION stream is missing';
+ var numVertices = positionStream.numElements();
+
+ // Concatenate all VertexStreamInfos' data
+ for (var i = 0; i < this.streams.length; i++) {
+ var stream = this.streams[i];
+ var srcStream = info.findStream(stream.semantic, stream.semanticIndex);
+ stream.elements = stream.elements.concat(srcStream.elements);
+ }
+
+ // Concatenate and adjust indices
+ for (var i = 0; i < info.indices.length; i++) {
+ this.indices.push(info.indices[i] + numVertices);
+ }
+};
+
+/**
* Validates that all the streams contain the same number of elements, that
* all the indices are within range and that a position stream is present.
*/
@@ -1147,6 +1215,72 @@ o3djs.primitives.createCylinderVertices = function(radius,
radialSubdivisions,
verticalSubdivisions,
opt_matrix) {
+ return o3djs.primitives.createTruncatedConeVertices(radius,
+ radius,
+ height,
+ radialSubdivisions,
+ verticalSubdivisions,
+ opt_matrix);
+};
+
+/**
+ * Creates a cylinder shape. The cylinder will be created around the
+ * origin along the y-axis. The created cylinder has position, normal
+ * and uv streams.
+ *
+ * @param {!o3d.Pack} pack Pack to create cylinder elements in.
+ * @param {!o3d.Material} material to use.
+ * @param {number} radius Radius of cylinder.
+ * @param {number} height Height of cylinder.
+ * @param {number} radialSubdivisions The number of subdivisions around the
+ * cylinder.
+ * @param {number} verticalSubdivisions The number of subdivisions down the
+ * cylinder.
+ * @param {!o3djs.math.Matrix4} opt_matrix A matrix by which to multiply
+ * all the vertices.
+ * @return {!o3d.Shape} The created cylinder.
+ */
+o3djs.primitives.createCylinder = function(pack,
+ material,
+ radius,
+ height,
+ radialSubdivisions,
+ verticalSubdivisions,
+ opt_matrix) {
+ var vertexInfo = o3djs.primitives.createCylinderVertices(
+ radius,
+ height,
+ radialSubdivisions,
+ verticalSubdivisions,
+ opt_matrix);
+ return vertexInfo.createShape(pack, material);
+};
+
+/**
+ * Creates vertices for a truncated cone, which is like a cylinder
+ * except that it has different top and bottom radii. A truncated cone
+ * can also be used to create cylinders and regular cones. The
+ * truncated cone will be created centered about the origin, with the
+ * y axis as its vertical axis. The created cone has position, normal
+ * and uv streams.
+ *
+ * @param {number} bottomRadius Bottom radius of truncated cone.
+ * @param {number} topRadius Top radius of truncated cone.
+ * @param {number} height Height of truncated cone.
+ * @param {number} radialSubdivisions The number of subdivisions around the
+ * truncated cone.
+ * @param {number} verticalSubdivisions The number of subdivisions down the
+ * truncated cone.
+ * @param {!o3djs.math.Matrix4} opt_matrix A matrix by which to multiply
+ * all the vertices.
+ * @return {o3djs.primitives.VertexInfo} The created truncated cone vertices.
+ */
+o3djs.primitives.createTruncatedConeVertices = function(bottomRadius,
+ topRadius,
+ height,
+ radialSubdivisions,
+ verticalSubdivisions,
+ opt_matrix) {
if (radialSubdivisions < 1) {
throw Error('radialSubdivisions must be 1 or greater');
}
@@ -1167,16 +1301,26 @@ o3djs.primitives.createCylinderVertices = function(radius,
var vertices = [];
var vertsAroundEdge = radialSubdivisions + 1;
+ // The slant of the cone is constant across its surface
+ var slant = Math.atan2(bottomRadius - topRadius, height);
+ var cosSlant = Math.cos(slant);
+ var sinSlant = Math.sin(slant);
+
for (var yy = -2; yy <= verticalSubdivisions + 2; ++yy) {
- var ringRadius = radius;
var v = yy / verticalSubdivisions
var y = height * v;
+ var ringRadius;
if (yy < 0) {
y = 0;
v = 1;
+ ringRadius = bottomRadius;
} else if (yy > verticalSubdivisions) {
y = height;
v = 1;
+ ringRadius = topRadius;
+ } else {
+ ringRadius = bottomRadius +
+ (topRadius - bottomRadius) * (yy / verticalSubdivisions);
}
if (yy == -2 || yy == verticalSubdivisions + 2) {
ringRadius = 0;
@@ -1188,9 +1332,9 @@ o3djs.primitives.createCylinderVertices = function(radius,
var cos = Math.cos(ii * Math.PI * 2 / radialSubdivisions);
positionStream.addElement(sin * ringRadius, y, cos * ringRadius);
normalStream.addElement(
- (yy < 0 || yy > verticalSubdivisions) ? 0 : sin,
- (yy < 0) ? -1 : (yy > verticalSubdivisions ? 1 : 0),
- (yy < 0 || yy > verticalSubdivisions) ? 0 : cos);
+ (yy < 0 || yy > verticalSubdivisions) ? 0 : (sin * cosSlant),
+ (yy < 0) ? -1 : (yy > verticalSubdivisions ? 1 : sinSlant),
+ (yy < 0 || yy > verticalSubdivisions) ? 0 : (cos * cosSlant));
texCoordStream.addElement(ii / radialSubdivisions, v);
}
}
@@ -1214,32 +1358,39 @@ o3djs.primitives.createCylinderVertices = function(radius,
};
/**
- * Creates cylinder a cylinder shape. The cylinder will be created around the
- * origin along the y-axis. The created cylinder has position, normal and uv
- * streams.
+ * Creates a truncated cone shape, which is like a cylinder except
+ * that it has different top and bottom radii. A truncated cone can
+ * also be used to create cylinders, by setting the bottom and top
+ * radii equal, and cones, by setting either the top or bottom radius
+ * to 0. The truncated cone will be created with the bottom face in
+ * the xz plane, and the y axis in the center. The created cone has
+ * position, normal and uv streams.
*
- * @param {!o3d.Pack} pack Pack to create cylinder elements in.
+ * @param {!o3d.Pack} pack Pack in which to create the truncated cone.
* @param {!o3d.Material} material to use.
- * @param {number} radius Radius of cylinder.
- * @param {number} depth Depth of cylinder.
+ * @param {number} bottomRadius Bottom radius of truncated cone.
+ * @param {number} topRadius Top radius of truncated cone.
+ * @param {number} height Height of truncated cone.
* @param {number} radialSubdivisions The number of subdivisions around the
- * cylinder.
+ * truncated cone.
* @param {number} verticalSubdivisions The number of subdivisions down the
- * cylinder.
+ * truncated cone.
* @param {!o3djs.math.Matrix4} opt_matrix A matrix by which to multiply
* all the vertices.
- * @return {!o3d.Shape} The created cylinder.
+ * @return {!o3d.Shape} The created truncated cone.
*/
-o3djs.primitives.createCylinder = function(pack,
- material,
- radius,
- depth,
- radialSubdivisions,
- verticalSubdivisions,
- opt_matrix) {
- var vertexInfo = o3djs.primitives.createCylinderVertices(
- radius,
- depth,
+o3djs.primitives.createTruncatedCone = function(pack,
+ material,
+ bottomRadius,
+ topRadius,
+ height,
+ radialSubdivisions,
+ verticalSubdivisions,
+ opt_matrix) {
+ var vertexInfo = o3djs.primitives.createTruncatedConeVertices(
+ bottomRadius,
+ topRadius,
+ height,
radialSubdivisions,
verticalSubdivisions,
opt_matrix);
diff --git a/o3d/samples/primitives.html b/o3d/samples/primitives.html
index 0137cc2..4cc3935 100644
--- a/o3d/samples/primitives.html
+++ b/o3d/samples/primitives.html
@@ -60,7 +60,7 @@ var g_pack;
var g_viewInfo;
var g_lightPosition = [5, 5, 7];
-var g_eyePosition = [1, 3, 12];
+var g_eyePosition = [3, 4, 14];
/**
* Creates the client area.
@@ -176,7 +176,25 @@ function createShapes() {
g_pack,
createPhongMaterial([1,0,1,1]),
0.5, // Radius.
- 1.5, // Depth.
+ 1.5, // Height.
+ 20, // Number of radial subdivisions.
+ 20); // Number of vertical subdivisions.
+
+ var truncatedCone = o3djs.primitives.createTruncatedCone(
+ g_pack,
+ createPhongMaterial([0,0,1,1]),
+ 0.3, // Bottom radius.
+ 0.5, // Top radius.
+ 1.5, // Height.
+ 20, // Number of radial subdivisions.
+ 20); // Number of vertical subdivisions.
+
+ var cone = o3djs.primitives.createTruncatedCone(
+ g_pack,
+ createPhongMaterial([0,1,0,1]),
+ 0.5, // Bottom radius.
+ 0.0, // Top radius.
+ 1.5, // Height.
20, // Number of radial subdivisions.
20); // Number of vertical subdivisions.
@@ -214,12 +232,14 @@ function createShapes() {
// Add the shapes to the transforms.
var transformTable = [
- {shape: cube, translation: [-2, 1, 0]},
- {shape: sphere, translation: [0, 1, 0]},
- {shape: cylinder, translation: [2, 1, 0]},
- {shape: plane, translation: [-2, -1, 0]},
- {shape: prism, translation: [0, -1, 0]},
- {shape: disc, translation: [2, -1, 0]}
+ {shape: cube, translation: [-3, 1, 0]},
+ {shape: sphere, translation: [-1, 1, 0]},
+ {shape: cylinder, translation: [1, 1, 0]},
+ {shape: truncatedCone, translation: [3, 1, 0]},
+ {shape: plane, translation: [-3, -1, 0]},
+ {shape: prism, translation: [-1, -1, 0]},
+ {shape: disc, translation: [1, -1, 0]},
+ {shape: cone, translation: [3, -1, 0]},
];
for (var tt = 0; tt < transformTable.length; ++tt) {