From 8d1cc709340da845d76f84220fe92c11e6217ff3 Mon Sep 17 00:00:00 2001
From: John Mayhew
Date: Tue, 3 Apr 2012 09:36:14 -0700
Subject: Made use of semicolons consistent and updated new files to use the
new RDGE namespace
---
js/lib/rdge/materials/twist-vert-material.js | 486 +++++++++++++--------------
1 file changed, 231 insertions(+), 255 deletions(-)
(limited to 'js/lib/rdge/materials/twist-vert-material.js')
diff --git a/js/lib/rdge/materials/twist-vert-material.js b/js/lib/rdge/materials/twist-vert-material.js
index 9af1953d..0cf4d954 100644
--- a/js/lib/rdge/materials/twist-vert-material.js
+++ b/js/lib/rdge/materials/twist-vert-material.js
@@ -1,278 +1,254 @@
/*
- This file contains proprietary software owned by Motorola Mobility, Inc.
- No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.
- (c) Copyright 2011 Motorola Mobility, Inc. All Rights Reserved.
- */
+This file contains proprietary software owned by Motorola Mobility, Inc.
+No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.
+(c) Copyright 2011 Motorola Mobility, Inc. All Rights Reserved.
+ */
var MaterialParser = require("js/lib/rdge/materials/material-parser").MaterialParser;
///////////////////////////////////////////////////////////////////////
// Class GLMaterial
// RDGE representation of a material.
///////////////////////////////////////////////////////////////////////
-function TwistVertMaterial()
-{
- // initialize the inherited members
- this.inheritedFrom = GLMaterial;
- this.inheritedFrom();
-
- ///////////////////////////////////////////////////////////////////////
- // Instance variables
- ///////////////////////////////////////////////////////////////////////
- this._name = "TwistVertMaterial";
- this._shaderName = "twistVert";
-
- this._color = [1,0,0,1];
-
- this._tex0 = 'assets/images/rocky-normal.jpg';
- this._tex1 = 'assets/images/metal.png';
-
- this._angle = 0.0;
- this._deltaTime = 0.01;
-
- ///////////////////////////////////////////////////////////////////////
- // Property Accessors
- ///////////////////////////////////////////////////////////////////////
- this.getColor = function() { return this._color; }
- this.getShaderName = function() { return this._shaderName; }
-
- this.isAnimated = function() { return true; }
- this.hasVertexDeformation = function() { return this._hasVertexDeformation; }
- this._hasVertexDeformation = true;
- this._vertexDeformationTolerance = 0.02; // should be a property
-
- ///////////////////////////////////////////////////////////////////////
- // Methods
- ///////////////////////////////////////////////////////////////////////
- // duplcate method requirde
- this.dup = function() { return new TwistVertMaterial(); }
-
- this.init = function( world )
- {
- this.setWorld( world );
-
- // set up the shader
- this._shader = new RDGE.jshader();
- this._shader.def = twistVertShaderDef;
- this._shader.init();
-
- // set the defaults
- this._shader.twistMe.color.set( this.getColor() );
-
- // set up the material node
- this._materialNode = RDGE.createMaterialNode("twistVertMaterial" + "_" + world.generateUniqueNodeID());
- this._materialNode.setShader(this._shader);
-
- // initialize the twist vert properties
- this.updateShaderValues();
- }
-
-
- ///////////////////////////////////////////////////////////////////////
- // Material Property Accessors
- ///////////////////////////////////////////////////////////////////////
- this._propNames = ["color", "u_limit1", "u_limit2", "u_center", "u_twistAmount", "u_tex0", "u_tex1" ];
- this._propLabels = ["Color", "Minimum Parameter Value", "Center Paramater Value", "Center", "Twist Amount", "Front facing texture map", "Back facing texture map"];
- this._propTypes = ["color", "float", "float", "float", "float", "file", "file"];
- this._propValues = [];
-
- // initialize the property values
- this._propValues[ this._propNames[0] ] = this._color.slice();
- this._propValues[ this._propNames[1] ] = 0.25;
- this._propValues[ this._propNames[2] ] = 0.75;
- this._propValues[ this._propNames[3] ] = 0.0;
- this._propValues[ this._propNames[4] ] = 2.0*Math.PI;
- this._propValues[ this._propNames[5] ] = this._tex0.slice();
- this._propValues[ this._propNames[6] ] = this._tex1.slice();
-
- this.setProperty = function( prop, value )
- {
- // make sure we have legitimate input
- if (this.validateProperty( prop, value ))
- {
- switch (prop)
- {
- case "color":
- case "u_tex1":
- case "u_tex0": this._propValues[prop] = value.slice(); break;
- default: this._propValues[prop] = value; break;
- }
-
- this.updateShaderValues();
- }
- }
- ///////////////////////////////////////////////////////////////////////
-
- this.exportJSON = function()
- {
- var jObj =
+function TwistVertMaterial() {
+ // initialize the inherited members
+ this.inheritedFrom = GLMaterial;
+ this.inheritedFrom();
+
+ ///////////////////////////////////////////////////////////////////////
+ // Instance variables
+ ///////////////////////////////////////////////////////////////////////
+ this._name = "TwistVertMaterial";
+ this._shaderName = "twistVert";
+
+ this._color = [1, 0, 0, 1];
+
+ this._tex0 = 'assets/images/rocky-normal.jpg';
+ this._tex1 = 'assets/images/metal.png';
+
+ this._angle = 0.0;
+ this._deltaTime = 0.01;
+
+ ///////////////////////////////////////////////////////////////////////
+ // Property Accessors
+ ///////////////////////////////////////////////////////////////////////
+ this.getColor = function () { return this._color; };
+ this.getShaderName = function () { return this._shaderName; };
+
+ this.isAnimated = function () { return true; };
+ this.hasVertexDeformation = function () { return this._hasVertexDeformation; };
+ this._hasVertexDeformation = true;
+ this._vertexDeformationTolerance = 0.02; // should be a property
+
+ ///////////////////////////////////////////////////////////////////////
+ // Methods
+ ///////////////////////////////////////////////////////////////////////
+ // duplcate method requirde
+ this.dup = function () { return new TwistVertMaterial(); };
+
+ this.init = function (world) {
+ this.setWorld(world);
+
+ // set up the shader
+ this._shader = new RDGE.jshader();
+ this._shader.def = twistVertShaderDef;
+ this._shader.init();
+
+ // set the defaults
+ this._shader.twistMe.color.set(this.getColor());
+
+ // set up the material node
+ this._materialNode = RDGE.createMaterialNode("twistVertMaterial" + "_" + world.generateUniqueNodeID());
+ this._materialNode.setShader(this._shader);
+
+ // initialize the twist vert properties
+ this.updateShaderValues();
+ };
+
+
+ ///////////////////////////////////////////////////////////////////////
+ // Material Property Accessors
+ ///////////////////////////////////////////////////////////////////////
+ this._propNames = ["color", "u_limit1", "u_limit2", "u_center", "u_twistAmount", "u_tex0", "u_tex1"];
+ this._propLabels = ["Color", "Minimum Parameter Value", "Center Paramater Value", "Center", "Twist Amount", "Front facing texture map", "Back facing texture map"];
+ this._propTypes = ["color", "float", "float", "float", "float", "file", "file"];
+ this._propValues = [];
+
+ // initialize the property values
+ this._propValues[this._propNames[0]] = this._color.slice();
+ this._propValues[this._propNames[1]] = 0.25;
+ this._propValues[this._propNames[2]] = 0.75;
+ this._propValues[this._propNames[3]] = 0.0;
+ this._propValues[this._propNames[4]] = 2.0 * Math.PI;
+ this._propValues[this._propNames[5]] = this._tex0.slice();
+ this._propValues[this._propNames[6]] = this._tex1.slice();
+
+ this.setProperty = function (prop, value) {
+ // make sure we have legitimate input
+ if (this.validateProperty(prop, value)) {
+ switch (prop) {
+ case "color":
+ case "u_tex1":
+ case "u_tex0": this._propValues[prop] = value.slice(); break;
+ default: this._propValues[prop] = value; break;
+ }
+
+ this.updateShaderValues();
+ }
+ };
+ ///////////////////////////////////////////////////////////////////////
+
+ this.exportJSON = function () {
+ var jObj =
{
- 'material' : this.getShaderName(),
- 'name' : this.getName(),
- 'color' : this._propValues["color"]
+ 'material': this.getShaderName(),
+ 'name': this.getName(),
+ 'color': this._propValues["color"]
};
- return jObj;
- }
-
- this.importJSON = function( jObj )
- {
- if (this.getShaderName() != jObj.material) throw new Error( "ill-formed material" );
- this.setName( jObj.name );
-
- try
- {
- var color = jObj.color;
- this.setProperty( "color", color);
- }
- catch (e)
- {
- throw new Error( "could not import material: " + importStr );
- }
- }
-
- this.export = function()
- {
- // this function should be overridden by subclasses
- var exportStr = "material: " + this.getShaderName() + "\n";
- exportStr += "name: " + this.getName() + "\n";
-
- if (this._shader)
- exportStr += "color: " + String(this._shader.twistMe.color) + "\n";
- else
- exportStr += "color: " + this.getColor() + "\n";
- exportStr += "endMaterial\n";
-
- return exportStr;
- }
-
- this.import = function( importStr )
- {
- var pu = new MaterialParser( importStr );
- var material = pu.nextValue( "material: " );
- if (material != this.getShaderName()) throw new Error( "ill-formed material" );
- this.setName( pu.nextValue( "name: ") );
-
- var rtnStr;
- try
- {
- var color = eval( "[" + pu.nextValue( "color: " ) + "]" );
-
- this.setProperty( "color", color);
-
- var endKey = "endMaterial\n";
- var index = importStr.indexOf( endKey );
- index += endKey.length;
- rtnStr = importStr.substr( index );
- }
- catch (e)
- {
- throw new Error( "could not import material: " + importStr );
- }
-
- return rtnStr;
- }
-
- this.update = function( time )
- {
- if (this._shader && this._shader.twistMe)
- {
- var angle = this._angle;
- angle += this._deltaTime;
- if (angle > this._propValues[ "u_twistAmount" ])
- {
- angle = this._propValues[ "u_twistAmount" ];
- this._deltaTime = -this._deltaTime;
- }
- else if (angle < 0.0)
- {
- angle = 0;
- this._deltaTime = -this._deltaTime;
- }
- this._angle = angle;
- this._shader.twistMe["u_twistAmount"].set( [angle] );
- }
- }
-
- this.updateShaderValues = function()
- {
- if (this._shader && this._shader.twistMe)
- {
- var nProps = this._propNames.length;
- for (var i=0; i this._propValues["u_twistAmount"]) {
+ angle = this._propValues["u_twistAmount"];
+ this._deltaTime = -this._deltaTime;
+ }
+ else if (angle < 0.0) {
+ angle = 0;
+ this._deltaTime = -this._deltaTime;
+ }
+ this._angle = angle;
+ this._shader.twistMe["u_twistAmount"].set([angle]);
+ }
+ };
+
+ this.updateShaderValues = function () {
+ if (this._shader && this._shader.twistMe) {
+ var nProps = this._propNames.length;
+ for (var i = 0; i < nProps; i++) {
+ var propName = this._propNames[i];
+ var propValue = this._propValues[propName];
+ switch (propName) {
+ case "u_tex0":
+ case "u_tex1":
+ case "color": this._shader.twistMe[propName].set(propValue); break;
+ default: this._shader.twistMe[propName].set([propValue]); break;
+ }
+ }
+ }
+ };
+
+ this.updateTextures = function () {
+ var material = this._materialNode;
+ if (material) {
+ var technique = material.shaderProgram['default'];
+ var renderer = RDGE.globals.engine.getContext().renderer;
+ if (renderer && technique) {
+ var texMapName = this._propValues[this._propNames[5]];
+ var wrap = 'REPEAT', mips = true;
+ var tex = this.loadTexture(texMapName, wrap, mips);
+ if (tex) technique.u_tex0.set(tex);
+
+ texMapName = this._propValues[this._propNames[6]];
+ tex = this.loadTexture(texMapName, wrap, mips);
+ if (tex) technique.u_tex1.set(tex);
+ }
+ }
+ };
+};
///////////////////////////////////////////////////////////////////////////////////////
// RDGE shader
-
+
// shader spec (can also be loaded from a .JSON file, or constructed at runtime)
-twistVertShaderDef =
+twistVertShaderDef =
{
- 'shaders': { // shader files
- 'defaultVShader':"assets/shaders/TwistVert.vert.glsl",
- 'defaultFShader':"assets/shaders/TwistVert.frag.glsl"
- },
- 'techniques': { // rendering control
- 'twistMe':[ // simple color pass
+ 'shaders': { // shader files
+ 'defaultVShader': "assets/shaders/TwistVert.vert.glsl",
+ 'defaultFShader': "assets/shaders/TwistVert.frag.glsl"
+ },
+ 'techniques': { // rendering control
+ 'twistMe': [ // simple color pass
{
- 'vshader' : 'defaultVShader',
- 'fshader' : 'defaultFShader',
-
- // attributes
- 'attributes' :
+ 'vshader': 'defaultVShader',
+ 'fshader': 'defaultFShader',
+
+ // attributes
+ 'attributes':
{
- 'vert' : { 'type' : 'vec3' },
- 'normal' : { 'type' : 'vec3' },
- 'texcoord' : { 'type' : 'vec2' }
+ 'vert': { 'type': 'vec3' },
+ 'normal': { 'type': 'vec3' },
+ 'texcoord': { 'type': 'vec2' }
},
- // attributes
- 'params' :
+ // attributes
+ 'params':
{
- 'color' : { 'type' : 'vec4' },
-
- 'u_limit1': { 'type': 'float' },
- 'u_limit2': { 'type': 'float' },
- 'u_limit3': { 'type': 'float' },
- 'u_minVal': { 'type': 'float' },
- 'u_maxVal': { 'type': 'float' },
- 'u_center': { 'type': 'float' },
- 'u_twistAmount': { 'type': 'float' }
+ 'color': { 'type': 'vec4' },
+
+ 'u_limit1': { 'type': 'float' },
+ 'u_limit2': { 'type': 'float' },
+ 'u_limit3': { 'type': 'float' },
+ 'u_minVal': { 'type': 'float' },
+ 'u_maxVal': { 'type': 'float' },
+ 'u_center': { 'type': 'float' },
+ 'u_twistAmount': { 'type': 'float' }
}
- }
+ }
]
- }
+ }
};
--
cgit v1.2.3