annotate resources/render/J3DI.js @ 0:0b8d8ce99f46 default tip

commit
author Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
date Mon, 14 Feb 2011 17:06:56 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 /*
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 * Copyright (C) 2009 Apple Inc. All Rights Reserved.
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 *
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 * Redistribution and use in source and binary forms, with or without
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
5 * modification, are permitted provided that the following conditions
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 * are met:
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 * 1. Redistributions of source code must retain the above copyright
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
8 * notice, this list of conditions and the following disclaimer.
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
9 * 2. Redistributions in binary form must reproduce the above copyright
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 * notice, this list of conditions and the following disclaimer in the
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
11 * documentation and/or other materials provided with the distribution.
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
12 *
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
13 * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
24 */
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
25
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
26 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
27 // initWebGL
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
28 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
29 // Initialize the Canvas element with the passed name as a WebGL object and return the
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
30 // WebGLRenderingContext.
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
31 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
32 // Load shaders with the passed names and create a program with them. Return this program
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
33 // in the 'program' property of the returned context.
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
34 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
35 // For each string in the passed attribs array, bind an attrib with that name at that index.
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
36 // Once the attribs are bound, link the program and then use it.
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
37 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
38 // Set the clear color to the passed array (4 values) and set the clear depth to the passed value.
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
39 // Enable depth testing and blending with a blend func of (SRC_ALPHA, ONE_MINUS_SRC_ALPHA)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
40 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 // A console function is added to the context: console(string). This can be replaced
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
42 // by the caller. By default, it maps to the window.console() function on WebKit and to
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
43 // an empty function on other browsers.
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
44 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
45 function initWebGL(canvasName, vshader, fshader, attribs, clearColor, clearDepth)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
46 {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
47 var canvas = document.getElementById(canvasName);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
48 var gl = WebGLUtils.setupWebGL(canvas);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
49 if (!gl) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
50 return null;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
51 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
52
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
53 // Add a console
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
54 gl.console = ("console" in window) ? window.console : { log: function() { } };
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
55
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
56 // create our shaders
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
57 var vertexShader = loadShader(gl, vshader);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
58 var fragmentShader = loadShader(gl, fshader);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
59
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
60 if (!vertexShader || !fragmentShader)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
61 return null;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
62
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
63 // Create the program object
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
64 gl.program = gl.createProgram();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
65
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
66 if (!gl.program)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
67 return null;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
68
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
69 // Attach our two shaders to the program
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
70 gl.attachShader (gl.program, vertexShader);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
71 gl.attachShader (gl.program, fragmentShader);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
72
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
73 // Bind attributes
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
74 for (var i = 0; i < attribs.length; ++i)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
75 gl.bindAttribLocation (gl.program, i, attribs[i]);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
76
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
77 // Link the program
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
78 gl.linkProgram(gl.program);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
79
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
80 // Check the link status
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
81 var linked = gl.getProgramParameter(gl.program, gl.LINK_STATUS);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
82 if (!linked) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
83 // something went wrong with the link
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
84 var error = gl.getProgramInfoLog (gl.program);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
85 gl.console.log("Error in program linking:"+error);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
86
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
87 gl.deleteProgram(gl.program);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
88 gl.deleteProgram(fragmentShader);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
89 gl.deleteProgram(vertexShader);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
90
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
91 return null;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
92 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
93
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
94 gl.useProgram(gl.program);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
95
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
96 gl.clearColor(clearColor[0], clearColor[1], clearColor[2], clearColor[3]);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
97 gl.clearDepth(clearDepth);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
98
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
99 gl.enable(gl.DEPTH_TEST);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
100 gl.enable(gl.BLEND);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
101 gl.blendFunc(gl.SRC_ALPHA, gl.ONE_MINUS_SRC_ALPHA);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
102
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
103 return gl;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
104 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
105
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
106 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
107 // loadShader
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
108 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
109 // 'shaderId' is the id of a <script> element containing the shader source string.
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
110 // Load this shader and return the WebGLShader object corresponding to it.
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
111 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
112 function loadShader(ctx, shaderId)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
113 {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
114 var shaderScript = document.getElementById(shaderId);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
115 if (!shaderScript) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
116 ctx.console.log("*** Error: shader script '"+shaderId+"' not found");
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
117 return null;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
118 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
119
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
120 if (shaderScript.type == "x-shader/x-vertex")
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
121 var shaderType = ctx.VERTEX_SHADER;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
122 else if (shaderScript.type == "x-shader/x-fragment")
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
123 var shaderType = ctx.FRAGMENT_SHADER;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
124 else {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
125 ctx.console.log("*** Error: shader script '"+shaderId+"' of undefined type '"+shaderScript.type+"'");
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
126 return null;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
127 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
128
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
129 // Create the shader object
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
130 var shader = ctx.createShader(shaderType);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
131 if (shader == null) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
132 ctx.console.log("*** Error: unable to create shader '"+shaderId+"'");
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
133 return null;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
134 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
135
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
136 // Load the shader source
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
137 ctx.shaderSource(shader, shaderScript.text);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
138
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
139 // Compile the shader
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
140 ctx.compileShader(shader);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
141
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
142 // Check the compile status
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
143 var compiled = ctx.getShaderParameter(shader, ctx.COMPILE_STATUS);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
144 if (!compiled) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
145 // Something went wrong during compilation; get the error
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
146 var error = ctx.getShaderInfoLog(shader);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
147 ctx.console.log("*** Error compiling shader '"+shaderId+"':"+error);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
148 ctx.deleteShader(shader);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
149 return null;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
150 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
151
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
152 return shader;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
153 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
154
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
155 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
156 // makeBox
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
157 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
158 // Create a box with vertices, normals and texCoords. Create VBOs for each as well as the index array.
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
159 // Return an object with the following properties:
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
160 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
161 // normalObject WebGLBuffer object for normals
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
162 // texCoordObject WebGLBuffer object for texCoords
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
163 // vertexObject WebGLBuffer object for vertices
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
164 // indexObject WebGLBuffer object for indices
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
165 // numIndices The number of indices in the indexObject
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
166 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
167 function makeBox(ctx)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
168 {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
169 // box
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
170 // v6----- v5
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
171 // /| /|
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
172 // v1------v0|
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
173 // | | | |
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
174 // | |v7---|-|v4
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
175 // |/ |/
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
176 // v2------v3
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
177 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
178 // vertex coords array
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
179 var vertices = new Float32Array(
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
180 [ 1, 1, 1, -1, 1, 1, -1,-1, 1, 1,-1, 1, // v0-v1-v2-v3 front
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
181 1, 1, 1, 1,-1, 1, 1,-1,-1, 1, 1,-1, // v0-v3-v4-v5 right
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
182 1, 1, 1, 1, 1,-1, -1, 1,-1, -1, 1, 1, // v0-v5-v6-v1 top
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
183 -1, 1, 1, -1, 1,-1, -1,-1,-1, -1,-1, 1, // v1-v6-v7-v2 left
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
184 -1,-1,-1, 1,-1,-1, 1,-1, 1, -1,-1, 1, // v7-v4-v3-v2 bottom
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
185 1,-1,-1, -1,-1,-1, -1, 1,-1, 1, 1,-1 ] // v4-v7-v6-v5 back
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
186 );
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
187
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
188 // normal array
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
189 var normals = new Float32Array(
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
190 [ 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, // v0-v1-v2-v3 front
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
191 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, // v0-v3-v4-v5 right
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
192 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, // v0-v5-v6-v1 top
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
193 -1, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, // v1-v6-v7-v2 left
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
194 0,-1, 0, 0,-1, 0, 0,-1, 0, 0,-1, 0, // v7-v4-v3-v2 bottom
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
195 0, 0,-1, 0, 0,-1, 0, 0,-1, 0, 0,-1 ] // v4-v7-v6-v5 back
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
196 );
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
197
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
198
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
199 // texCoord array
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
200 var texCoords = new Float32Array(
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
201 [ 1, 1, 0, 1, 0, 0, 1, 0, // v0-v1-v2-v3 front
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
202 0, 1, 0, 0, 1, 0, 1, 1, // v0-v3-v4-v5 right
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
203 1, 0, 1, 1, 0, 1, 0, 0, // v0-v5-v6-v1 top
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
204 1, 1, 0, 1, 0, 0, 1, 0, // v1-v6-v7-v2 left
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
205 0, 0, 1, 0, 1, 1, 0, 1, // v7-v4-v3-v2 bottom
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
206 0, 0, 1, 0, 1, 1, 0, 1 ] // v4-v7-v6-v5 back
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
207 );
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
208
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
209 // index array
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
210 var indices = new Uint8Array(
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
211 [ 0, 1, 2, 0, 2, 3, // front
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
212 4, 5, 6, 4, 6, 7, // right
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
213 8, 9,10, 8,10,11, // top
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
214 12,13,14, 12,14,15, // left
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
215 16,17,18, 16,18,19, // bottom
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
216 20,21,22, 20,22,23 ] // back
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
217 );
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
218
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
219 var retval = { };
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
220
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
221 retval.normalObject = ctx.createBuffer();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
222 ctx.bindBuffer(ctx.ARRAY_BUFFER, retval.normalObject);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
223 ctx.bufferData(ctx.ARRAY_BUFFER, normals, ctx.STATIC_DRAW);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
224
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
225 retval.texCoordObject = ctx.createBuffer();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
226 ctx.bindBuffer(ctx.ARRAY_BUFFER, retval.texCoordObject);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
227 ctx.bufferData(ctx.ARRAY_BUFFER, texCoords, ctx.STATIC_DRAW);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
228
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
229 retval.vertexObject = ctx.createBuffer();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
230 ctx.bindBuffer(ctx.ARRAY_BUFFER, retval.vertexObject);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
231 ctx.bufferData(ctx.ARRAY_BUFFER, vertices, ctx.STATIC_DRAW);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
232
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
233 ctx.bindBuffer(ctx.ARRAY_BUFFER, null);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
234
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
235 retval.indexObject = ctx.createBuffer();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
236 ctx.bindBuffer(ctx.ELEMENT_ARRAY_BUFFER, retval.indexObject);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
237 ctx.bufferData(ctx.ELEMENT_ARRAY_BUFFER, indices, ctx.STATIC_DRAW);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
238 ctx.bindBuffer(ctx.ELEMENT_ARRAY_BUFFER, null);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
239
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
240 retval.numIndices = indices.length;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
241
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
242 return retval;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
243 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
244
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
245 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
246 // makeSphere
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
247 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
248 // Create a sphere with the passed number of latitude and longitude bands and the passed radius.
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
249 // Sphere has vertices, normals and texCoords. Create VBOs for each as well as the index array.
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
250 // Return an object with the following properties:
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
251 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
252 // normalObject WebGLBuffer object for normals
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
253 // texCoordObject WebGLBuffer object for texCoords
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
254 // vertexObject WebGLBuffer object for vertices
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
255 // indexObject WebGLBuffer object for indices
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
256 // numIndices The number of indices in the indexObject
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
257 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
258 function makeSphere(ctx, radius, lats, longs)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
259 {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
260 var geometryData = [ ];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
261 var normalData = [ ];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
262 var texCoordData = [ ];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
263 var indexData = [ ];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
264
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
265 for (var latNumber = 0; latNumber <= lats; ++latNumber) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
266 for (var longNumber = 0; longNumber <= longs; ++longNumber) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
267 var theta = latNumber * Math.PI / lats;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
268 var phi = longNumber * 2 * Math.PI / longs;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
269 var sinTheta = Math.sin(theta);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
270 var sinPhi = Math.sin(phi);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
271 var cosTheta = Math.cos(theta);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
272 var cosPhi = Math.cos(phi);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
273
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
274 var x = cosPhi * sinTheta;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
275 var y = cosTheta;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
276 var z = sinPhi * sinTheta;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
277 var u = 1-(longNumber/longs);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
278 var v = latNumber/lats;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
279
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
280 normalData.push(x);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
281 normalData.push(y);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
282 normalData.push(z);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
283 texCoordData.push(u);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
284 texCoordData.push(v);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
285 geometryData.push(radius * x);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
286 geometryData.push(radius * y);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
287 geometryData.push(radius * z);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
288 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
289 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
290
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
291 for (var latNumber = 0; latNumber < lats; ++latNumber) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
292 for (var longNumber = 0; longNumber < longs; ++longNumber) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
293 var first = (latNumber * (longs+1)) + longNumber;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
294 var second = first + longs + 1;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
295 indexData.push(first);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
296 indexData.push(second);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
297 indexData.push(first+1);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
298
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
299 indexData.push(second);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
300 indexData.push(second+1);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
301 indexData.push(first+1);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
302 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
303 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
304
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
305 var retval = { };
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
306
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
307 retval.normalObject = ctx.createBuffer();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
308 ctx.bindBuffer(ctx.ARRAY_BUFFER, retval.normalObject);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
309 ctx.bufferData(ctx.ARRAY_BUFFER, new Float32Array(normalData), ctx.STATIC_DRAW);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
310
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
311 retval.texCoordObject = ctx.createBuffer();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
312 ctx.bindBuffer(ctx.ARRAY_BUFFER, retval.texCoordObject);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
313 ctx.bufferData(ctx.ARRAY_BUFFER, new Float32Array(texCoordData), ctx.STATIC_DRAW);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
314
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
315 retval.vertexObject = ctx.createBuffer();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
316 ctx.bindBuffer(ctx.ARRAY_BUFFER, retval.vertexObject);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
317 ctx.bufferData(ctx.ARRAY_BUFFER, new Float32Array(geometryData), ctx.STATIC_DRAW);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
318
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
319 retval.numIndices = indexData.length;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
320 retval.indexObject = ctx.createBuffer();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
321 ctx.bindBuffer(ctx.ELEMENT_ARRAY_BUFFER, retval.indexObject);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
322 ctx.bufferData(ctx.ELEMENT_ARRAY_BUFFER, new Uint16Array(indexData), ctx.STREAM_DRAW);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
323
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
324 return retval;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
325 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
326
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
327 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
328 // loadObj
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
329 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
330 // Load a .obj file from the passed URL. Return an object with a 'loaded' property set to false.
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
331 // When the object load is complete, the 'loaded' property becomes true and the following
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
332 // properties are set:
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
333 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
334 // normalObject WebGLBuffer object for normals
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
335 // texCoordObject WebGLBuffer object for texCoords
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
336 // vertexObject WebGLBuffer object for vertices
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
337 // indexObject WebGLBuffer object for indices
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
338 // numIndices The number of indices in the indexObject
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
339 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
340 function loadObj(ctx, url)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
341 {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
342 var obj = { loaded : false };
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
343 obj.ctx = ctx;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
344 var req = new XMLHttpRequest();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
345 req.obj = obj;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
346 req.onreadystatechange = function () { processLoadObj(req) };
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
347 req.open("GET", url, true);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
348 req.send(null);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
349 return obj;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
350 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
351
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
352 function processLoadObj(req)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
353 {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
354 req.obj.ctx.console.log("req="+req)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
355 // only if req shows "complete"
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
356 if (req.readyState == 4) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
357 doLoadObj(req.obj, req.responseText);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
358 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
359 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
360
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
361 function doLoadObj(obj, text)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
362 {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
363 vertexArray = [ ];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
364 normalArray = [ ];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
365 textureArray = [ ];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
366 indexArray = [ ];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
367
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
368 var vertex = [ ];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
369 var normal = [ ];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
370 var texture = [ ];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
371 var facemap = { };
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
372 var index = 0;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
373
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
374 // This is a map which associates a range of indices with a name
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
375 // The name comes from the 'g' tag (of the form "g NAME"). Indices
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
376 // are part of one group until another 'g' tag is seen. If any indices
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
377 // come before a 'g' tag, it is given the group name "_unnamed"
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
378 // 'group' is an object whose property names are the group name and
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
379 // whose value is a 2 element array with [<first index>, <num indices>]
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
380 var groups = { };
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
381 var currentGroup = [-1, 0];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
382 groups["_unnamed"] = currentGroup;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
383
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
384 var lines = text.split("\n");
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
385 for (var lineIndex in lines) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
386 var line = lines[lineIndex].replace(/[ \t]+/g, " ").replace(/\s\s*$/, "");
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
387
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
388 // ignore comments
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
389 if (line[0] == "#")
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
390 continue;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
391
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
392 var array = line.split(" ");
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
393 if (array[0] == "g") {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
394 // new group
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
395 currentGroup = [indexArray.length, 0];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
396 groups[array[1]] = currentGroup;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
397 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
398 else if (array[0] == "v") {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
399 // vertex
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
400 vertex.push(parseFloat(array[1]));
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
401 vertex.push(parseFloat(array[2]));
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
402 vertex.push(parseFloat(array[3]));
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
403 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
404 else if (array[0] == "vt") {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
405 // normal
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
406 texture.push(parseFloat(array[1]));
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
407 texture.push(parseFloat(array[2]));
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
408 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
409 else if (array[0] == "vn") {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
410 // normal
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
411 normal.push(parseFloat(array[1]));
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
412 normal.push(parseFloat(array[2]));
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
413 normal.push(parseFloat(array[3]));
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
414 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
415 else if (array[0] == "f") {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
416 // face
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
417 if (array.length != 4) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
418 obj.ctx.console.log("*** Error: face '"+line+"' not handled");
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
419 continue;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
420 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
421
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
422 for (var i = 1; i < 4; ++i) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
423 if (!(array[i] in facemap)) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
424 // add a new entry to the map and arrays
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
425 var f = array[i].split("/");
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
426 var vtx, nor, tex;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
427
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
428 if (f.length == 1) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
429 vtx = parseInt(f[0]) - 1;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
430 nor = vtx;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
431 tex = vtx;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
432 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
433 else if (f.length = 3) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
434 vtx = parseInt(f[0]) - 1;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
435 tex = parseInt(f[1]) - 1;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
436 nor = parseInt(f[2]) - 1;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
437 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
438 else {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
439 obj.ctx.console.log("*** Error: did not understand face '"+array[i]+"'");
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
440 return null;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
441 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
442
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
443 // do the vertices
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
444 var x = 0;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
445 var y = 0;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
446 var z = 0;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
447 if (vtx * 3 + 2 < vertex.length) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
448 x = vertex[vtx*3];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
449 y = vertex[vtx*3+1];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
450 z = vertex[vtx*3+2];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
451 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
452 vertexArray.push(x);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
453 vertexArray.push(y);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
454 vertexArray.push(z);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
455
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
456 // do the textures
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
457 x = 0;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
458 y = 0;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
459 if (tex * 2 + 1 < texture.length) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
460 x = texture[tex*2];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
461 y = texture[tex*2+1];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
462 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
463 textureArray.push(x);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
464 textureArray.push(y);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
465
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
466 // do the normals
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
467 x = 0;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
468 y = 0;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
469 z = 1;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
470 if (nor * 3 + 2 < normal.length) {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
471 x = normal[nor*3];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
472 y = normal[nor*3+1];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
473 z = normal[nor*3+2];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
474 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
475 normalArray.push(x);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
476 normalArray.push(y);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
477 normalArray.push(z);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
478
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
479 facemap[array[i]] = index++;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
480 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
481
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
482 indexArray.push(facemap[array[i]]);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
483 currentGroup[1]++;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
484 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
485 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
486 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
487
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
488 // set the VBOs
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
489 obj.normalObject = obj.ctx.createBuffer();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
490 obj.ctx.bindBuffer(obj.ctx.ARRAY_BUFFER, obj.normalObject);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
491 obj.ctx.bufferData(obj.ctx.ARRAY_BUFFER, new Float32Array(normalArray), obj.ctx.STATIC_DRAW);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
492
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
493 obj.texCoordObject = obj.ctx.createBuffer();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
494 obj.ctx.bindBuffer(obj.ctx.ARRAY_BUFFER, obj.texCoordObject);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
495 obj.ctx.bufferData(obj.ctx.ARRAY_BUFFER, new Float32Array(textureArray), obj.ctx.STATIC_DRAW);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
496
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
497 obj.vertexObject = obj.ctx.createBuffer();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
498 obj.ctx.bindBuffer(obj.ctx.ARRAY_BUFFER, obj.vertexObject);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
499 obj.ctx.bufferData(obj.ctx.ARRAY_BUFFER, new Float32Array(vertexArray), obj.ctx.STATIC_DRAW);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
500
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
501 obj.numIndices = indexArray.length;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
502 obj.indexObject = obj.ctx.createBuffer();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
503 obj.ctx.bindBuffer(obj.ctx.ELEMENT_ARRAY_BUFFER, obj.indexObject);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
504 obj.ctx.bufferData(obj.ctx.ELEMENT_ARRAY_BUFFER, new Uint16Array(indexArray), obj.ctx.STREAM_DRAW);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
505
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
506 obj.groups = groups;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
507
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
508 obj.loaded = true;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
509 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
510
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
511 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
512 // loadImageTexture
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
513 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
514 // Load the image at the passed url, place it in a new WebGLTexture object and return the WebGLTexture.
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
515 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
516 function loadImageTexture(ctx, url)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
517 {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
518 var texture = ctx.createTexture();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
519 texture.image = new Image();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
520 texture.image.onload = function() { doLoadImageTexture(ctx, texture.image, texture) }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
521 texture.image.src = url;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
522 return texture;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
523 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
524
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
525 function doLoadImageTexture(ctx, image, texture)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
526 {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
527 ctx.bindTexture(ctx.TEXTURE_2D, texture);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
528 ctx.texImage2D(
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
529 ctx.TEXTURE_2D, 0, ctx.RGBA, ctx.RGBA, ctx.UNSIGNED_BYTE, image);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
530 ctx.texParameteri(ctx.TEXTURE_2D, ctx.TEXTURE_MAG_FILTER, ctx.LINEAR);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
531 ctx.texParameteri(ctx.TEXTURE_2D, ctx.TEXTURE_MIN_FILTER, ctx.LINEAR);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
532 ctx.texParameteri(ctx.TEXTURE_2D, ctx.TEXTURE_WRAP_S, ctx.CLAMP_TO_EDGE);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
533 ctx.texParameteri(ctx.TEXTURE_2D, ctx.TEXTURE_WRAP_T, ctx.CLAMP_TO_EDGE);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
534 //ctx.generateMipmap(ctx.TEXTURE_2D)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
535 ctx.bindTexture(ctx.TEXTURE_2D, null);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
536 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
537
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
538 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
539 // Framerate object
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
540 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
541 // This object keeps track of framerate and displays it as the innerHTML text of the
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
542 // HTML element with the passed id. Once created you call snapshot at the end
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
543 // of every rendering cycle. Every 500ms the framerate is updated in the HTML element.
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
544 //
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
545 Framerate = function(id)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
546 {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
547 this.numFramerates = 10;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
548 this.framerateUpdateInterval = 500;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
549 this.id = id;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
550
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
551 this.renderTime = -1;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
552 this.framerates = [ ];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
553 self = this;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
554 var fr = function() { self.updateFramerate() }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
555 setInterval(fr, this.framerateUpdateInterval);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
556 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
557
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
558 Framerate.prototype.updateFramerate = function()
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
559 {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
560 var tot = 0;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
561 for (var i = 0; i < this.framerates.length; ++i)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
562 tot += this.framerates[i];
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
563
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
564 var framerate = tot / this.framerates.length;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
565 framerate = Math.round(framerate);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
566 document.getElementById(this.id).innerHTML = "Framerate:"+framerate+"fps";
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
567 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
568
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
569 Framerate.prototype.snapshot = function()
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
570 {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
571 if (this.renderTime < 0)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
572 this.renderTime = new Date().getTime();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
573 else {
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
574 var newTime = new Date().getTime();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
575 var t = newTime - this.renderTime;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
576 var framerate = 1000/t;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
577 this.framerates.push(framerate);
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
578 while (this.framerates.length > this.numFramerates)
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
579 this.framerates.shift();
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
580 this.renderTime = newTime;
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
581 }
Daiki KINJYO <e085722@ie.u-ryukyu.ac.jp>
parents:
diff changeset
582 }