summaryrefslogtreecommitdiffstats
path: root/dom/canvas/test/webgl-mochitest/test_vertexattrib4f_update.html
blob: e845b4a5943d74461af4a321f56f81a066fef177 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
<!DOCTYPE html>
<html>
  <head>
    <meta charset='utf-8'>
    <title>Bug 1426289 - vertexAttrib4f should actually update.</title>
    <script src='/tests/SimpleTest/SimpleTest.js'></script>
    <link rel='stylesheet' href='/tests/SimpleTest/test.css'>
    <script src='webgl-util.js'></script>
  </head>
  <body>
    <script id='eVertSource' type='none'>
attribute vec4 aColor;
varying vec4 vColor;

void main() {
  gl_PointSize = 64.0;
  gl_Position = vec4(vec3(0.0), 1.0);
  vColor = aColor;
}
    </script>
    <script id='eFragSource' type='none'>
precision mediump float;
varying vec4 vColor;

void main() {
  gl_FragColor = vColor;
}
    </script>
    <script>
const canvas = document.createElement('canvas');
canvas.width = 1;
canvas.height = 1;
const gl = canvas.getContext('webgl');

const prog = WebGLUtil.linkProgramByIds(gl, eVertSource, eFragSource);
gl.useProgram(prog);

function getRgb() {
  const data = new Uint32Array(1);
  gl.readPixels(0, 0, 1, 1, gl.RGBA, gl.UNSIGNED_BYTE, new Uint8Array(data.buffer));
  return data[0] & 0xffffff;
}

gl.clearColor(0.0, 0.0, 0.0, 1.0);
gl.clear(gl.COLOR_BUFFER_BIT);
let was = getRgb();
ok(was == 0x000000, '0x'+was.toString(16));

gl.disableVertexAttribArray(prog.aColor);

gl.vertexAttrib4f(prog.aColor, 1, 0, 0, 1);
gl.drawArrays(gl.POINTS, 0, 1);
was = getRgb();
ok(was == 0x0000ff, '0x'+was.toString(16));

gl.vertexAttrib4f(prog.aColor, 0, 1, 0, 1);
gl.drawArrays(gl.POINTS, 0, 1);
was = getRgb();
ok(was == 0x00ff00, '0x'+was.toString(16));
    </script>
  </body>
</html>