summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorpetersont@google.com <petersont@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2010-08-17 23:44:05 +0000
committerpetersont@google.com <petersont@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2010-08-17 23:44:05 +0000
commit22697f1356f97eab7ccfd6c2469f9e2d52bdd4f1 (patch)
tree5f83a6c6472fe93e0deeebdff8bc58ab7498e3d2
parentc10688623b331e0c72c502b718cff5016de61f85 (diff)
downloadchromium_src-22697f1356f97eab7ccfd6c2469f9e2d52bdd4f1.zip
chromium_src-22697f1356f97eab7ccfd6c2469f9e2d52bdd4f1.tar.gz
chromium_src-22697f1356f97eab7ccfd6c2469f9e2d52bdd4f1.tar.bz2
Converted o3d to use new types for floating point and integer arrays: Float32Array, Uint16Array et cetera.
Review URL: http://codereview.chromium.org/3184007 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@56453 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--o3d/samples/o3d-webgl/buffer.js8
-rw-r--r--o3d/samples/o3d-webgl/primitive.js5
-rw-r--r--o3d/samples/o3d-webgl/texture.js8
3 files changed, 9 insertions, 12 deletions
diff --git a/o3d/samples/o3d-webgl/buffer.js b/o3d/samples/o3d-webgl/buffer.js
index 6cfeb50..8f4e65e 100644
--- a/o3d/samples/o3d-webgl/buffer.js
+++ b/o3d/samples/o3d-webgl/buffer.js
@@ -64,9 +64,9 @@ o3d.Buffer.prototype.gl_buffer_ = 0;
/**
* Type of the array element.
- * @type {!WebGLFloatArray}
+ * @type {!Float32Array}
*/
-o3d.Buffer.prototype.ArrayType = WebGLFloatArray;
+o3d.Buffer.prototype.ArrayType = Float32Array;
o3d.Buffer.prototype.__defineGetter__('numElements',
function() {
@@ -318,9 +318,9 @@ o3d.inherit('IndexBuffer', 'Buffer');
/**
* Type of the array element.
- * @type {!WebGLUnsignedShortArray}
+ * @type {!Uint16Array}
*/
-o3d.IndexBuffer.prototype.ArrayType = WebGLUnsignedShortArray;
+o3d.IndexBuffer.prototype.ArrayType = Uint16Array;
/**
diff --git a/o3d/samples/o3d-webgl/primitive.js b/o3d/samples/o3d-webgl/primitive.js
index 71b32ec..358c3955 100644
--- a/o3d/samples/o3d-webgl/primitive.js
+++ b/o3d/samples/o3d-webgl/primitive.js
@@ -145,10 +145,7 @@ o3d.Primitive.prototype.render = function() {
this.gl.enableVertexAttribArray(gl_index);
enabled_attribs.push(gl_index);
- // TODO(petersont): When the constant WebGLFloatArray.BYTES_PER_ELEMENT
- // becomes available in implementations, use that here instead of this
- // hard-coded 4.
- var kFloatSize = 4;
+ var kFloatSize = Float32Array.BYTES_PER_ELEMENT;
this.gl.vertexAttribPointer(
gl_index, field.numComponents, this.gl.FLOAT, false,
buffer.totalComponents * kFloatSize, field.offset_ * kFloatSize);
diff --git a/o3d/samples/o3d-webgl/texture.js b/o3d/samples/o3d-webgl/texture.js
index be991bd..b2ee1a2 100644
--- a/o3d/samples/o3d-webgl/texture.js
+++ b/o3d/samples/o3d-webgl/texture.js
@@ -272,7 +272,7 @@ o3d.Texture.prototype.setFromCanvas_ =
* @private
*/
o3d.Texture.prototype.setValues_ = function(target, level, values) {
- var pixels = new WebGLUnsignedByteArray(values.length);
+ var pixels = new Uint8Array(values.length);
for (var i = 0; i < values.length; ++i) {
pixels[i] = Math.min(255, Math.max(0, values[i] * 256.0));
}
@@ -351,7 +351,7 @@ o3d.Texture2D.prototype.init_ =
// TODO(petersont): remove this allocation once Firefox supports
// passing null as argument to this form of ... some function.
- var pixels = new WebGLUnsignedByteArray(width * height * 4);
+ var pixels = new Uint8Array(width * height * 4);
this.gl.texImage2D(this.gl.TEXTURE_2D, 0, format, width, height,
0, format, this.gl.UNSIGNED_BYTE, pixels);
this.texture_width_ = width;
@@ -467,7 +467,7 @@ o3d.Texture2D.prototype.setRect =
var start_x = (destination_x < 0) ? Math.abs(destination_x) : 0;
var start_y = (destination_y < 0) ? Math.abs(destination_y) : 0;
- var keptPixels = new WebGLUnsignedByteArray(size_x * size_y * numChannels);
+ var keptPixels = new Uint8Array(size_x * size_y * numChannels);
var count = 0;
for (var y = 0; y < size_y; ++y) {
for (var x = 0; x < size_x; ++x) {
@@ -660,7 +660,7 @@ o3d.TextureCUBE.prototype.init_ =
this.gl.bindTexture(this.gl.TEXTURE_CUBE_MAP, this.texture_);
// TODO(petersont): remove this allocation once Firefox supports
// passing null as argument to this form of texImage2D.
- var t = new WebGLUnsignedByteArray(edgeLength * edgeLength * 4);
+ var t = new Uint8Array(edgeLength * edgeLength * 4);
for (var ii = 0; ii < 6; ++ii) {
this.gl.texImage2D(this.gl.TEXTURE_CUBE_MAP_POSITIVE_X + ii,
0, this.gl.RGBA, edgeLength, edgeLength, 0,