-
Notifications
You must be signed in to change notification settings - Fork 4
/
multiple-shaders.js
62 lines (56 loc) · 1.3 KB
/
multiple-shaders.js
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
concat=function(x,y){return Array.prototype.push.apply(x,y),x}
w=a.width=innerWidth
h=a.height=innerHeight
g=a.getContext('webgl')||a.getContext('experimental-webgl')
g.enable(g.DEPTH_TEST)
// background
p1=$prog(g,[vs1,fs1])
bkgBuf=$buf(sq(12))
// foreground
p2=$prog(g,[vs2,fs2])
colors=[]
for(i=36;i--;)
concat(colors,[
[1,0,0],
[1,1,0],
[0,1,0],
[0,1,1],
[0,0,1],
[1,0,1],
[1,1,1]
][i%7])
colorBuf=$buf(colors)
diceBuf=$buf(qb())
P=perspective(45,w/h,0.1,100)
~function scene(time,m) {
time/=1e3
// clear screen
g.clearColor(1/5,1/5,1/5,1)
g.clear(g.COLOR_BUFFER_BIT|g.DEPTH_BUFFER_BIT)
// program 1
$prog(g,p1)
$attr("pos")
$bind("pos",bkgBuf,3)
$uni("time",time)
$uniV("resolution",[w,h])
$uniM("M",mX(P, mT(0,0,-15)))
g.drawArrays(g.TRIANGLE_STRIP,0,4)
$attrOff("pos")
// program 2
$prog(g,p2)
$attr("pos")
$attr("color")
$bind("pos", diceBuf,3)
$bind("color", colorBuf,3)
// set uniforms
$uni("time",time)
$uniV("resolution",[w,h])
// create transformation/rotation matrix
// mX is matrix multiplication, mT is transformation, mR* is rotatio
$uniM("M",mX(P,mX(mT(sin(time*2)*3,cos(time*3)*1.5,sin(time)*5-10),
mX(mX(mRx(time*3.5),mRy(time*2)),mRz(time*1.6)))))
g.drawArrays(g.TRIANGLES,0,36)
$attrOff("color")
$attrOff("pos")
requestAnimationFrame(scene)
}(0)