diff options
Diffstat (limited to 'addons')
76 files changed, 3855 insertions, 0 deletions
diff --git a/addons/visualization.vortex/addon.xml b/addons/visualization.vortex/addon.xml new file mode 100644 index 0000000000..9a975ffd42 --- /dev/null +++ b/addons/visualization.vortex/addon.xml @@ -0,0 +1,13 @@ +<?xml version="1.0" encoding="UTF-8"?> +<addon + id="visualization.vortex" + version="1.0.0" + name="Vortex" + provider-name="Team XBMC"> + <extension + point="xbmc.player.musicviz" + library_windx="Vortex_win32dx.vis"/> + <extension point="xbmc.addon.metadata"> + <platform>windx</platform> + </extension> +</addon> diff --git a/addons/visualization.vortex/icon.png b/addons/visualization.vortex/icon.png Binary files differnew file mode 100644 index 0000000000..c8d07f5e46 --- /dev/null +++ b/addons/visualization.vortex/icon.png diff --git a/addons/visualization.vortex/resources/Presets/AlbumArtCube.vtx b/addons/visualization.vortex/resources/Presets/AlbumArtCube.vtx new file mode 100644 index 0000000000..44bf7a8d42 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/AlbumArtCube.vtx @@ -0,0 +1,28 @@ +// AlbumArtCube.vtx +// Author - MrC + +float time = 0; +float rx,rxamt,ry,ryamt; + +void Render() +{ + time += TIMEPASS; + + gfxSetTexture(TEXTURE_ALBUMART); + gfxTranslate(0, 0, 2.0f - (TREBLE * 0.5)); + + if (BASS>0.3) rxamt = 1; + if (BASS<-0.3) rxamt = -1; + if (TREBLE>0.3) ryamt = 1; + if (TREBLE<-0.3) ryamt = -1; + rx = rx + (rxamt*TIMEPASS); + ry = ry + (ryamt*TIMEPASS); + + gfxRotate(-70+(Sin(time)*12),1,0,0); + gfxRotate(rx*90,0,0,1); + gfxRotate(ry*90,0,1,0); + + gfxColour(1, 1, 1, 1); + gfxCube(-0.25f, -0.25f, -0.25f, 0.25f, 0.25f, 0.25f); + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/AlbumArtCubeRain.vtx b/addons/visualization.vortex/resources/Presets/AlbumArtCubeRain.vtx new file mode 100644 index 0000000000..86c4d23ad4 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/AlbumArtCubeRain.vtx @@ -0,0 +1,71 @@ +// AlbumArtCubeRain.vtx +// Author - MrC +// Based on CubeRain.r4 by Gordon Williams + +int x,y; +float c,tm,tn,td; +float[] c_x(256),c_y(256),c_z(256),c_vz(256),c_rx(256),c_ry(256),c_sx(256),c_sy(256),c_sz(256); + +float counter; + +void MakeNew(int n) +{ + c_x[n]=c_y[n]=0; + while (Mag(c_x[n],c_y[n])<1) + { + c_x[n] = (Rand()*10.0)-5.0; + c_y[n] = (Rand()*10.0)-5.0; + } + + c_z[n] = 10; + c_vz[n] = (1.0+Rand())*4; + c_rx[n] = (1.0+Rand())*80; + c_ry[n] = (1.0+Rand())*80; + c_sx[n] = (0.5+Rand())*0.5; + c_sy[n] = (0.5+Rand())*0.15; + c_sz[n] = (0.5+Rand())*0.15; +} + +void Init() +{ + counter = 0; + + for (x=0;x<256;x=x+1) + { + MakeNew(x); + c_z[x] = Rand()*10; + } + tm = tn = 0; +} + +void Render() +{ + td = ((TREBLE+1.0f)*TIMEPASS); + tm = tm + td; + tn = tn + ((BASS+1.5)*TIMEPASS*2); + + gfxTranslate(Cos(tn * 1.23f) * 0.5f, Sin(tn) * 0.5f, 0.0f); + gfxRotate(Cos(tn*0.6734f)*20.0f, 1.0f, 0.0f, 0.0f); + gfxRotate(Sin(tn*0.2143f)*20.0f, 0.0f, 1.0f, 0.0f); + + gfxSetTexture(TEXTURE_ALBUMART); + + for (x=0;x<20;x=x+1) + { + c_z[x] = c_z[x] - (td*c_vz[x]); + if (c_z[x]<0) + { + MakeNew(x); + } + + c = Cos(c_z[x]*0.05*3.1416); + gfxColour(c,c,c,1); + gfxPushMatrix(); + gfxTranslate(c_x[x],c_y[x],c_z[x]); + gfxRotate(c_rx[x]*tm, 1, 0, 0); + gfxRotate(c_ry[x]*tm, 0, 1, 0); + gfxCube(-c_sx[x],-c_sx[x],-c_sx[x],c_sx[x],c_sx[x],c_sx[x]); + gfxPopMatrix(); + } + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/AlbumArtStretch.vtx b/addons/visualization.vortex/resources/Presets/AlbumArtStretch.vtx new file mode 100644 index 0000000000..b92d2c1c61 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/AlbumArtStretch.vtx @@ -0,0 +1,52 @@ +// AlbumArtStretch.vtx +// Author - MrC + +Map map; +float time = 0; + +void Init() +{ + map.SetTimed(); +} + +void Render() +{ + if (BASS > 0) + time += (BASS)* TIMEPASS; + + float myX = Sin(time); + float myY = Cos(time); + + float dx, dy; + + for (int y = 0; y < 24; y++) + { + for (int x = 0; x < 32; x++) + { + dx = x-15.5; + dy = y-11.5; + float mx = dx + myX*10; + float my = dy + myY*10; + + map.SetValues(x,y, mx, my, -2, -2, -2); + } + } + + map.Render(); + gfxSetRenderTarget(map); + + gfxSetTexture(TEXTURE_ALBUMART); + + gfxSetAspect(0); + gfxTranslate(0, 0, 2.414); + + float x = (MIDDLE + 1) / 2; + float y = (TREBLE+ 1) / 2; + + gfxTexRect(-1 * x, 1 * y, 1 * x, -1 * y); + + gfxSetRenderTarget(0); + gfxSetTexture(map); + + gfxTexRect(-1, 1, 1, -1); +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/AlbumArtWaveSpectrum.vtx b/addons/visualization.vortex/resources/Presets/AlbumArtWaveSpectrum.vtx new file mode 100644 index 0000000000..bb90cbaeb3 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/AlbumArtWaveSpectrum.vtx @@ -0,0 +1,102 @@ +// AlbumArtWaveSpectum.vtx +// Author : MrC + +float[] vl(256); +int x; +float[] cubeRot(3); +float[] cubePos(3); + +void Init() +{ + for (int i=0; i<9;i++) + { + cubePos[i] = 0.0f; + cubeRot[i] = 0.0f; + } + +} + +void Render() +{ + + gfxSetTexture(TEXTURE_ALBUMART); + + for (int i=0; i<3;i++) + { + cubePos[i] = cubePos[i] + cubeRot[i]; + cubeRot[i] = cubeRot[i] * 0.95; + if (cubeRot[i] > 1) + cubeRot[i] = 1; + if (cubeRot[i] < -1) + cubeRot[i] = -1; + } + + cubeRot[0] += BASS; + cubeRot[1] += MIDDLE; + cubeRot[2] += TREBLE; + + + gfxPushMatrix(); + gfxTranslate(-0.8, 0.25, 2); + + gfxRotate(cubePos[0],1,0,0); + gfxRotate(cubePos[1],0,0,1); + gfxRotate(cubePos[2],0,1,0); + + gfxCube(-0.25f, -0.25f, -0.25f, 0.25f, 0.25f, 0.25f); + gfxPopMatrix(); + + gfxSetTexture(NULL); + + gfxSetAspect(0); + gfxTranslate(0, 0, 2.414); + + gfxColour(1, 1, 1, 1); + + gfxBegin(PRIM_LINESTRIP); + for (int x=0; x<256; x=x+1) + { + float r = WaveLeft(x); + gfxVertex((x-128) / 256.0f + 0.3, r * 0.2f + 0.5f, 0); + } + gfxEnd(); + + gfxBegin(PRIM_LINESTRIP); + for (int x=0; x<256; x=x+1) + { + float r = WaveRight(x); + gfxVertex((x-128) / 256.0f + 0.3, r * 0.2f + 0.1f, 0); + } + gfxEnd(); + + // calculate spectrum + for (x=0;x<256;x=x+1) + vl[x] = 0; + for (x=0;x<512;x=x+1) + vl[x/2] = vl[x/2] + GetSpecLeft(x)+GetSpecRight(x); + + // now draw spectrum + gfxTranslate(-1,-0.9,0); + gfxBegin(PRIM_QUADLIST); + gfxSetTexture(NULL); + + + for (x = 0; x < 256; x++) + { + vl[x] = vl[x]/8; + if (vl[x]>1.0) vl[x]=1.0; + + + float xPos = x / 128.0f; + + gfxColour(1,0,0,1); + gfxVertex(xPos+(1/128.0f),0,0); + gfxVertex(xPos,0,0); + gfxColour(1,vl[x],0, 1); + gfxVertex(xPos,vl[x]*0.4,0); + gfxVertex(xPos+(1/128.0f),vl[x]*0.4,0); + } + gfxEnd(); + + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/AlbumArtZoomer.vtx b/addons/visualization.vortex/resources/Presets/AlbumArtZoomer.vtx new file mode 100644 index 0000000000..a7facdba75 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/AlbumArtZoomer.vtx @@ -0,0 +1,66 @@ +// AlbumArtZoomer.vtx +// Author - MrC + +float rot; +float zoom; +float dxx,dxy,dyx,dyy; + +float t; +float px = 16; +float py = 12; +float pdx = 1.342; +float pdy = 1; +float basstime = 0; + +void Init() +{ + zoom = 0; + rot=Rand(); + px = 16; + py = 12; + pdx = 1.342; + pdy = 1; + basstime = 0; +} + +void Quad(float rt, float sz) +{ + dxx = Cos(rt)*sz; + dxy = Sin(rt)*sz; + dyx = Sin(rt)*sz; + dyy = 0.0f-Cos(rt)*sz; + + gfxTexCoord((0.0f-dxx)+(0.0f+dyx),(0.0f-dxy)+(0.0f+dyy)); + gfxVertex(-1 * 2,1 * 2,0); + gfxTexCoord((0.0f+dxx)+(0.0f+dyx),(0.0f+dxy)+(0.0f+dyy)); + gfxVertex(1 * 2,1 * 2,0); + gfxTexCoord((0.0f+dxx)+(0.0f-dyx),(0.0f+dxy)+(0.0f-dyy)); + gfxVertex(1 * 2,-1 * 2,0); + gfxTexCoord((0.0f-dxx)+(0.0f-dyx),(0.0f-dxy)+(0.0f-dyy)); + gfxVertex(-1 * 2,-1 * 2,0); +} + +void Render() +{ + zoom += BASS * 2 * TIMEPASS; + rot += TREBLE * 4* TIMEPASS; + + t = TIMEPASS*(BASS+0.25) * 20; + px = px + (pdx*t); + if (px>28) { pdx = -Abs(pdx); px = 28; } + if (px<4) { pdx = Abs(pdx); px = 4; } + py = py + (pdy*t); + if (py>20) { pdy = -Abs(pdy); py=20; } + if (py<4) { pdy = Abs(pdy); py = 4; } + + // draw + gfxSetTexture(TEXTURE_ALBUMART); + gfxSetAspect(0); + gfxTranslate(((px / 28.0f) - 0.5f), (py / 20.0f) - 0.5f, 2.414f); + gfxBegin(PRIM_QUADLIST); + + gfxColour(1.0f, 1.0f, 1.0f, 1); + Quad(Sin(rot),(Fabs(Sin(zoom)) + 0.25)*5); + gfxEnd(); + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/Awakenings.vtx b/addons/visualization.vortex/resources/Presets/Awakenings.vtx new file mode 100644 index 0000000000..e052516855 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/Awakenings.vtx @@ -0,0 +1,125 @@ +// Awakenings.vtx +// Author - MrC +// Based on Awakenings_remix.r4 by John Baker and Gordon Williams + +int x,y; +float c,tm,tn,td; +float[] c_x(256),c_y(256),c_z(256),c_vz(256),c_rx(256),c_ry(256),c_sx(256),c_sy(256),c_sz(256); +float d; + +Texture envTexture; + +void MakeNew(int n) +{ + c_x[n]=c_y[n]=0; + while (Mag(c_x[n],c_y[n])<1) + { + c_x[n] = (Rand()*8.0)-4.0; + c_y[n] = (Rand()*8.0)-4.0; + } + + c_z[n] = 10; + c_vz[n] = (1.0+Rand())*4; + c_rx[n] = (1.0+Rand())*80; + c_ry[n] = (1.0+Rand())*80; + c_sx[n] = (0.5+Rand())*0.5; + c_sy[n] = (0.5+Rand())*0.5; + c_sz[n] = (0.5+Rand())*0.05; +} + + +void Init() +{ + envTexture.LoadTexture("xbmc_icon.png"); + + for (x=0;x<256;x=x+1) + { + MakeNew(x); + c_z[x] = Rand()*10; + } + tm = tn = 0; +} + +void mything(float x,float y,float z) +{ + gfxBegin(PRIM_QUADLIST); + gfxTexCoord(0,0); + gfxVertex(-x,y,0); + gfxTexCoord(1,0); + gfxVertex(x,y,0); + gfxTexCoord(1,1); + gfxVertex(x,-y,0); + gfxTexCoord(0,1); + gfxVertex(-x,-y,0); + + gfxTexCoord(0,0); + gfxVertex(-x,0,z); + gfxTexCoord(1,0); + gfxVertex(x,0,z); + gfxTexCoord(1,1); + gfxVertex(x,0,-z); + gfxTexCoord(0,1); + gfxVertex(-x,0,-z); + + gfxTexCoord(0,0); + gfxVertex(0,-y,z); + gfxTexCoord(1,0); + gfxVertex(0,y,z); + gfxTexCoord(1,1); + gfxVertex(0,y,-z); + gfxTexCoord(0,1); + gfxVertex(0,-y,-z); + gfxEnd(); +} + +void Render() +{ + td = ((TREBLE+1.5f) * TIMEPASS); + tm = tm + td; + tn = tn + ((BASS+1.0) * TIMEPASS * 2); + + gfxTranslate(Cos(tn * 1.23f) * 0.25f, Sin(tn) * 0.25f, 0.0f); + gfxRotate(Cos(tn*0.6734f)*20.0f, 1.0f, 0.0f, 0.0f); + gfxRotate(Sin(tn*0.2143f)*20.0f, 0.0f, 1.0f, 0.0f); + + gfxSetBlendMode(BLEND_MOD); + gfxSetTexture(envTexture); + gfxTranslate(0, 0, 3+BASS); + gfxBegin(PRIM_QUADLIST); + gfxTexCoord(0, 0); + gfxVertex(-1.5, 1,0); + gfxTexCoord(1, 0); + gfxVertex(1.5, 1,0); + gfxTexCoord(1, 1); + gfxVertex(1.5, -1,0); + gfxTexCoord(0, 1); + gfxVertex(-1.5, -1,0); + gfxEnd(); + gfxTranslate(0, 0, -3-BASS); + + gfxSetTexture(envTexture); + gfxSetBlendMode(BLEND_ADD); + + for (x=255;x>0;x=x-1) + { + c_z[x] = c_z[x] - (td*c_vz[x]); + if (c_z[x]<0) MakeNew(x); + + c = (5.0-(c_z[x]*0.5))*0.1; + if (c>1.75) c=(2-c)*4; + if (c>1) c=1; + + d = (20.0-(c_z[x]*2.0))*0.1; + if (d>1.75) d=(2-c)*4; + if (d>1) c=1; + + gfxColour(c,d*(TREBLE+1)*0.5,c,1); + gfxPushMatrix(); + gfxTranslate(c_x[x],c_y[x],c_z[x]); + gfxRotate(c_rx[x]*tm,1.0f,0.0f,0.0f); + gfxRotate(c_ry[x]*tm,0.0f,1.0f,0.0f); + mything(c_sx[x],c_sy[x],c_sz[x]); + gfxPopMatrix(); + } + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/Block.tra b/addons/visualization.vortex/resources/Presets/Block.tra new file mode 100644 index 0000000000..6f3526bfbe --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/Block.tra @@ -0,0 +1,88 @@ +// Block.tra +// Author - MrC +// Based on FadeBlocks.r4 by Gordon Williams + +int i,x,y; +float dx,dy,sx,sy,dd,a,b,mytime; +float[] d(64); +Texture mix; + +void Init() +{ + mix.CreateTexture(); + for (x=0;x<64;x=x+1) + d[x] = Rand()-0.5; + mytime = 0; +} + +void Rect(float x0, float y0, float x1, float y1) +{ + gfxBegin(PRIM_QUADLIST); + + gfxTexCoord(0,1); + gfxVertex(x0, y0, 0.0); + gfxTexCoord(1, 1); + gfxVertex(x1, y0, 0.0); + gfxTexCoord(1, 0); + gfxVertex(x1, y1, 0.0); + gfxTexCoord(0, 0); + gfxVertex(x0, y1, 0.0); + + gfxEnd(); + +} +void Render() +{ + mytime = mytime + (TIMEPASS*0.25); + FINISHED = mytime>=1.0; + b = (1.0-Cos(mytime*3.14159))*0.5; + + + gfxSetRenderTarget(mix); + gfxClear(0); + gfxSetAspect(0); + a = -2.414; + gfxTranslate(0, 0, -a); + gfxSetBlendMode(BLEND_MOD); + gfxColour(1, 1, 1, 1-b); + gfxSetTexture(TEXTURE_CURRPRESET); + gfxTexRect(-1, 1, 1, -1); + gfxColour(1, 1, 1, b); + gfxSetTexture(TEXTURE_NEXTPRESET); + gfxTexRect(-1, -1, 1, 1); + + gfxSetRenderTarget(TEXTURE_FRAMEBUFFER); + gfxSetBlendMode(BLEND_OFF); + + + gfxSetAspect((1.0-Cos(b*3.14159*2.0))*0.5); + + gfxRotate(b*180, 0, 1, 0); + gfxRotate(b*180, 0, 0, 1); + gfxColour(1, 1, 1, 1); + + gfxSetTexture(mix); + + gfxBegin(PRIM_QUADLIST); + + for (i=0;i<64;i=i+1) + { + x = i%8; + y = i/8; + dx = (x/8.0); + dy = (y/8.0); + sx = ((x+1.0)/8.0); + sy = ((y+1.0)/8.0); + dd = 0.83*(a-((0.5-b)*2*d[i])); + gfxTexCoord(1.0-dx,dy); + gfxVertex(dd*(dx-0.5),dd*(dy-0.5),d[i]); + gfxTexCoord(1.0-sx,dy); + gfxVertex(dd*(sx-0.5),dd*(dy-0.5),d[i]); + gfxTexCoord(1.0-sx,sy); + gfxVertex(dd*(sx-0.5),dd*(sy-0.5),d[i]); + gfxTexCoord(1.0-dx,sy); + gfxVertex(dd*(dx-0.5),dd*(sy-0.5),d[i]); + } + gfxEnd(); + +} diff --git a/addons/visualization.vortex/resources/Presets/ChessMania.vtx b/addons/visualization.vortex/resources/Presets/ChessMania.vtx new file mode 100644 index 0000000000..278d36c612 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/ChessMania.vtx @@ -0,0 +1,90 @@ +// ChessMania.vtx +// Author - MrC +// Based on Rovastar - Chessmania.r4 by John Baker + +Texture checker; +Texture tex1; +Texture tex2; + +float[] cubeRot(3*3); +float[] cubePos(3*3); + +void Init() +{ + checker.LoadTexture("checker.png"); + tex1.CreateTexture(); + tex2.CreateTexture(); + + for (int i=0; i<9;i++) + { + cubePos[i] = 0.0f; + cubeRot[i] = 0.0f; + } + +} + +void RenderCube(int cube, float dist) +{ + gfxPushMatrix(); + gfxTranslate(0, 0, dist); + + gfxRotate(cubePos[0+cube*3],1,0,0); + gfxRotate(cubePos[1+cube*3],0,0,1); + gfxRotate(cubePos[2+cube*3],0,1,0); + + gfxCube(-0.25f, -0.25f, -0.25f, 0.25f, 0.25f, 0.25f); + gfxPopMatrix(); +} + +void Render() +{ + gfxSetTexture(checker); + + gfxTranslate(0,0,2.414); + + for (int i=0; i<9;i++) + { + cubePos[i] = cubePos[i] + cubeRot[i]; + cubeRot[i] = cubeRot[i] * 0.95; + if (cubeRot[i] > 1) + cubeRot[i] = 1; + if (cubeRot[i] < -1) + cubeRot[i] = -1; + } + + cubeRot[0] += BASS; + cubeRot[1] += MIDDLE; + cubeRot[2] += TREBLE; + + cubeRot[4] += BASS; + cubeRot[5] += MIDDLE; + cubeRot[3] += TREBLE; + + cubeRot[8] += BASS; + cubeRot[6] += MIDDLE; + cubeRot[7] += TREBLE; + + gfxSetRenderTarget(tex1); + gfxClear(0); + gfxSetTexture(checker); + gfxSetAspect(0); + gfxTexRect(-1, -1, 1, 1); + RenderCube(2, -1.0); + + gfxSetRenderTarget(tex2); + gfxClear(0); + gfxSetTexture(checker); + gfxSetAspect(0); + gfxTexRect(-1, -1, 1, 1); + gfxSetTexture(tex1); + RenderCube(1, -1.0); + + gfxSetRenderTarget(TEXTURE_FRAMEBUFFER); + gfxSetTexture(checker); + gfxSetAspect(0); + gfxTexRect(-1, -1, 1, 1); + gfxSetTexture(tex2); + gfxSetAspect(1); + RenderCube(0, -1.15); + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/CubeBlowOut.tra b/addons/visualization.vortex/resources/Presets/CubeBlowOut.tra new file mode 100644 index 0000000000..4674c0972e --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/CubeBlowOut.tra @@ -0,0 +1,160 @@ +// CubeBlowOut.tra +// Author - MrC +// Based on FadeCubeBlowOut.r4 by Gordon Williams + +int x,y; +float c,tm,td,ftime,fric; +float[] c_tx(64),c_ty(64),c_x(64),c_y(64),c_z(64),c_vx(64),c_vy(64),c_vz(64),c_rx(64),c_ry(64); +const float dx = 0.125; +const float dy = 0.125; + +void Init() +{ + reset(); +} + +void makenew(int n) +{ + c_tx[n]=(n%8)/8.0; + c_ty[n]=(n-(n%8))/64.0; + c_x[n] = (c_tx[n]-0.5)*2+dx; + c_y[n] = (c_ty[n]-0.5)*2+dy; + c_z[n] = 0; + c_vx[n] = (c_x[n]+Rand()-0.5); + c_vy[n] = (c_y[n]+Rand()); + c_vz[n] = (1.0+Rand()); + c_rx[n] = (1.0+Rand())*160; + c_ry[n] = (1.0+Rand())*160; +} + +void drawcube(int n) +{ + gfxBegin(PRIM_QUADLIST); + // FRONT FACE + gfxTexCoord(c_tx[n],c_ty[n]); + gfxVertex(-1,-1,-1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n])); + gfxVertex(1,-1,-1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n]+dy)); + gfxVertex(1,1,-1); + gfxTexCoord(c_tx[n],1-(c_ty[n]+dy)); + gfxVertex(-1,1,-1); + // BACK + gfxTexCoord(c_tx[n],1-(c_ty[n])); + gfxVertex(-1,-1,1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n])); + gfxVertex(1,-1,1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n]+dy)); + gfxVertex(1,1,1); + gfxTexCoord(c_tx[n],1-(c_ty[n]+dy)); + gfxVertex(-1,1,1); + // LEFT + gfxTexCoord(c_tx[n],1-(c_ty[n])); + gfxVertex(-1,-1,-1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n])); + gfxVertex(-1,-1,1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n]+dy)); + gfxVertex(-1,1,1); + gfxTexCoord(c_tx[n],1-(c_ty[n]+dy)); + gfxVertex(-1,1,-1); + // RIGHT + gfxTexCoord(c_tx[n],1-(c_ty[n])); + gfxVertex(1,-1,-1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n])); + gfxVertex(1,-1,1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n]+dy)); + gfxVertex(1,1,1); + gfxTexCoord(c_tx[n],1-(c_ty[n]+dy)); + gfxVertex(1,1,-1); + // UP + gfxTexCoord(c_tx[n],1-(c_ty[n])); + gfxVertex(1,-1,-1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n])); + gfxVertex(1,-1,1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n]+dy)); + gfxVertex(-1,-1,1); + gfxTexCoord(c_tx[n],1-(c_ty[n]+dy)); + gfxVertex(-1,-1,-1); + // DOWN + gfxTexCoord(c_tx[n],1-(c_ty[n])); + gfxVertex(1,1,-1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n])); + gfxVertex(1,1,1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n]+dy)); + gfxVertex(-1,1,1); + gfxTexCoord(c_tx[n],1-(c_ty[n]+dy)); + gfxVertex(-1,1,-1); + + gfxEnd(); +} + +void reset() +{ + for (x=0;x<64;x=x+1) + { + makenew(x); + } + tm = 0; + ftime = 0; +} + +void Render() +{ + gfxPushMatrix(); + gfxTranslate(0, 0, 2.414); + gfxSetAspect(0); + gfxSetTexture(TEXTURE_NEXTPRESET); + gfxColour(1, 1, 1, 1); + gfxTexRect(-1, 1, 1, -1); + gfxPopMatrix(); + gfxSetAspect(1); + gfxSetTexture(TEXTURE_CURRPRESET); + + + if (ftime<0.1) + td = TIMEPASS*(ftime*10); + else + td = TIMEPASS; + tm = tm+td; + + ftime = ftime + (TIMEPASS*0.225); + if (ftime>0.6) + { + ftime=1; + FINISHED = true; + return; + } + + gfxPushMatrix(); + + gfxSetAspect(0); + gfxScale(-1,1,1); + gfxTranslate(0,0,2.414); + gfxTranslate(0,0,-dx); + gfxRotate(180,0,1,0); + + fric = Pow(0.75,td); + + for (x=0;x<64;x=x+1) + { + c_vy[x] = c_vy[x] - (td*2); + c_x[x] = c_x[x] + (td*c_vx[x]); + c_y[x] = c_y[x] + (td*c_vy[x]); + c_z[x] = c_z[x] + (td*c_vz[x]); + c_vx[x] = c_vx[x]*fric; + c_vy[x] = c_vy[x]*fric; + c_vz[x] = c_vz[x]*fric; + + gfxPushMatrix(); + gfxTranslate(c_x[x],c_y[x],c_z[x]); + gfxRotate(c_rx[x]*tm,1,0,0); + gfxRotate(c_ry[x]*tm,0,1,0); + gfxScale(dx,dx,dx); + drawcube(x); + + gfxPopMatrix(); + + } + + gfxPopMatrix(); +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/CubeGrid.vtx b/addons/visualization.vortex/resources/Presets/CubeGrid.vtx new file mode 100644 index 0000000000..bbceb82676 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/CubeGrid.vtx @@ -0,0 +1,69 @@ +// CubeGrid.vtx +// Author - MrC +// Based on CubeGrid.r4 by Gordon Williams + +int x,y,z; +float t,c; +float bt,bs; +float time; + +const int XMAX = 3; +const int YMAX = 3; +const int ZMAX = 5; + +Texture envTexture; + +void Init() +{ + t = 0; + bt = 0; + bs = 0; + time = 0; + envTexture.LoadTexture("env3.png"); +} + +void Render() +{ + bt = bt + (TIMEPASS*(MIDDLE+0.5f)); + bs = bs + (TIMEPASS*(TREBLE+0.5f)); + t = t + (TIMEPASS*2.5); + while (t>1.0) + { + t=t-1.0; + } + + time = time + TIMEPASS; + + gfxRotate(time*60.0f, 0.0f, 0.0f, 1.0f); + gfxRotate(bt*53.0f, 1.0f, 0.0f, 1.0f); + gfxRotate(bs*62.0f, 0.0f, 1.0f, 0.0f); + + gfxSetEnvTexture(envTexture); + + gfxTranslate(-XMAX*0.5f, -YMAX*0.5f, -3.0f+t); + for (z=0;z<=ZMAX;z=z+1) + { + c=1; + if (z==0) + c = t; + if (z==ZMAX) + c = 1.0f - t; + gfxColour(c,c,c,1); + for (y=0;y<=YMAX;y=y+1) + { + for (x=0;x<=XMAX;x=x+1) + { + gfxCube(x-0.15f, y-0.15f, z-0.15f, x+0.15f, y+0.15f, z+0.15f); + if (x<XMAX) + { + gfxCube(x+0.15f, y-0.05f, z-0.05f, x+0.85f, y+0.05f, z+0.05f); + } + if (y<YMAX) + { + gfxCube(x-0.05f, y+0.15f, z-0.05f, x+0.05f, y+0.85f, z+0.05f); + } + gfxCube(x-0.05f, y-0.05f, z+0.15f, x+0.05f, y+0.05f, z+0.85f); + } + } + } +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/CubeGridStrobe.vtx b/addons/visualization.vortex/resources/Presets/CubeGridStrobe.vtx new file mode 100644 index 0000000000..5180032c17 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/CubeGridStrobe.vtx @@ -0,0 +1,74 @@ +// CubeGridStrobe.vtx +// Author - Pike +// Based on CubeGrid.r4 by Gordon Williams + +int x,y,z; +float t,c; +float bt,bs; +float time; + +const int XMAX = 3; +const int YMAX = 3; +const int ZMAX = 5; + +Texture envTexture; +Texture envTexture1; + +void Init() +{ + t = 0; + bt = 0; + bs = 0; + time = 0; + envTexture.LoadTexture("env2.jpg"); + envTexture1.LoadTexture("env3_darker.png"); +} + +void Render() +{ + bt = bt + (TIMEPASS*(MIDDLE+0.5f)); + bs = bs + (TIMEPASS*(TREBLE+0.5f)); + t = t + (TIMEPASS*2.5); + while (t>1.0) + { + t=t-1.0; + } + + time = time + TIMEPASS; + + gfxRotate(time*60.0f, 0.0f, 0.0f, 1.0f); + gfxRotate(bt*53.0f, 1.0f, 0.0f, 1.0f); + gfxRotate(bs*62.0f, 0.0f, 1.0f, 0.0f); + + if (TREBLE > 0.5) + gfxSetEnvTexture(envTexture); + else + gfxSetEnvTexture(envTexture1); + + gfxTranslate(-XMAX*0.5f, -YMAX*0.5f, -3.0f+t); + for (z=0;z<=ZMAX;z=z+1) + { + c=1; + if (z==0) + c = t; + if (z==ZMAX) + c = 1.0f - t; + gfxColour(c,c,c,1); + for (y=0;y<=YMAX;y=y+1) + { + for (x=0;x<=XMAX;x=x+1) + { + gfxCube(x-0.15f, y-0.15f, z-0.15f, x+0.15f, y+0.15f, z+0.15f); + if (x<XMAX) + { + gfxCube(x+0.15f, y-0.05f, z-0.05f, x+0.85f, y+0.05f, z+0.05f); + } + if (y<YMAX) + { + gfxCube(x-0.05f, y+0.15f, z-0.05f, x+0.05f, y+0.85f, z+0.05f); + } + gfxCube(x-0.05f, y-0.05f, z+0.15f, x+0.05f, y+0.05f, z+0.85f); + } + } + } +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/CubeGridWire.vtx b/addons/visualization.vortex/resources/Presets/CubeGridWire.vtx new file mode 100644 index 0000000000..18d848d0f6 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/CubeGridWire.vtx @@ -0,0 +1,75 @@ +// CubeGridWire.vtx +// Author - MrC +// Based on CubeGrid.r4 by Gordon Williams + +int x,y,z; +float t,c; +float bt,bs; +float time; + +const int XMAX = 3; +const int YMAX = 3; +const int ZMAX = 5; + +Texture envTexture; + +void Init() +{ + t = 0; + bt = 0; + bs = 0; + time = 0; + envTexture.LoadTexture("env2.jpg"); +} + +void Render() +{ + bt = bt + (TIMEPASS*(MIDDLE+0.5f)); + bs = bs + (TIMEPASS*(TREBLE+0.5f)); + t = t + (TIMEPASS*2.5); + while (t>1.0) + { + t=t-1.0; + } + + time = time + TIMEPASS; + + gfxRotate(time*60.0f, 0.0f, 0.0f, 1.0f); + gfxRotate(bt*53.0f, 1.0f, 0.0f, 1.0f); + gfxRotate(bs*62.0f, 0.0f, 1.0f, 0.0f); + + if (TREBLE < 0.5) + { + gfxSetTexture(NULL); + gfxSetFillMode(FILLMODE_WIREFRAME); + } + else + gfxSetEnvTexture(envTexture); + + gfxTranslate(-XMAX*0.5f, -YMAX*0.5f, -3.0f+t); + for (z=0;z<=ZMAX;z=z+1) + { + c=1; + if (z==0) + c = t; + if (z==ZMAX) + c = 1.0f - t; + gfxColour(c,c,c,1); + for (y=0;y<=YMAX;y=y+1) + { + for (x=0;x<=XMAX;x=x+1) + { + gfxCube(x-0.15f, y-0.15f, z-0.15f, x+0.15f, y+0.15f, z+0.15f); + if (x<XMAX) + { + gfxCube(x+0.15f, y-0.05f, z-0.05f, x+0.85f, y+0.05f, z+0.05f); + } + if (y<YMAX) + { + gfxCube(x-0.05f, y+0.15f, z-0.05f, x+0.05f, y+0.85f, z+0.05f); + } + gfxCube(x-0.05f, y-0.05f, z+0.15f, x+0.05f, y+0.05f, z+0.85f); + } + } + } +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/CubeRain.vtx b/addons/visualization.vortex/resources/Presets/CubeRain.vtx new file mode 100644 index 0000000000..5ddbae8e55 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/CubeRain.vtx @@ -0,0 +1,70 @@ +// CubeRain.vtx +// Author - MrC +// Based on CubeRain.r4 By Gordon Williams +int x,y; +float c,tm,tn,td; +float[] c_x(256),c_y(256),c_z(256),c_vz(256),c_rx(256),c_ry(256),c_sx(256),c_sy(256),c_sz(256); + +float counter; +Texture envTexture; + +void MakeNew(int n) +{ + c_x[n]=c_y[n]=0; + while (Mag(c_x[n],c_y[n])<1) + { + c_x[n] = (Rand()*8.0)-4.0; + c_y[n] = (Rand()*8.0)-4.0; + } + + c_z[n] = 10; + c_vz[n] = (1.0+Rand())*4; + c_rx[n] = (1.0+Rand())*80; + c_ry[n] = (1.0+Rand())*80; + c_sx[n] = (0.5+Rand())*0.15; + c_sy[n] = (0.5+Rand())*0.15; + c_sz[n] = (0.5+Rand())*0.15; +} + +void Init() +{ + envTexture.LoadTexture("env2.jpg"); + counter = 0; + + for (x=0;x<256;x=x+1) + { + MakeNew(x); + c_z[x] = Rand()*10; + } + tm = tn = 0; +} + +void Render() +{ + td = ((TREBLE+1.0f)*TIMEPASS); + tm = tm + td; + tn = tn + ((BASS+1.5)*TIMEPASS*2); + + gfxTranslate(Cos(tn * 1.23f) * 0.5f, Sin(tn) * 0.5f, 0.0f); + gfxRotate(Cos(tn*0.6734f)*20.0f, 1.0f, 0.0f, 0.0f); + gfxRotate(Sin(tn*0.2143f)*20.0f, 0.0f, 1.0f, 0.0f); + + gfxSetEnvTexture(envTexture); + + for (x=0;x<256;x=x+1) + { + c_z[x] = c_z[x] - (td*c_vz[x]); + if (c_z[x]<0) + { + MakeNew(x); + } + c = Cos(c_z[x]*0.05*3.1416); + gfxColour(c,c,c,1); + gfxPushMatrix(); + gfxTranslate(c_x[x],c_y[x],c_z[x]); + gfxRotate(c_rx[x]*tm, 1, 0, 0); + gfxRotate(c_ry[x]*tm, 0, 1, 0); + gfxCube(-c_sx[x],-c_sy[x],-c_sz[x],c_sx[x],c_sy[x],c_sz[x]); + gfxPopMatrix(); + } +} diff --git a/addons/visualization.vortex/resources/Presets/CubeSlide.vtx b/addons/visualization.vortex/resources/Presets/CubeSlide.vtx new file mode 100644 index 0000000000..09beb21c3c --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/CubeSlide.vtx @@ -0,0 +1,69 @@ +// CubeSlide.vtx +// Author - MrC +// Based on CubeSlide.r4 by Gordon Williams + +Texture env; +Texture skybox; + +int x,y; +float tm,tn,ofs,c; + +void Init() +{ + skybox.LoadTexture("skybox.dds"); + env.LoadTexture("tex_edge.png"); +} + +void reset() +{ + tm = 0; + tn = 0; +} + +float tiltfunc(float p) +{ + return (Sin((ofs+p)*0.1)+Cos((ofs+p)*0.123))*10.0; +} + +void Render() +{ + tm = tm + 1 * TIMEPASS * 8; + + if (TREBLE > 0.0) + tm = tm + ((TREBLE) * TIMEPASS * 20); + + while (tm>1) + { + tm = tm-1; + ofs = ofs + 1; + } + + tn = tn + ((BASS+1.5)*TIMEPASS); + + + gfxSetAspect(0); + gfxLookAt(Cos(tn*1.23)*5,Sin(tn)*5,(tm*2)-1,Cos(tn*0.6734)*2,Sin(tn*0.2143)*2,(tm*2)+8,0,1,0); + gfxRotate(-tiltfunc(0)*tm,0,0,1); + + gfxSetTexture(skybox); + gfxPushMatrix(); + gfxTranslate(0,0,tm*2); + gfxRotate(tiltfunc(0)*tm,0,0,1); + gfxCube(-400,-400,-400,400,400,400); + gfxPopMatrix(); + gfxSetTexture(env); + + gfxSetBlendMode(BLEND_ADD); + + for (y=0;y<15;y=y+1) + { + c = 1.0 - ((y-tm)/15.0); + for (x=-3;x<4;x=x+1) + { + gfxColour(c,c,c,1); + gfxCube((x*2)-0.75,-0.375,(y*2)-0.75, (x*2)+0.75,0.375,(y*2)+0.75); + } + gfxRotate(tiltfunc(y),0,0,1); + } + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/CubeTunnel.vtx b/addons/visualization.vortex/resources/Presets/CubeTunnel.vtx new file mode 100644 index 0000000000..9bb7a69940 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/CubeTunnel.vtx @@ -0,0 +1,66 @@ +// CubeTunnel.vtx +// Author - MrC +// Based on CubeTunnel.r4 By Gordon Williams + +Texture texture; +Texture sky; + +int x,y; +float tm,tn,ofs,c,ox,oy,stretch; + +void Init() +{ + sky.LoadTexture("skybox.dds"); + texture.LoadTexture("plasma_edge.jpg"); + + tm = 0; + tn = 0; +} + +float tiltfunc(float p) +{ + float a = (Sin((ofs+p)*0.1) + Cos((ofs+p)*0.423))*15.0; + return a; +} + +void Render() +{ + tm = tm + ((TREBLE+1.5)*TIMEPASS*8); + while (tm>1) + { + tm = tm-1; + ofs = ofs + 1; + } + + + tn = tn + ((BASS+1.5)*TIMEPASS); + + stretch = 3.5+(Sin(tn*1.23)*2); + + gfxSetAspect(0); + gfxLookAt(Cos(tn*1.23)*2.5, Sin(tn)*2.5,(tm*stretch)-1,Cos(tn*0.6734)*2,Sin(tn*0.2143)*2,(tm*stretch)+6,0.0,1.0,0.0); + gfxRotate(-tiltfunc(0)*tm,0,0,1); + + gfxSetTexture(sky); + gfxPushMatrix(); + gfxTranslate(0, 0, tm*stretch); + gfxRotate(tiltfunc(0)*tm,0,0,1); + gfxCube(-400,-400,-400,400,400,400); + gfxPopMatrix(); + + gfxSetTexture(texture); + + gfxSetBlendMode(BLEND_ADD); + for (y=0;y<15;y=y+1) + { + c = 1.0 - ((y-tm)/15.0); + for (x=0;x<8;x=x+1) + { + gfxColour(c,c,c,1); + ox = Sin(x*3.14159*0.25)*5; + oy = Cos(x*3.14159*0.25)*5; + gfxCube(ox-0.75,oy-0.75,(y*stretch)-(0.75*stretch), 0.75+ox,oy+0.75,(y*stretch)+(0.75*stretch)); + } + gfxRotate(tiltfunc(y),0,0,1); + } +} diff --git a/addons/visualization.vortex/resources/Presets/Cubes.tra b/addons/visualization.vortex/resources/Presets/Cubes.tra new file mode 100644 index 0000000000..c66439a597 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/Cubes.tra @@ -0,0 +1,162 @@ +// Cube.tra +// Author - MrC +// Based on FadeCube.r4 By Gordon Williams + +int x,y; +float c,tm,td,ftime,fric; +float[] c_tx(64),c_ty(64),c_x(64),c_y(64),c_z(64),c_vx(64),c_vy(64),c_vz(64),c_rx(64),c_ry(64); +const float dx = 0.125; +const float dy = 0.125; + +void Init() +{ + reset(); +} + +void makenew(int n) +{ + c_tx[n]=(n%8)/8.0; + c_ty[n]=(n-(n%8))/64.0; + c_x[n] = (c_tx[n]-0.5)*2+dx; + c_y[n] = (c_ty[n]-0.5)*2+dy; + c_z[n] = 0; + c_vx[n] = (c_x[n]+Rand()-0.5); + c_vy[n] = (c_y[n]+Rand()); + c_vz[n] = -(1.0+Rand()); + c_rx[n] = (1.0+Rand())*160; + c_ry[n] = (1.0+Rand())*160; +} + +void drawcube(int n) +{ + gfxBegin(PRIM_QUADLIST); + // FRONT FACE + gfxTexCoord(c_tx[n],c_ty[n]); + gfxVertex(-1,-1,-1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n])); + gfxVertex(1,-1,-1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n]+dy)); + gfxVertex(1,1,-1); + gfxTexCoord(c_tx[n],1-(c_ty[n]+dy)); + gfxVertex(-1,1,-1); + // BACK + gfxTexCoord(c_tx[n],1-(c_ty[n])); + gfxVertex(-1,-1,1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n])); + gfxVertex(1,-1,1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n]+dy)); + gfxVertex(1,1,1); + gfxTexCoord(c_tx[n],1-(c_ty[n]+dy)); + gfxVertex(-1,1,1); + // LEFT + gfxTexCoord(c_tx[n],1-(c_ty[n])); + gfxVertex(-1,-1,-1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n])); + gfxVertex(-1,-1,1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n]+dy)); + gfxVertex(-1,1,1); + gfxTexCoord(c_tx[n],1-(c_ty[n]+dy)); + gfxVertex(-1,1,-1); + // RIGHT + gfxTexCoord(c_tx[n],1-(c_ty[n])); + gfxVertex(1,-1,-1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n])); + gfxVertex(1,-1,1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n]+dy)); + gfxVertex(1,1,1); + gfxTexCoord(c_tx[n],1-(c_ty[n]+dy)); + gfxVertex(1,1,-1); + // UP + gfxTexCoord(c_tx[n],1-(c_ty[n])); + gfxVertex(1,-1,-1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n])); + gfxVertex(1,-1,1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n]+dy)); + gfxVertex(-1,-1,1); + gfxTexCoord(c_tx[n],1-(c_ty[n]+dy)); + gfxVertex(-1,-1,-1); + // DOWN + gfxTexCoord(c_tx[n],1-(c_ty[n])); + gfxVertex(1,1,-1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n])); + gfxVertex(1,1,1); + gfxTexCoord(c_tx[n]+dx,1-(c_ty[n]+dy)); + gfxVertex(-1,1,1); + gfxTexCoord(c_tx[n],1-(c_ty[n]+dy)); + gfxVertex(-1,1,-1); + + gfxEnd(); +} + +void reset() +{ + for (x=0;x<64;x=x+1) + { + makenew(x); + } + tm = 0; + ftime = 0; +} + +void Render() +{ + gfxPushMatrix(); + gfxTranslate(0, 0, 2.414); + gfxSetAspect(0); + gfxSetTexture(TEXTURE_NEXTPRESET); + gfxColour(1, 1, 1, 1); + gfxTexRect(-1, 1, 1, -1); + gfxPopMatrix(); + gfxSetAspect(1); + gfxSetTexture(TEXTURE_CURRPRESET); + + if (ftime<0.1) + td = TIMEPASS*(ftime*10); + else + td = TIMEPASS; + tm = tm+td; + + ftime = ftime + (TIMEPASS*0.225); + if (ftime>1) + { + ftime=1; + FINISHED = true; + return; + } + + gfxPushMatrix(); + + gfxSetAspect(0); + gfxScale(-1,1,1); + gfxTranslate(0,0,2.414); + gfxTranslate(0,0,dx); + + gfxRotate(180,0,1,0); + + + fric = Pow(0.75,td); + + + for (x=0;x<64;x=x+1) + { + c_vy[x] = c_vy[x] - (td*2); + c_x[x] = c_x[x] + (td*c_vx[x]); + c_y[x] = c_y[x] + (td*c_vy[x]); + c_z[x] = c_z[x] + (td*c_vz[x]); + c_vx[x] = c_vx[x]*fric; + c_vy[x] = c_vy[x]*fric; + c_vz[x] = c_vz[x]*fric; + + gfxPushMatrix(); + gfxTranslate(c_x[x],c_y[x],c_z[x]); + gfxRotate(c_rx[x]*tm,1,0,0); + gfxRotate(c_ry[x]*tm,0,1,0); + gfxScale(dx,dx,dx); + drawcube(x); + + gfxPopMatrix(); + + } + + gfxPopMatrix(); +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/DynamicCubeTunnel.vtx b/addons/visualization.vortex/resources/Presets/DynamicCubeTunnel.vtx new file mode 100644 index 0000000000..1f78e1c3e1 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/DynamicCubeTunnel.vtx @@ -0,0 +1,176 @@ +// DynamicCubeTunnel.vtx +// Author - MrC +// Based on DynamicCubeTunnel.r4 by Gordon Williams + +Texture env; +Texture skybox; +Map map; + + +int x,y; +float tm,tn,ofs,c; +float btime,ctime; +float[] v(32*24),o(32*24),va(32*24),oa(32*24); +float[] pv(4),po(4); +int sx,sy,i; +float wa,txa,txb,tya,tyb; + + +void Init() +{ + skybox.LoadTexture("skybox.dds"); + env.LoadTexture("huemap.jpg"); + map.SetTimed(); + reset(); +} + +void reset() +{ + tm = 0; + tn = 0; + btime = 0; + ctime = 0; + + for (sy=0;sy<24;sy=sy+1) + { + for (sx=0;sx<32;sx=sx+1) + { + v[sy*32 + sx] = Rand()+1.0; + o[sy*32 + sx] = Rand()*6.3; + va[sy*32 + sx] = (Rand()+1.0)*3.0; + oa[sy*32 + sx] = Rand()*6.3; + } + } + + + for (i=0;i<4;i=i+1) + { + pv[i] = Rand()+1.0; + po[i] = Rand()*6.3; + } + +} + +float tiltfunc(float p) +{ + return (Sin((ofs+p)*0.1)+Cos((ofs+p)*0.123))*10.0; +} + +void Render() +{ + + btime = btime + (TIMEPASS*(TREBLE+0.5)*2.0); + ctime = ctime + (TIMEPASS*(BASS+0.5)*0.5); + + for (sy=0;sy<24;sy=sy+1) + for (sx=0;sx<32;sx=sx+1) + { + float tu = ((sx-15.5)/16) + Sin(oa[sy * 32 + sx] + (va[sy * 32 + sx]*btime)); + float tv = ((sy-11.5)/12) + Sin(o[sy * 32 + sx] + (v[sy * 32 + sx]*btime)); + map.SetValues(sx, sy, tu, tv, -1.5, -1.5, -1.5); + } + + map.Render(); + + gfxPushMatrix(); + gfxSetAspect(0); + gfxTranslate(0,0,2.414); + + gfxSetTexture(env); + gfxSetBlendMode(BLEND_MOD); + + gfxSetRenderTarget(map); + + txa = (Sin(po[0]+(ctime*pv[0]))*2.0); + tya = (Sin(po[1]+(ctime*pv[1]))*2.0); + txb = (Sin(po[2]+(ctime*pv[2]))*2.0); + tyb = (Sin(po[3]+(ctime*pv[3]))*2.0); + + gfxBegin(PRIM_QUADLIST); + // bottom + gfxColour(1,1,1,0); + gfxTexCoord(txa,tya); + gfxVertex(-1,-0.9,0); + gfxTexCoord(txb,tyb); + gfxVertex(1,-0.9,0); + gfxColour(1,1,1,1); + gfxTexCoord(txb,tyb); + gfxVertex(1,-1.0,0); + gfxTexCoord(txa,tya); + gfxVertex(-1,-1.0,0); + + // top + gfxColour(1,1,1,0); + gfxTexCoord(txa,tya); + gfxVertex(-1,0.9,0); + gfxTexCoord(txb,tyb); + gfxVertex(1,0.9,0); + gfxColour(1,1,1,1); + gfxTexCoord(txb,tyb); + gfxVertex(1,1.0,0); + gfxTexCoord(txa,tya); + gfxVertex(-1,1.0,0); + + // left + gfxColour(1,1,1,0); + gfxTexCoord(txa,tya); + gfxVertex(-0.9,-1,0); + gfxTexCoord(txb,tyb); + gfxVertex(-0.9,1,0); + gfxColour(1,1,1,1); + gfxTexCoord(txb,tyb); + gfxVertex(-1,1,0); + gfxTexCoord(txa,tya); + gfxVertex(-1,-1,0); + + // right + gfxColour(1,1,1,0); + gfxTexCoord(txa,tya); + gfxVertex(0.9,-1,0); + gfxTexCoord(txb,tyb); + gfxVertex(0.9,1,0); + gfxColour(1,1,1,1); + gfxTexCoord(txb,tyb); + gfxVertex(1,1,0); + gfxTexCoord(txa,tya); + gfxVertex(1,-1,0); + gfxEnd(); + + gfxSetRenderTarget(0); + gfxSetTexture(map); + gfxPopMatrix(); + + + tm = tm + ((TREBLE+1.5)*TIMEPASS*8); + while (tm>1) + { + tm = tm-1; + ofs = ofs + 1; + } + + tn = tn + ((BASS+1.5)*TIMEPASS); + + gfxSetAspect(0); + gfxLookAt(Cos(tn*1.23)*3.5,Sin(tn)*3.5,(tm*2)-1,Cos(tn*0.6734)*2,Sin(tn*0.2143)*2,(tm*2)+8,0,1,0); + gfxRotate(-tiltfunc(0)*tm,0,0,1); + gfxSetTexture(skybox); + gfxPushMatrix(); + gfxTranslate(0,0,tm*2); + gfxRotate(tiltfunc(0)*tm,0,0,1); + gfxCube(-400,-400,-400,400,400,400); + gfxPopMatrix(); + gfxSetTexture(map); + + gfxSetBlendMode(BLEND_ADD); + + for (y=0;y<15;y=y+1) + { + c = 1.0 - ((y-tm)/15.0); + gfxColour(c,c,c,1); + gfxCube(-4,-4,(y*2)-0.75, 4,-4.5,(y*2)+0.75); + gfxCube(-4,4,(y*2)-0.75, 4,4.5,(y*2)+0.75); + gfxCube(-4,-4,(y*2)-0.75, -4.5,4,(y*2)+0.75); + gfxCube(4,-4,(y*2)-0.75, 4.5,4,(y*2)+0.75); + gfxRotate(tiltfunc(y),0,0,1); + } +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/FlipBoth.tra b/addons/visualization.vortex/resources/Presets/FlipBoth.tra new file mode 100644 index 0000000000..5e44bf848d --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/FlipBoth.tra @@ -0,0 +1,54 @@ +// FlipBoth.tra +// Author - MrC +// Based on FadeFlipBoth.r4 by Gordon Williams +float myTime = 0; +float d; + +void Init() +{ + +} + +void Rect(float x0, float y0, float x1, float y1) +{ + gfxBegin(PRIM_QUADLIST); + + gfxTexCoord(0,1); + gfxVertex(x0, y0, 0.0); + gfxTexCoord(1, 1); + gfxVertex(x1, y0, 0.0); + gfxTexCoord(1, 0); + gfxVertex(x1, y1, 0.0); + gfxTexCoord(0, 0); + gfxVertex(x0, y1, 0.0); + + gfxEnd(); + +} +void Render() +{ + myTime = myTime + (TIMEPASS/1.5); + + FINISHED = myTime>=1.0; + + gfxSetAspect(0); + gfxTranslate(0, 0, 2.414); + + d = 0.0-Cos(myTime*3.14159); + + gfxSetTexture(TEXTURE_CURRPRESET); + gfxSetBlendMode(BLEND_ADD); + gfxColour(1, 1, 1, 0.25); + + Rect(-1.0, -1.0, 0.0 - d, 1.0); + Rect(d, -1.0, 1.0, 1.0); + Rect(-1.0, -1.0, 1.0, 0 - d); + Rect(-1.0, d, 1.0, 1.0); + + gfxSetTexture(TEXTURE_NEXTPRESET); + Rect(0.0 - d, -1.0, 1.0, 1.0); + Rect(-1.0, -1.0, d, 1.0); + Rect(-1.0, 0.0 - d, 1.0, 1.0); + Rect(-1.0, -1.0, 1.0, d); + +} diff --git a/addons/visualization.vortex/resources/Presets/HamsterMatic.vtx b/addons/visualization.vortex/resources/Presets/HamsterMatic.vtx new file mode 100644 index 0000000000..7e8cd8d9ec --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/HamsterMatic.vtx @@ -0,0 +1,104 @@ +// HamsterMatic.vtx +// Author - MrC +// Based on HamsterMatic.r4 by Gordon Williams + +Texture tex; +float btime; +float[] rot(8); +float[] rots(8); +int x; +float dxx,dxy,dyx,dyy; +// colours +float ar,ag,ab,br,bg,bb; +float colamt,coltime; + +void Init() +{ + int id = Rand() * 3; + if (id == 0) + tex.LoadTexture("Alien.png"); + else if (id == 1) + tex.LoadTexture("Smiley.png"); + else + tex.LoadTexture("skull.png"); + + btime = 0; + for (x=0;x<8;x=x+1) + { + rot[x]=Rand(); + rots[x]=Rand()+1.0f; + } + colamt = 1; + br = 0.0; + bg = 0.0; + bb = 0.5; + coltime = 1+(Rand()*5); +} + +void quad(float rt, float sz) +{ + dxx = Cos(rt)*sz; + dxy = Sin(rt)*sz; + dyx = Sin(rt)*sz; + dyy = 0.0f-Cos(rt)*sz; + + gfxTexCoord((0.0f-dxx)+(0.0f+dyx),(0.0f-dxy)+(0.0f+dyy)); + gfxVertex(1.0,-1,0); + gfxTexCoord((0.0f+dxx)+(0.0f+dyx),(0.0f+dxy)+(0.0f+dyy)); + gfxVertex(-1.0,-1,0); + gfxTexCoord((0.0f+dxx)+(0.0f-dyx),(0.0f+dxy)+(0.0f-dyy)); + gfxVertex(-1.0,1,0); + gfxTexCoord((0.0f-dxx)+(0.0f-dyx),(0.0f-dxy)+(0.0f-dyy)); + gfxVertex(1.0,1,0); +} + +void Render() +{ + gfxSetBlendMode(BLEND_MOD); + + // keep moving + btime = btime + TIMEPASS; + while (btime>1) + { + btime = btime - 1; + for (x=6;x>=0;x=x-1) + { + rot[x+1]=rot[x]; + rots[x+1]=rots[x]; + } + rot[0] = 0; + rots[0] = Rand()+1.0f; + } + + coltime = coltime - TIMEPASS; + if (coltime<0) + { + coltime = 1+(Rand()*5); + ar = br; ag = bg; ab = bb; + colamt = 0; + x = (Rand()*6.0)+1.0; + br = x%2; + bg = ((x%4)-br)/2; + bb = ((x%8)-(bg*2)-br)/4; + br = br/2.0; + bg = bg/2.0; + bb = bb/2.0; + } + colamt = colamt + TIMEPASS; + if (colamt>1) colamt=1; + gfxClear( ((1.0f-colamt)*ar)+(colamt*br), ((1.0f-colamt)*ag)+(colamt*bg), ((1.0f-colamt)*ab)+(colamt*bb) ); + + // draw + gfxSetTexture(tex); + gfxSetAspect(0); + gfxTranslate(0.0f, 0.0f, 2.414f); + gfxBegin(PRIM_QUADLIST); + for (x=7;x>=0;x=x-1) + { + rot[x] = rot[x] + (TIMEPASS*rots[x]*(0.5+BASS)*1.5f); + gfxColour(1.0f, 1.0f, 1.0f, 0.0f-((x+btime)/8.0f)); + quad(rot[x],0.2f+((x+btime)/2.0)); + } + gfxEnd(); + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/MentalHangover.vtx b/addons/visualization.vortex/resources/Presets/MentalHangover.vtx new file mode 100644 index 0000000000..b7014e2d75 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/MentalHangover.vtx @@ -0,0 +1,143 @@ +// MentalHangover.vtx +// Author - MrC + +Texture checker; +Texture ball; +float ty; + +float d = 0; +float c; + +// colours +float ar,ag,ab,br,bg,bb; +float colamt,coltime; + +// balls +float[] c_z(64),c_vz(64),c_sx(64),c_sy(64), c_vy(64); + +void Init() +{ + checker.LoadTexture("checker_transp.png"); + ball.LoadTexture("smiley.png"); + + ty = 0; + coltime = 0; + + for (int x=0;x<64;x=x+1) + { + MakeNew(x); + c_z[x] = (Rand()*6) - 2; + c_vy[x] = Rand()*2 - 1; + } +} + +void MakeNew(int n) +{ + c_z[n] = 4; + c_vz[n] = Rand()* 1.0f + 1.0; + c_vy[n] = (Rand()*1.0 + 0.5); + c_sx[n] = (-0.5+Rand())*2.5; + c_sy[n] = 0.0f; +} + + +void Sprite(float x, float y, float z, float sz) +{ + gfxTexCoord(0,0); + gfxVertex(x-sz,y+sz,z); + gfxTexCoord(1,0); + gfxVertex(x+sz,y+sz,z); + gfxTexCoord(1,1); + gfxVertex(x+sz,y-sz,z); + gfxTexCoord(0,1); + gfxVertex(x-sz,y-sz,z); +} + +void Render() +{ + d = (TIMEPASS*6 + (TREBLE * 4 * TIMEPASS)) * 0.25; + + ty -= d; + + if (ty > 2) + ty -= 1.0f; + + if (ty < 2) + ty += 1.0f; + + // Floor + + coltime = coltime - TIMEPASS; + if (coltime<0) + { + coltime = 1+(Rand()*5); + ar = br; ag = bg; ab = bb; + colamt = 0; + float x = (Rand()*5.0)+1.0; + br = x%2; + bg = ((x%4)-br)/2; + bb = ((x%8)-(bg*2)-br)/4; + br = br/2.0; + bg = bg/2.0; + bb = bb/2.0; + } + colamt = colamt + TIMEPASS; + if (colamt>1) colamt=1; + + gfxRotate(-5.0,1,0,0); + + gfxSetTexture(NULL); + gfxTranslate(0, -0.245, 2.0f); + gfxSetBlendMode(BLEND_MOD); + + gfxBegin(PRIM_QUADLIST); + gfxColour( ((1.0f-colamt)*ag)+(colamt*bg), ((1.0f-colamt)*ab)+(colamt*bb), ((1.0f-colamt)*ar)+(colamt*br), 1 ); + gfxVertex(-5, 0, 2.5); + gfxVertex(5, 0, 2.5); + gfxVertex(5, 0, -2.5); + gfxVertex(-5, 0, -2.5); + gfxEnd(); + + gfxSetTexture(checker); + gfxSetBlendMode(BLEND_MOD); + + gfxBegin(PRIM_QUADLIST); + gfxColour(0, 0, 0, 0.4); + gfxColour( ((1.0f-colamt)*ar)+(colamt*br), ((1.0f-colamt)*ag)+(colamt*bg), ((1.0f-colamt)*ab)+(colamt*bb), 1 ); + gfxTexCoord(0, 0 + ty); + gfxVertex(-10, 0, 2.5); + gfxTexCoord(20, 0 + ty); + gfxVertex(10, 0, 2.5); + gfxTexCoord(20, 5 + ty); + gfxVertex(10, 0, -2.5); + gfxTexCoord(0, 5 + ty); + gfxVertex(-10, 0, -2.5); + gfxEnd(); + + gfxSetTexture(ball); + + gfxSetBlendMode(BLEND_MOD); + + gfxBegin(PRIM_QUADLIST); + for (int x=0;x<32;x++) + { + + c_z[x] = c_z[x] - (d*c_vz[x]); + c_vy[x] = c_vy[x] + 1 * TIMEPASS*2; + c_sy[x] = c_sy[x] - (c_vy[x] * d); + if (c_sy[x] < 0.025) + { + c_sy[x] = 0.025; + c_vy[x] = - (c_vy[x]* 0.9); + } + if (c_z[x]<-2) + MakeNew(x); + + c = (7.0-(c_z[x]+2))*0.11; + gfxColour(1,1,1,1); + Sprite(c_sx[x],c_sy[x],c_z[x], 0.0350); + } + + gfxEnd(); + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/MeteorShower.vtx b/addons/visualization.vortex/resources/Presets/MeteorShower.vtx new file mode 100644 index 0000000000..d636aaa809 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/MeteorShower.vtx @@ -0,0 +1,73 @@ +// MeteorShower.vtx +// Author - MrC +// Based on MeteorShower.r4 by Gordon Williams +Texture trail; +Texture sky; + +float[] pvel(256),ppos(256),ptheta(256),prad(256),plen(256),psnd(256); +int x; +float f,g,bt; +const int cnt = 256; +float time; + +void Init() +{ + sky.LoadTexture("skybox.dds"); + trail.LoadTexture("trail2.dds"); + + for (x=0;x<cnt;x=x+1) newpt(x); + bt = 0; + time = 0; +} + +void drawit(float ax,float ay,float bx, float by,float r) +{ + gfxTexCoord(0,0); + gfxVertex(r*Cos(ax),r*Sin(ax),ay); + gfxTexCoord(0,1); + gfxVertex(r*Cos(bx),r*Sin(bx),ay); + gfxTexCoord(1,1); + gfxVertex(r*Cos(bx),r*Sin(bx),by); + gfxTexCoord(1,0); + gfxVertex(r*Cos(ax),r*Sin(ax),by); +} + +void newpt(int p) +{ + pvel[p] = (Rand()+0.5)*2.0; + ppos[p] = 0.0; + ptheta[p] = Rand()*3.14159*2.0; + prad[p] = (Rand()*2.0)+0.25; + plen[p] = 1.5+Rand(); + psnd[p] = Rand(); +} + +void Render() +{ + gfxClear(0.1, 0, 0); + + bt = bt + (TIMEPASS*(0.5+BASS)); + time += TIMEPASS; + gfxSetBlendMode(BLEND_ADD); + + f = Sin(bt+Sin(time*1.353)); + g=f; + gfxTranslate(0,0,3); + gfxRotate(90*(g+1.0),Sin(time*0.4),Cos(time*0.4),0); + gfxSetTexture(sky); + + gfxCube(-20,-20,-20,20,20,20); + gfxSetTexture(trail); + gfxTranslate((Sin(bt*1.61))*0.3,(Sin(bt*1.23))*0.3,-8+(g*5.0)); + gfxBegin(PRIM_QUADLIST); + for (x=0;x<cnt;x=x+1) + { + ppos[x] = ppos[x] + (pvel[x]*TIMEPASS*(0.5+(psnd[x]*BASS)+((1.0-psnd[x])*TREBLE))); + if (ppos[x]<0) ppos[x] = 0; + if (ppos[x]>1.0) newpt(x); + gfxColour(1,1,1,(1.0-Cos(ppos[x]*3.14159*2.0))*0.5); + drawit(ptheta[x],(ppos[x]*16.0)+plen[x],ptheta[x]+0.08+(prad[x]*0.025),(ppos[x]*16.0),prad[x]); + } + gfxEnd(); + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/MiddleGrid.tra b/addons/visualization.vortex/resources/Presets/MiddleGrid.tra new file mode 100644 index 0000000000..dfff79e903 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/MiddleGrid.tra @@ -0,0 +1,67 @@ +// MiddleGrid.tra +// Author - MrC +// Based on FadeMiddleGrid.r4 By Gordon Williams + +int x,y,mx,my,hx,hy; +float dx,dy,sx,sy,a,b,mytime; + +void Init() +{ + +} + +void Render() +{ + mytime = mytime + (TIMEPASS*0.40); + + + gfxSetAspect(0); + gfxTranslate(-1, -1, 2.414); + gfxSetTexture(TEXTURE_NEXTPRESET); + gfxColour(1, 1, 1, 1); + gfxTexRect(0, 2, 2, 0); + + mx = 16; + my = 12; + hx = 8; + hy = 6; + + gfxScale(2.0/mx,2.0/my,1.0); + sx = 1.0/mx; + sy = 1.0/my; + + gfxSetTexture(TEXTURE_CURRPRESET); + gfxColour(1, 1, 1, 1); + + gfxBegin(PRIM_QUADLIST); + + FINISHED = true; + + dx = 0; + for (x=0;x<mx;x=x+1) + { + dy = 0; + for (y=0;y<my;y=y+1) + { + a = (mytime*10.0)-((Abs(x-hx)+Abs(y-hy))*0.25); + if (a<0) a=0; + if (a<3.14159) + { + a = (Cos(a)*0.25)+0.25; + gfxTexCoord(dx,1.0f - dy); + gfxVertex(x+0.5-a,y+0.5-a,0.0); + gfxTexCoord(dx+sx,1.0f-dy); + gfxVertex(x+0.5+a,y+0.5-a,0.0); + gfxTexCoord(dx+sx,1.0f-(dy+sy)); + gfxVertex(x+0.5+a,y+0.5+a,0.0); + gfxTexCoord(dx,1.0f - (dy+sy)); + gfxVertex(x+0.5-a,y+0.5+a,0.0); + FINISHED = false; + } + dy = dy + sy; + } + dx = dx + sx; + } + gfxEnd(); + +} diff --git a/addons/visualization.vortex/resources/Presets/SingingSkull.vtx b/addons/visualization.vortex/resources/Presets/SingingSkull.vtx new file mode 100644 index 0000000000..c7cac906f0 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/SingingSkull.vtx @@ -0,0 +1,72 @@ +// AlbumArtZoomer.vtx +// Author - MrC + +Texture skull1; +Texture skull2; +Texture skull3; +Texture skull4; +Texture skull5; +Texture skull6; +Texture skull7; +Texture skull0; + +float bt,bump,n; + +void Init() +{ + skull0.LoadTexture("skull_jawud1.png"); + skull1.LoadTexture("skull_jawud2.png"); + skull2.LoadTexture("skull_jawud3.png"); + skull3.LoadTexture("skull_jawud4.png"); + skull4.LoadTexture("skull_jawud5.png"); + skull5.LoadTexture("skull_jawud6.png"); + skull6.LoadTexture("skull_jawud7.png"); + skull7.LoadTexture("skull_jawud8.png"); + bt = 0; +} + +float time = 0; + +void Render() +{ + time += TIMEPASS*10; + bt = bt + (TIMEPASS*(0.5+BASS)); + n = 1.0-(TIMEPASS*4); + bump = (bump*n)+(BASS*(1.0-n)); + + int tex = 0; + if (MIDDLE > 0) + tex = MIDDLE * 10; + if (tex == 0) + gfxSetTexture(skull0); + else if (tex == 1) + gfxSetTexture(skull1); + else if (tex == 2) + gfxSetTexture(skull2); + else if (tex == 3) + gfxSetTexture(skull3); + else if (tex == 4) + gfxSetTexture(skull4); + else if (tex == 5) + gfxSetTexture(skull5); + else if (tex == 6) + gfxSetTexture(skull6); + else if (tex >= 7) + gfxSetTexture(skull7); +// gfxSetAspect(0); + gfxSetBlendMode(BLEND_MOD); + gfxTranslate(0,0,2.5); + + float x = (Sin(bt*6.43)+Cos(bt*4.23))*0.25; + float y = (Cos(bt*6.43)+Sin(bt*4.23))*0.25; + + + gfxTexRect(x - 0.5, y + 0.5, x + 0.5, y -0.5); + + float col = 0; + if (BASS > 0) + col = BASS; + + col = Fabs(Sin(time)); + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/Slide.tra b/addons/visualization.vortex/resources/Presets/Slide.tra new file mode 100644 index 0000000000..e73e20944e --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/Slide.tra @@ -0,0 +1,52 @@ +// Slide.tra +// Author - MrC + +int direction; +float position; + +void Init() +{ + position = 0; + direction = Rand() * 4; +} + +void Render() +{ + position += TIMEPASS*0.75; + if (position >= 1.0f) + FINISHED = true; + + gfxSetTexture(TEXTURE_CURRPRESET); + gfxSetAspect(0); + gfxTranslate(0, 0, 2.414); + gfxColour(1, 1, 1, 1); + gfxTexRect(-1, 1, 1, -1); + + gfxSetTexture(TEXTURE_NEXTPRESET); + + if (direction == 0) + { + // Top to bottom + float i = -3 + position * 2; + gfxTexRect(-1, i+2, 1, i); + } + else if (direction == 1) + { + // Bottom to top + float i = 1 - (position * 2); + gfxTexRect(-1, i+2, 1, i); + } + else if (direction == 2) + { + // Left to right + float i = -3 + position * 2; + gfxTexRect(i, 1, i+2, -1); + } + else + { + // Right to left + float i = 1 - position * 2; + gfxTexRect(i, 1, i+2, -1); + } + +} diff --git a/addons/visualization.vortex/resources/Presets/SpaceHarrier.vtx b/addons/visualization.vortex/resources/Presets/SpaceHarrier.vtx new file mode 100644 index 0000000000..60ffd09dd6 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/SpaceHarrier.vtx @@ -0,0 +1,91 @@ +/* + +SCENE ( +"name" = "Space Harrier 2"; +"author" = "Gordon Williams"; +SOLID bg(); +TEXTURE texa(); +TEXTURE texb(); +GL gl(bg,texa,texb); +) +*/ +Texture checker; + +int x; +float bt,bump,n; +float time; + +//- --------------------------- +void drawit(float ox,float oy) +{ + gfxColour(1, 1, 1, 1); + gfxTexCoord(0+ox,0+oy); + gfxVertex(-10,0,-5); + gfxTexCoord(20+ox,0+oy); + gfxVertex(10,0,-5); + + gfxColour(0, 0, 0, 0); + gfxTexCoord(20+ox,10+oy); + gfxVertex(10,0,5); + gfxTexCoord(0+ox,10+oy); + gfxVertex(-10,0,5); +} +//- --------------------------- + +void Init() +{ + checker.LoadTexture("checker.png"); + bt = 0; +// bg.col = rgb(0,0,0); +// strcpy(texa.filename,"dots.png"); +// strcpy(texb.filename,"grid.png"); +// strcpy(gl.shader,"T0;BAa;"); +} + +void Render() +{ + time += TIMEPASS; + bt = bt + (TIMEPASS*(0.5+BASS)); + n = 1.0-(TIMEPASS*4); + bump = (bump*n)+(BASS*(1.0-n)); + +// gl.clear(); + + gfxRotate(bump*40.0,1,0,0); + gfxRotate((Sin(bt*6.43)+Cos(bt*4.23))*15,0,1,0); + + gfxRotate((Sin(bt*2)+Cos(bt*4.23))*30,0,0,1); + + gfxSetTexture(checker); + gfxTranslate(0,0.3,5); + gfxColour(1,1,1,1); + gfxBegin(PRIM_QUADLIST); + drawit(0,bt); + gfxEnd(); + +// gl.glbindtexture(2); + gfxTranslate(0,-0.6,0); +// gl.glcolor(1,1,1,1); + gfxBegin(PRIM_QUADLIST); + drawit(0,bt+time); + gfxEnd(); + + gfxSetTexture(NULL); + gfxTranslate(0, 0.3, -2 ); + gfxScale(5,0.35,1); + gfxColour(1,1,1,1); + gfxSetLineWidth(2); + gfxBegin(PRIM_LINESTRIP); + + gfxColour(1, 1, 0, 1); + for (x=0;x<256;x=x+1) + gfxVertex((x-128.0)/128.0,WaveLeft(x),0); + gfxEnd(); + + gfxColour(0, 1, 1, 1); + gfxBegin(PRIM_LINESTRIP); + for (x=0;x<256;x=x+1) + gfxVertex((x-128.0)/128.0,WaveRight(x),0); + gfxEnd(); + +} diff --git a/addons/visualization.vortex/resources/Presets/Speakers.vtx b/addons/visualization.vortex/resources/Presets/Speakers.vtx new file mode 100644 index 0000000000..e7e4af1957 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/Speakers.vtx @@ -0,0 +1,95 @@ +// Speakers.vtx +// Author - MrC + +float[] x(15), y(15), vx(15), vy(15); + +Texture speaker; + +void Init() +{ + speaker.LoadTexture("speaker.png"); + + for (int i = 0; i < 15; i++) + { + x[i] = (Rand()-0.5) * 2; + y[i] = (Rand()-0.5) * 2; + vx[i] = (Rand()-0.5) * 0.05; + vy[i] = (Rand()-0.5) * 0.05; + } +} + +void quad(float x, float y, float sz) +{ + gfxTexCoord(0,0); + gfxVertex(x-sz,y+sz,0); + gfxTexCoord(1,0); + gfxVertex(x+sz,y+sz,0); + gfxTexCoord(1,1); + gfxVertex(x+sz,y-sz,0); + gfxTexCoord(0,1); + gfxVertex(x-sz,y-sz,0); +} + +float time = 0; + +void Render() +{ + time += TIMEPASS * 30; + + for (int i = 0; i < 15; i++) + { + float value; + if (i < 5) + value = BASS; + else if (i < 10) + value = MIDDLE; + else + value = TREBLE; + + + x[i] = x[i] + vx[i] * value; + if (x[i] < -1) + { + x[i] = -1; + vx[i] = -vx[i]; + } + else if (x[i] > 1) + { + x[i] = 1; + vx[i] = -vx[i]; + } + y[i] = y[i] + vy[i] * value; + if (y[i] < -1) + { + y[i] = -1; + vy[i] = -vy[i]; + } + else if (y[i] > 1) + { + y[i] = 1; + vy[i] = -vy[i]; + } + } + + + gfxSetTexture(speaker); + gfxSetAspect(1); + gfxTranslate(0, 0, 2.0); + gfxBegin(PRIM_QUADLIST); + gfxColour(1.0f, 1.0f, 1.0f, 1); + gfxSetBlendMode(BLEND_MOD); + for (int i=0; i < 5; i++) + { + quad(x[i], y[i], 0.1 + (1+BASS)*0.2); + } + for (int i=5; i < 10; i++) + { + quad(x[i], y[i], 0.1 + (1+MIDDLE)*0.2); + } + for (int i=10; i < 15; i++) + { + quad(x[i], y[i], 0.1 + (1+TREBLE)*0.2); + } + gfxEnd(); + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/SpectrumCylinder.vtx b/addons/visualization.vortex/resources/Presets/SpectrumCylinder.vtx new file mode 100644 index 0000000000..3d588754f8 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/SpectrumCylinder.vtx @@ -0,0 +1,91 @@ +// SpectrumCylinder.vtx +// Author - MrC +// Based on SpectrumCylinder.r4 by Gordon Williams + +float time = 0; + +float tm; +int x,y; + +float rx,rxamt,ry,ryamt; +int currBuffer; + +float[] buffers(12*12); + +float[] savr(12); +int[] sn(12); +float[] sp(12); + + +Map map; +Texture envTexture; + +void Init() +{ + envTexture.LoadTexture("env3.png"); + currBuffer = 0; + + for (y=0;y<24;y=y+1) + { + for (x=0;x<32;x=x+1) + { + map.SetValues(x, y, Sin((x-15.5)*3)*0.01, Sin((y-11.5)*3)*0.01, 1, 1, 1); + } + } + rxamt = 1; + ryamt = -1; +} + +void Render() +{ + time += TIMEPASS; + + map.Render(); + + gfxSetRenderTarget(map); + + gfxPushMatrix(); + + gfxTranslate(0,0,17.5f); + gfxRotate(-70+(Sin(time)*12),1,0,0); + + if (BASS>0.3) rxamt = 1; + if (BASS<-0.3) rxamt = -1; + if (TREBLE>0.3) ryamt = 1; + if (TREBLE<-0.3) ryamt = -1; + rx = rx + (rxamt*TIMEPASS); + ry = ry + (ryamt*TIMEPASS); + + gfxRotate(rx*90,0,0,1); + gfxRotate(ry*90,0,1,0); + + + for (x = 0; x < 12; x++) + { + sp[x] = GetSpec(x*2); + } + gfxSetEnvTexture(envTexture); + + // draw buffer out of cubes + for (y=0;y<12;y=y+1) + { + for (x=0;x<12;x=x+1) + { + gfxColour(x/12.0,y/12.0,1.0-(y/12.0),1.0); // fade colour + gfxCube(-5.5+x,-0.25f,1.0,-5.5+x+0.5f,0.25f,1.0+(sp[x]*1.5)); + } + gfxRotate(360.0/12.0,1,0,0); + } + + gfxPopMatrix(); + + gfxSetRenderTarget(0); + gfxSetEnvTexture(NULL); + gfxSetTexture(map); + + gfxSetAspect(0); + gfxTranslate(0, 0, 2.414); + gfxColour(1, 1, 1, 1); + gfxTexRect(-1, 1, 1, -1); + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/SpectrumField.vtx b/addons/visualization.vortex/resources/Presets/SpectrumField.vtx new file mode 100644 index 0000000000..9b421b4ae8 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/SpectrumField.vtx @@ -0,0 +1,73 @@ +// SpectrumFile.vtx +// Author - MrC + +const int STEP = 5; +float time = 0; + +float tm; +int x,y; + +float rx,ry,ryamt; +int currBuffer; + +float[] buffers(24*32); +int counter = 0; + +void Init() +{ + currBuffer = 0; + counter = 0; + for (int i=0; i<24*32; i++) + { + buffers[i]=0; + } + + ryamt = -25.0f; + ry = Rand() * 360.0f; + +} + +void Render() +{ + + time += TIMEPASS; + + gfxTranslate(0,-2,30.0f); + counter++; + + ryamt = (BASS) * 40; + + ry = ry + (ryamt*TIMEPASS); + + + gfxRotate(-20,1,0,0); + gfxRotate(ry,0,1,0); + + gfxSetBlendMode(BLEND_ADD); + + if (counter == 5) + { + currBuffer = (currBuffer+1) % 24; + for (int i=0; i<32; i++) + { + buffers[currBuffer*32 + i] = GetSpec(i) * 4; + } + counter = 0; + } + + gfxColour(1, 1, 1, 1); + gfxSetLineWidth(5); + + for (int i=0; i<24;i++) + { + int index = (i+currBuffer+1) % 24; + + gfxBegin(PRIM_LINESTRIP); + for (int x=0; x<32; x++) + { + gfxColour(i/24.0,x/32.0,1.0-(x/32.0),1.0); // fade colour + gfxVertex(-12+i-(counter/5.0f), buffers[index*32 + x], -16+x); + } + gfxEnd(); + } +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/SpectrumSphere.vtx b/addons/visualization.vortex/resources/Presets/SpectrumSphere.vtx new file mode 100644 index 0000000000..8ff226c786 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/SpectrumSphere.vtx @@ -0,0 +1,186 @@ +// SpectrumSphere.vtx +// Author - morte0815 + +float time = 0; +float rx,rxamt,ry,ryamt; + +float[] org_coordsX(70); +float[] org_coordsY(70); +float[] org_coordsZ(70); +float[] org_colorR(70); +float[] org_colorG(70); +float[] org_colorB(70); + +float stacks = 8; +float segments = 8; + +float velX,velY,velZ; +float posX,posY,posZ; +float signX,signY,signZ; +Map map; + +int x,y; + +void Init() +{ + velX= 0; + velY= 0; + velZ = 0; + posX= 0; + posY= 0; + posZ = 0; + posX= 0; + posY= 0; + posZ = 0; + signX= 1; + signY= 1; + signZ = 1; + + if(BASS < 0.2f){signZ = 1;} + if(MIDDLE < 0.2f){signY = -1;} + if(TREBLE < 0.2f){signX = -1;} + + for (int i = 0; i< stacks; i++) + { + float temp = Cos(3.14159f/6.0f*i-3.14159f/2.0f); + for (int j = 0; j < segments; j++) + { + org_coordsY[Fabs(i*segments+j)] = Sin(3.14159f/6.0f*i-3.14159f/2.0f); + org_coordsX[Fabs(i*segments+j)] = Cos(2*3.14159f/segments*j) * temp; + org_coordsZ[Fabs(i*segments+j)] = Sin(2*3.14159f/segments*j) * temp; + } + } + for (int i = 0; i< stacks; i++) + { + for (int j = 0; j< segments; j++) + { + org_colorR[i*segments+j] = Sin(i); + org_colorG[i*segments+j] = Sin(j); + org_colorB[i*segments+j] = 1-Sin(j); + } + } + + + + + +} + +void RenderSphere() +{ + float addX=0; + float addY=0; + float addZ=0; + float scale = 0.5f; + float colorVal = 0; + gfxBegin(PRIM_TRIANGLELIST); + for (int i = 0; i< stacks-2; i++) + { + for (int j = 0; j< segments; j++) + { + float temp = i*segments+j; + addX = GetSpec(Fabs(temp/2)) * org_coordsX[temp]*scale; + addY = GetSpec(Fabs(temp/2)) * org_coordsY[temp]*scale; + addZ = GetSpec(Fabs(temp/2)) * org_coordsZ[temp]*scale; + colorVal = GetSpec(Fabs(temp/2)); + + + gfxColour(org_colorR[temp],org_colorG[temp] ,org_colorB[temp] ,1); + gfxVertex(org_coordsX[temp] + addX,org_coordsY[temp] + addY,org_coordsZ[temp] + addZ); + + temp = (i+1)*segments+((j+1)%segments); + gfxVertex(org_coordsX[temp] + addX,org_coordsY[temp] + addY,org_coordsZ[temp] + addZ); + + temp = i*segments+((j+1)%segments); + gfxVertex(org_coordsX[temp] + addX,org_coordsY[temp] + addY,org_coordsZ[temp] + addZ); + + temp = i*segments+j; + addX = GetSpec(Fabs(temp/2)) * org_coordsX[temp]*scale; + addY = GetSpec(Fabs(temp/2)) * org_coordsY[temp]*scale; + addZ = GetSpec(Fabs(temp/2)) * org_coordsZ[temp]*scale; + colorVal = GetSpec(Fabs(temp/2)); + + gfxColour(org_colorR[temp],org_colorG[temp],org_colorB[temp],1); + gfxVertex(org_coordsX[temp] + addX,org_coordsY[temp] + addY,org_coordsZ[temp] + addZ); + + temp = (i+1)*segments+j; + gfxVertex(org_coordsX[temp] + addX,org_coordsY[temp] + addY,org_coordsZ[temp] + addZ); + + temp = (i+1)*segments+((j+1)%segments); + gfxVertex(org_coordsX[temp] + addX,org_coordsY[temp] + addY,org_coordsZ[temp] + addZ); + } + } + gfxEnd(); +} + +void PushAround() +{ + if (Abs(BASS) > 0.3f){velZ += BASS*3.0f;} + if (Abs(BASS) < 0.3f){velZ -= BASS*3.0f;} + if (Abs(MIDDLE) > 0.3f){velY += MIDDLE*3.0f;} + if (Abs(MIDDLE) < 0.3f){velY -= MIDDLE*3.0f;} + if (Abs(TREBLE) > 0.3f){velX += TREBLE*3.0f;} + if (Abs(TREBLE) < 0.3f){velX -= TREBLE*3.0f;} + + velX = Clamp(velX,-3.0f,3.0f); + velY = Clamp(velY,-3.0f,3.0f); + velZ = Clamp(velZ,-3.0f,3.0f); + + posX += signX*velX*TIMEPASS; + posY += signY*velY*TIMEPASS; + posZ += signZ*velZ*TIMEPASS; + + if (posX < -4 || posX > 4){signX = -signX;} + if (posY < -4 || posY > 4){signY = -signY;} + if (posZ < -4 || posZ > 4){signZ = -signZ;} + + gfxTranslate(posX,posY,posZ); + +} + +void Render() +{ + time += TIMEPASS; + for (y=0;y<24;y=y+1) + { + for (x=0;x<32;x=x+1) + { + float dx = (x-16); + float dy = (y-12); + float s = Mag(dx,dy)/Mag(16,12); + if (s == 0) + { + map.SetValues(x, y, 0.1, 0.1, 0.8,0.8, 0.8); + } + map.SetValues(x, y, dx*s*0.1*Fabs(BASS), dy*s*0.1*Fabs(BASS), 0.8,0.8, 0.8); + } + + } + map.Render(); + + gfxSetRenderTarget(map); + gfxPushMatrix(); + gfxTranslate(0,0,15); + + PushAround(); + + if (BASS>0.3) ryamt = 1; + if (BASS<-0.3) ryamt = -1; + ry = ry + (ryamt*TIMEPASS); + + gfxRotate(ry*90,0,1,0); + + + RenderSphere(); + + gfxPopMatrix(); + + gfxSetRenderTarget(0); + gfxSetEnvTexture(NULL); + gfxSetTexture(map); + + gfxSetAspect(0); + gfxTranslate(0, 0, 2.414); + gfxColour(1, 1, 1, 1); + gfxTexRect(-1, 1, 1, -1); +} diff --git a/addons/visualization.vortex/resources/Presets/Sphere.tra b/addons/visualization.vortex/resources/Presets/Sphere.tra new file mode 100644 index 0000000000..ef0df6489d --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/Sphere.tra @@ -0,0 +1,65 @@ +// Sphere.tra +// Author - MrC +// Based on FadeSphere.r4 by Gordon Williams + +const int stripx = 32; +const int stripy = 16; + +int x,y; +float dx,da,db,sa,sb,a,b,mytime; + +void Init() +{ +} + +void Render() +{ + mytime = mytime + (TIMEPASS * 0.25); + FINISHED = (mytime>1); + + gfxSetTexture(TEXTURE_NEXTPRESET); + gfxSetAspect(0); + gfxTranslate(0,0,2.414); + gfxColour(1, 1, 1, 1); + gfxTexRect(-1, 1, 1, -1); + gfxTranslate(0,0,-2.414); + + a = mytime*2; + if (a>1.0) a=1.0; + a = (1.0-Cos(a*3.14159))/2.0; + + gfxSetAspect(a); + + b = (mytime*2)-1.0; + if (b<0.0) b=0.0; + b = (1.0-Cos(b*3.14159))/2.0; + + gfxTranslate(b*6,0,2.414+(a*1.5)); + + gfxRotate(mytime*720,1,1,1); + + gfxSetTexture(TEXTURE_CURRPRESET); + + gfxColour(1,1,1,1); + for (y=0;y<stripy;y=y+1) + { + da = (1.0*y)/stripy; + db = (1.0*(y+1))/stripy; + sa = Sin(da*3.14159); + sb = Sin(db*3.14159); + da = -Cos(da*3.14159); + db = -Cos(db*3.14159); + gfxBegin(PRIM_QUADSTRIP); + for (x=0;x<=stripx;x=x+1) + { + dx = (1.0*x)/stripx; + gfxTexCoord(dx,(da*-0.5)+0.5); + gfxVertex(((dx*2.0)-1.0)*(1.0-a)+(Cos(3.14159*2.0*dx)*a*sa),da,(Sin(3.14159*2.0*dx)*a*sa)); + gfxTexCoord(dx,(db*-0.5)+0.5); + gfxVertex(((dx*2.0)-1.0)*(1.0-a)+(Cos(3.14159*2.0*dx)*a*sb),db,(Sin(3.14159*2.0*dx)*a*sb)); + } + gfxEnd(); + } + +} + diff --git a/addons/visualization.vortex/resources/Presets/Square.tra b/addons/visualization.vortex/resources/Presets/Square.tra new file mode 100644 index 0000000000..e44ed91665 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/Square.tra @@ -0,0 +1,66 @@ +// Square.tra +// Author - MrC +// Based on FadeGrid.r4 by Gordon Williams + +int x,y,mx,my; +float dx,dy,sx,sy,a,b,mytime; + +void Init() +{ + +} + +void Render() +{ + mytime = mytime + (TIMEPASS*0.40); + + gfxSetTexture(TEXTURE_NEXTPRESET); + gfxSetAspect(0); + gfxTranslate(0, 0, 2.414); + gfxColour(1, 1, 1, 1); + gfxTexRect(-1, 1, 1, -1); + + gfxSetAspect(0); + gfxTranslate(-1, -1, 0); + + mx = 16; + my = 12; + + gfxScale(2.0/mx,2.0/my,1.0); + sx = 1.0/mx; + sy = 1.0/my; + + gfxSetTexture(TEXTURE_CURRPRESET); + gfxColour(1, 1, 1, 1); + + gfxBegin(PRIM_QUADLIST); + + FINISHED = true; + + dx = 0; + for (x=0;x<mx;x=x+1) + { + dy = 0; + for (y=0;y<my;y=y+1) + { + a = (mytime*10.0)-((my+1.0+x-y)*0.25); + if (a<0) a=0; + if (a<3.14159) + { + a = (Cos(a)*0.25)+0.25; + gfxTexCoord(dx,1.0f - dy); + gfxVertex(x+0.5-a,y+0.5-a,0.0); + gfxTexCoord(dx+sx,1.0f-dy); + gfxVertex(x+0.5+a,y+0.5-a,0.0); + gfxTexCoord(dx+sx,1.0f-(dy+sy)); + gfxVertex(x+0.5+a,y+0.5+a,0.0); + gfxTexCoord(dx,1.0f - (dy+sy)); + gfxVertex(x+0.5-a,y+0.5+a,0.0); + FINISHED = false; + } + dy = dy + sy; + } + dx = dx + sx; + } + gfxEnd(); +} diff --git a/addons/visualization.vortex/resources/Presets/StereoSpectrum.vtx b/addons/visualization.vortex/resources/Presets/StereoSpectrum.vtx new file mode 100644 index 0000000000..4f2483010c --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/StereoSpectrum.vtx @@ -0,0 +1,128 @@ +// Author : paridox + +const int BUFFERS = 24; +const int WIDTH = 128; + +int currBuffer; +int rowRenderCount = 0; + +float[] buffers(256 * BUFFERS); +float[] bounces(BUFFERS); +float[] yaws(BUFFERS); + +int counter = 0; + +float m_prevValue = 0.0; + +void Init() +{ + currBuffer = 0; + + for (int clear = 0; clear < 256 * BUFFERS; clear++) + { + buffers[clear] = 0.0; + } +} + +void doRender(int bufferToUse, float Zpos) +{ + gfxPushMatrix(); + gfxTranslate(0.0f, bounces[bufferToUse], 0.0f); + + //gfxPushMatrix(); + gfxRotate(yaws[currBuffer], 0, 0, 1); + + for (int x = 0; x < WIDTH; x++) + { + float value = 0.0; + + // get the current value + for (int calcAverage = 0; calcAverage < (256 / WIDTH); calcAverage++) + { + //if (x == (WIDTH / 2)) + //{ + //gfxPopMatrix(); + //gfxPushMatrix(); + //gfxRotate(-yaws[currBuffer], 0, 0, 1); + //} + + int index = (bufferToUse * 256) + (x*(256/WIDTH)) + calcAverage; + if (index >= 0 && index < 256*BUFFERS) + value = value + buffers[index]; + } +// value = value / (256.0f / WIDTH); + value = value * 2.0; + + float prevValue = value; + + // get previous value + if (x != 0 && x != (WIDTH / 2)) prevValue = m_prevValue; + + // remember for next time + m_prevValue = value; + + value = (value + prevValue) / 2.0f; + + if (rowRenderCount == BUFFERS) + gfxColour((x >= (WIDTH / 2) ? 1.0 - (x-(WIDTH/2.0f)) / (WIDTH * 2.0f / 3.0f) : 0.0), (x < (WIDTH / 2) ? 1.0 - (WIDTH/2-x) / (WIDTH * 2.0f / 3.0f) : 0.0), 0.0, 0.2); // front bright colour + else + gfxColour((x >= (WIDTH / 2) ? (0.8f - (x-(WIDTH/2.0f)) / (WIDTH * 2.0f / 3.0f)) / (Zpos+1) : 0.0), (x < (WIDTH / 2) ? (0.8f - (WIDTH/2-x) / (WIDTH * 2.0f / 3.0f)) / (Zpos+1) : 0.0), 0.0, 1.0); // fade colour + if (x == 0 || x == WIDTH / 2) + gfxBegin(PRIM_QUADSTRIP); + + gfxVertex(-(WIDTH / 16.0f)+(x/8.0f)+(x < WIDTH / 2 ? 0.2f : 0.0) + (x < (WIDTH / 2) ? 0.0 : 0.0), value, Zpos + 0.3f); + gfxVertex(-(WIDTH / 16.0f)+(x/8.0f)+(x < WIDTH / 2 ? 0.0f : 0.2f) + (x < (WIDTH / 2) ? 0.0 : 0.0), value, Zpos); + + if (x == WIDTH / 2 - 1 || x == WIDTH - 1) + gfxEnd(); + } + + //gfxPopMatrix(); + + gfxPopMatrix(); +} + +void Render() +{ + yaws[currBuffer] = Fabs(Sin(BASS) * 6); + counter++; + + gfxTranslate(0.0, 0.0, 12.0f); + bounces[currBuffer] = -1.6 + Fabs((BASS + TREBLE) / 2.0f); + + { + for (int i = 0; i < 256; i++) + { + int index = i + (currBuffer * 256); + int prevIndex = (index + 256) % (BUFFERS * 256); + int prevIndex2 = (index + 512) % (BUFFERS * 256); + float value = 0.0f; + + if (i < 128) + { + buffers[index] = (GetSpecLeft(i * 4 + 0) + GetSpecLeft(i * 4 + 1) + GetSpecLeft(i * 4 + 2) + GetSpecLeft(i * 4 + 3)) / 4.0f; + } + else + { + buffers[index] = (GetSpecRight((256 - i) * 4 + 0) + GetSpecRight((256 - i) * 4 + 1) + GetSpecRight((256 - i) * 4 + 2) + GetSpecRight((256 - i) * 4 + 3)) / 4.0f; + } + } + + currBuffer = (currBuffer + 1) % BUFFERS; + counter = 0; + } + + rowRenderCount = 0; + int rendPos = BUFFERS; +//doRender(currBuffer-1, 0 * 0.25f); + for (int rend=currBuffer; rend<BUFFERS; rend++) + { + rowRenderCount++; + doRender(rend, rendPos-- * 0.25f); + } + for (int rend=0; rend < currBuffer; rend++) + { + rowRenderCount++; + doRender(rend, rendPos-- * 0.25f); + } +} diff --git a/addons/visualization.vortex/resources/Presets/VoicePrintDonut.vtx b/addons/visualization.vortex/resources/Presets/VoicePrintDonut.vtx new file mode 100644 index 0000000000..d144c85c05 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/VoicePrintDonut.vtx @@ -0,0 +1,74 @@ +// VoicePrintDonut.vtx +// Author - MrC +// Based on VoicePrint.r4 by Gordon Williams + +VoicePrint vp; +Map map; +float time = 0; +float minX; + +float rx,rxamt,ry,ryamt; + +void Init() +{ + vp.LoadColourMap("huemap.jpg"); + vp.SetSpeed(0.5); + + for (int y=0;y<24;y=y+1) + { + for (int x=0;x<32;x=x+1) + { + float dx = (x-16)/16.0; + float dy = (y-12)/12.0; + float s = (Mag(dx,dy))-1.5; + map.SetValues(x, y, dx*s, dy*s, 1, 1, 1); + } + } + +} + +void Render() +{ + gfxPushMatrix(); + minX = 0.75f - BASS; + if (minX<0.5f) minX=0.5f; + if (minX>0.99f) minX=0.99f; + + vp.SetRect(minX, 0, 0.5, 0.99); + + vp.Render(); + + gfxSetRenderTarget(map); + gfxSetTexture(vp); + gfxSetAspect(0); + gfxTranslate(0, 0, 2.414); + gfxTexRect(-1, 1, 1, -1); + + map.Render(); + gfxSetRenderTarget(0); + gfxSetTexture(map); + gfxTexRect(-1, 1, 1, -1); + + gfxPopMatrix(); + + time += TIMEPASS; + + gfxSetTexture(vp); + gfxTranslate(0, 0, 2.0f-(BASS* 0.5f)); + + if (BASS>0.3) rxamt = 1; + if (BASS<-0.3) rxamt = -1; + if (TREBLE>0.3) ryamt = 1; + if (TREBLE<-0.3) ryamt = -1; + rx = rx + (rxamt*TIMEPASS); + ry = ry + (ryamt*TIMEPASS); + + gfxRotate(-70+(Sin(time)*12),1,0,0); + gfxRotate(rx*90,0,0,1); + gfxRotate(ry*90,0,1,0); + + gfxColour(1, 1, 1, 1); + gfxSetAspect(1); + gfxCube(-0.25f, -0.25f, -0.25f, 0.25f, 0.25f, 0.25f); + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/WalkingCube.vtx b/addons/visualization.vortex/resources/Presets/WalkingCube.vtx new file mode 100644 index 0000000000..98e88a7888 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/WalkingCube.vtx @@ -0,0 +1,151 @@ +// WalkingCube.vtx +// Author - MrC + +float time = 0; +float rx,rxamt,ry,ryamt; +float y = 0; +Texture checker; +Texture sky; +float tx, ty; + +float d = 0; + +void Init() +{ + checker.LoadTexture("checker.png"); + sky.LoadTexture("sky.dds"); + + tx = 0; + ty = 0; + ryamt = 0; + +} + +void Render() +{ + + gfxPushMatrix(); + + d = TIMEPASS*((BASS + 1.5)*4); + d = TIMEPASS*6 + (BASS * 4 * TIMEPASS); + + time += d; + + ry += TIMEPASS * ryamt * 2; + + gfxSetTexture(sky); + + gfxSetBlendMode(BLEND_MOD); + gfxPushMatrix(); + gfxSetAspect(0); + gfxTranslate(0,0,2.414); + + gfxBegin(PRIM_QUADLIST); + gfxColour(1, 1, 1, 1); + gfxTexCoord(0, 0); + gfxVertex(-1, 1, 0); + + gfxTexCoord(1, 0); + gfxVertex(1, 1, 0); + + gfxTexCoord(1, 1); + gfxVertex(1, -0.2, 0); + + gfxTexCoord(0, 1); + gfxVertex(-1, -0.2, 0); + + gfxColour(0.7, 0.7, 0.7, 1); + + gfxTexCoord(0, 1); + gfxVertex(-1, -0.2, 0); + + gfxTexCoord(1, 1); + gfxVertex(1, -0.2, 0); + + gfxTexCoord(1, 0); + gfxVertex(1, -1, 0); + + gfxTexCoord(0, 0); + gfxVertex(-1, -1, 0); + + gfxEnd(); + + gfxSetAspect(1); + gfxPopMatrix(); + + gfxSetTexture(TEXTURE_ALBUMART); + + if (BASS>0.3) rxamt = 1; + if (BASS<-0.3) rxamt = -1; + if (TREBLE>0.4) ryamt = Rand()-0.5f; + + + + gfxPushMatrix(); + gfxSetBlendMode(BLEND_OFF); + gfxScale(1,-1,1); + gfxTranslate(0, 0.5 + Fabs(Sin(time * 2 *45 * 3.1415 / 180))* 0.125, 2.0f); + gfxRotate(ry*90,0,1,0); + gfxRotate(time*45,0,0,1); + + gfxColour(1, 1, 1, 1); + gfxCube(-0.25f, -0.25f, -0.25f, 0.25f, 0.25f, 0.25f); + + gfxPopMatrix(); + + gfxPushMatrix(); + + gfxTranslate(0, Fabs(Sin(time * 2 *45 * 3.1415 / 180))* 0.125, 2.0f); + gfxRotate(ry*90,0,1,0); + gfxRotate(time*45,0,0,1); + + gfxColour(1, 1, 1, 1); + gfxCube(-0.25f, -0.25f, -0.25f, 0.25f, 0.25f, 0.25f); + + gfxPopMatrix(); + + + float c = Cos(ry*90 * 3.1415 / 180); + float s = Sin(ry * 90 * 3.1415 / 180); + + ty -= d * 0.06f * s; + tx -= d * 0.06f * c; + + if (ty > 2) + ty -= 1.0f; + + if (ty < 2) + ty += 1.0f; + + if (tx > 2) + tx -= 1.0f; + + if (tx < 2) + tx += 1.0f; + + + // Floor + + + gfxSetTexture(checker); + gfxTranslate(0, -0.245, 2.0f); + gfxSetBlendMode(BLEND_MOD); + + gfxBegin(PRIM_QUADLIST); + gfxColour(0, 0, 0, 0.4); + gfxTexCoord((0+tx)*2, (0+ty)*2); + gfxVertex(-2, 0, 2); + gfxTexCoord((1+tx)*2, (0+ty)*2); + gfxVertex(2, 0, 2); + gfxColour(1, 1, 1, 0.8); + gfxTexCoord((1+tx)*2, (1+ty)*2); + gfxVertex(2, 0, -2); + gfxTexCoord((0+tx)*2, (1+ty)*2); + gfxVertex(-2, 0, -2); + gfxEnd(); + + + gfxPopMatrix(); + + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/WarpDrive.vtx b/addons/visualization.vortex/resources/Presets/WarpDrive.vtx new file mode 100644 index 0000000000..95d8df2c14 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/WarpDrive.vtx @@ -0,0 +1,73 @@ +// WarpDrive.vtx +// Author - MrC +// Based on WarpDrive.r4 by Gordon Williams + +Texture trail; +Texture sky; + +float[] pvel(256),ppos(256),ptheta(256),prad(256),plen(256),psnd(256); +int x; +float f,g,bt; +const int cnt = 256; +float time; + +void Init() +{ + sky.LoadTexture("skybox.dds"); + trail.LoadTexture("bluestrip.dds"); + + for (x=0;x<cnt;x=x+1) newpt(x); + bt = 0; + time = 0; +} + +void drawit(float ax,float ay,float bx, float by,float r) +{ + gfxTexCoord(0,0); + gfxVertex(r*Cos(ax),r*Sin(ax),ay); + gfxTexCoord(0,1); + gfxVertex(r*Cos(bx),r*Sin(bx),ay); + gfxTexCoord(1,1); + gfxVertex(r*Cos(bx),r*Sin(bx),by); + gfxTexCoord(1,0); + gfxVertex(r*Cos(ax),r*Sin(ax),by); +} + +void newpt(int p) +{ + pvel[p] = (Rand()+0.5)*2.0; + ppos[p] = 0.0; + ptheta[p] = Rand()*3.14159*2.0; + prad[p] = (Rand()*1.25)+0.25; + plen[p] = 1.0+Rand(); + psnd[p] = Rand(); +} + +void Render() +{ + gfxClear(0, 0, 0.1); + + bt = bt + (TIMEPASS*(0.2+BASS)); + time += TIMEPASS; + gfxSetBlendMode(BLEND_ADD); + + f = Sin(bt+Sin(time*1.353)); + g = Sin(f*3.14159*0.5); + gfxTranslate(0,0,3); + gfxRotate(90*(g+1.0),Sin(time*0.4),Cos(time*0.4),0); + gfxSetTexture(sky); + gfxCube(-200,-200,-200,200,200,200); + gfxSetTexture(trail); + gfxTranslate((Sin(bt*1.61))*0.3,(Sin(bt*1.23))*0.3,-8+(g*6.0)); + gfxBegin(PRIM_QUADLIST); + for (x=0;x<cnt;x=x+1) + { + ppos[x] = ppos[x] + (pvel[x]*TIMEPASS*(0.5+(psnd[x]*BASS)+((1.0-psnd[x])*TREBLE))); + if (ppos[x]<0) ppos[x] = 0; + if (ppos[x]>1.0) newpt(x); + gfxColour(1,1,1,(1.0-Cos(ppos[x]*3.14159*2.0))*0.5); + drawit(ptheta[x],(ppos[x]*16.0)+plen[x],ptheta[x]+0.08+(prad[x]*0.025),(ppos[x]*16.0),prad[x]); + } + gfxEnd(); + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/WarpDriveTwist.vtx b/addons/visualization.vortex/resources/Presets/WarpDriveTwist.vtx new file mode 100644 index 0000000000..fafcaf22b6 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/WarpDriveTwist.vtx @@ -0,0 +1,74 @@ +// WarpDriveTwist.vtx +// Author - MrC +// Based on WarpDriveTwist.r4 by Gordon Williams + +Texture trail; + +float[] pvel(256),ppos(256),ptheta(256),prad(256),plen(256),psnd(256); +int[] pval(256),vr(8),vg(8),vb(8); + +int x; +float f,g,bt; +const int cnt = 256; +float time; + +void Init() +{ + trail.LoadTexture("bluestrip.dds"); + + for (x=0;x<cnt;x=x+1) newpt(x); + bt = 0; + time = 0; +} + +void drawit(float ax,float ay,float bx, float by,float r) +{ + gfxTexCoord(0,0); + gfxVertex(r*Cos(ax),r*Sin(ax),ay); + gfxTexCoord(0,1); + gfxVertex(r*Cos(bx),r*Sin(bx),ay); + gfxTexCoord(1,1); + gfxVertex(r*Cos(bx),r*Sin(bx),by); + gfxTexCoord(1,0); + gfxVertex(r*Cos(ax),r*Sin(ax),by); +} + +void newpt(int p) +{ + pvel[p] = (Rand()+0.5)*2.0; + ppos[p] = 0.0; + ptheta[p] = Rand()*3.14159*2.0; + prad[p] = (Rand()*1.25)+0.25; + plen[p] = 1.0+Rand(); + psnd[p] = Rand() * 4; + pval[p] = Rand()*4; +} + +void Render() +{ + + gfxClear(0, 0, 0.1); + + bt = bt + (TIMEPASS*(0.2+BASS)); + time += TIMEPASS; + gfxSetBlendMode(BLEND_ADD); + + f = Sin(bt+Sin(time*1.353)); + g = Sin(f*3.14159*0.5); + gfxTranslate(0,0,3); + gfxRotate(90*(g+1.0),Sin(time*0.4),Cos(time*0.4),0); + gfxSetTexture(trail); + gfxTranslate((Sin(bt*1.61))*0.3,(Sin(bt*1.23))*0.3,-8+(g*6.0)); + gfxBegin(PRIM_QUADLIST); + for (x=0;x<cnt;x=x+1) + { + ppos[x] = ppos[x] + (pvel[x]*TIMEPASS*(0.5+(psnd[x]*BASS)+((1.0-psnd[x])*TREBLE))); + ptheta[x] = ptheta[x] + (((pval[x]%2)-0.5)*(BASS+0.15)*TIMEPASS*20); + if (ppos[x]<0) ppos[x] = 0; + if (ppos[x]>1.0) newpt(x); + gfxColour(1,1,1,(1.0-Cos(ppos[x]*3.14159*2.0))*0.5); + drawit(ptheta[x],(ppos[x]*16.0)+plen[x],ptheta[x]+0.08+(prad[x]*0.025),(ppos[x]*16.0),prad[x]); + } + gfxEnd(); + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/Wave.vtx b/addons/visualization.vortex/resources/Presets/Wave.vtx new file mode 100644 index 0000000000..82c4986930 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/Wave.vtx @@ -0,0 +1,26 @@ +// Author : MrC + +void Render() +{ + gfxSetAspect(0); + gfxTranslate(0, 0, 2.414); + + gfxBegin(PRIM_LINESTRIP); + for (int x=0; x<256; x=x+1) + { + float r = WaveLeft(x); + gfxColour(1, Fabs(r), 0.1f, 1); + gfxVertex((x-128) / 128.0f, r * 0.4f + 0.5f, 0); + } + gfxEnd(); + + gfxBegin(PRIM_LINESTRIP); + for (int x=0; x<256; x=x+1) + { + float r = WaveRight(x); + gfxColour(Fabs(r), 1, 0.1f, 1); + gfxVertex((x-128) / 128.0f, r * 0.4f - 0.5f, 0); + } + gfxEnd(); + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/WaveRing.vtx b/addons/visualization.vortex/resources/Presets/WaveRing.vtx new file mode 100644 index 0000000000..792adbbf2c --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/WaveRing.vtx @@ -0,0 +1,59 @@ +// Author - MrC +// Based on WaveRing.r4 by Gordon Williams + +Map map; + +int x,y; +float theta,rad,dx,dy; +float mx, my; + +void Init() +{ + for (y=0;y<24;y=y+1) + { + for (x=0;x<32;x=x+1) + { + dx = x-15.5; + dy = y-11.5; + rad = Mag(dx,dy); + theta = Atan2(dy,dx); + mx = -(0.01*dy/rad)-Sin((rad-7.5)*0.1)*0.02*dx/rad; + my = (0.01*dx/rad)-Sin((rad-7.5)*0.1)*0.02*dy/rad; + map.SetValues(x, y, mx, my, (3.0+Cos(theta))*0.275, (3.0+Cos(theta*2.0))*0.275, (3.0+Cos(theta*4.0))*0.275); + } + } +} + +void Render() +{ + map.Render(); + + gfxSetRenderTarget(map); + + gfxColour(1,1,1,1); + gfxBegin(PRIM_LINESTRIP); + for (int x=0; x < 256; x = x+1) + { + rad = 0.25 + (WaveLeft(x) / 10.0f); + theta = x*3.141592/128.0; + gfxVertex(Cos(theta)*rad, Sin(theta)*rad,1); + } + gfxEnd(); + + gfxBegin(PRIM_LINESTRIP); + for (int x=0; x < 256; x = x+1) + { + rad = 0.25 + (WaveRight(x) / 10.0f); + theta = x*3.141592/128.0; + gfxVertex(Cos(theta)*rad, Sin(theta)*rad,1); + } + gfxEnd(); + + gfxSetRenderTarget(0); + gfxSetTexture(map); + + gfxSetAspect(0); + gfxTranslate(0, 0, 2.414); + gfxTexRect(-1, 1, 1, -1); + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/WaveScope.vtx b/addons/visualization.vortex/resources/Presets/WaveScope.vtx new file mode 100644 index 0000000000..4f0a7f15d7 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/WaveScope.vtx @@ -0,0 +1,99 @@ +// Author - MrC +// Based on WaveScope.r4 by Gordon Williams +Map map; + +float dx,dy,a,r,d,tp,s,t,c; +float px,py,pdx,pdy; // point +float cr,cg,cb,basstime; + +void Init() +{ + px = 16; + py = 12; + pdx = 1.342; + pdy = 1; + basstime = 0; + map.SetTimed(); +} + +void Render() +{ + //-------------------------------------- + // Update map + + t = TIMEPASS*(BASS+0.25)*40; + px = px + (pdx*t); + if (px>28) + { + pdx = -(pdx); + px = 28; + } + else if (px<4) + { + pdx = -(pdx); + px = 4; + } + py = py + (pdy*t); + if (py>20) + { + pdy = -(pdy); + py = 20; + } + else if (py<4) + { + pdy = -(pdy); + py = 4; + } + + basstime = basstime + (TIMEPASS*(BASS+1)); + cr = (Cos(basstime)-1.0)/2.0; + cg = (Cos(basstime*2.0)-1.0)/2.0; + cb = (Cos(basstime*4.0)-1.0)/2.0; + + for (int y = 0; y < 24; y++) + { + for (int x = 0; x < 32; x++) + { + dx = x-px; + dy = y-py; + d = Mag(dx,dy); + if (d>0.01) + { + c = (0.5/d)-0.05; + if (c<0) + c=0; + a = (d-12)/64; + if (a>0) + a=0; + r = 1-(d/4.0); + map.SetValues(x,y, (dx*a)+(dy*c), (dy*a)-(dx*c), cr+r, cg+r, cb+r); + } + } + } + + map.Render(); + + gfxSetRenderTarget(map); + + gfxSetAspect(0); + gfxTranslate(0, 0, 2.414); + + gfxBegin(PRIM_LINESTRIP); + for (int x=0; x < 256; x = x+1) + { + gfxVertex((x-128)/128.0f, (WaveLeft(x) / 3.0f) + 0.5f, 0); + } + gfxEnd(); + + gfxBegin(PRIM_LINESTRIP); + for (int x=0; x < 256; x = x+1) + { + gfxVertex((x-128)/128.0f, (WaveRight(x) / 3.0f) - 0.5f, 0); + } + gfxEnd(); + + gfxSetRenderTarget(0); + gfxSetTexture(map); + gfxTexRect(-1, -1, 1, 1); + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/WaveZoomer.vtx b/addons/visualization.vortex/resources/Presets/WaveZoomer.vtx new file mode 100644 index 0000000000..ae26e0dfc6 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/WaveZoomer.vtx @@ -0,0 +1,90 @@ +// WaveZoomer.vtx +// Author - MrC +// Based on WaveZoomer.r4 b Gordon Williams + +Map map; + +int x,y; +float dx,dy,a,r; +float cr,cg,cb,cx,cy,crot,cox,coy; +float ccr,ccg,ccb; +float sinrot,cosrot; +float tx,ty,tz; +float mx, my; +int beat; + +void Init() +{ + map.SetTimed(); + cx = 15.5; + cy = 11.5; + cox = 0; + coy = 0; + crot = 0; +} + +void Render() +{ + if ((BASS+MIDDLE+TREBLE>0.6) && (beat!=1)) + { + beat=1; + cx = (20.0*Rand())+6.0; + cy = (16.0*Rand())+4.0; + cox = (Rand()-0.5)*1.5; + coy = (Rand()-0.5)*1.5; + crot = (Rand()-0.5)*2; + ccr = Rand()-2; + ccg = Rand()-2; + ccb = Rand()-2; + } + else if ((BASS+MIDDLE+TREBLE<-0.6) && (beat!=0)) + { + beat = 0; + } + + sinrot = -0.05*Sin(crot)*(BASS+1.5); + cosrot = -0.05*Cos(crot)*(BASS+1.5); + + tx = cox*(MIDDLE+1.5); + ty = coy*(MIDDLE+1.5); + for (y=0;y<24;y=y+1) + { + for (x=0;x<32;x=x+1) + { + dx = x-cx; + dy = y-cy; + mx = tx+((dx*cosrot)+(dy*sinrot)); + my = ty+((dy*cosrot)-(dx*sinrot)); + map.SetValues(x, y, mx, my, ccr, ccg, ccb); + } + } + + map.Render(); + + gfxSetRenderTarget(map); + + gfxColour(0.8,0.8,0.8, 1); + + gfxSetAspect(0); + gfxTranslate(0, 0, 2.414); + + gfxBegin(PRIM_LINESTRIP); + for (int x=0; x < 256; x = x+1) + { + gfxVertex((x-128)*0.0078125f, (WaveLeft(x) * 0.2f) + 0.5f, 0); + } + gfxEnd(); + + gfxBegin(PRIM_LINESTRIP); + for (int x=0; x < 256; x = x+1) + { + gfxVertex((x-128)*0.0078125f, (WaveRight(x) * 0.2f) - 0.5f, 0); + } + gfxEnd(); + + gfxSetRenderTarget(0); + gfxSetTexture(map); + + gfxTexRect(-1, 1, 1, -1); + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/Woofer.vtx b/addons/visualization.vortex/resources/Presets/Woofer.vtx new file mode 100644 index 0000000000..f6ab55ac86 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/Woofer.vtx @@ -0,0 +1,65 @@ +// woofer.vtx +// Author - morte0815 + +float angle = 0; + +void Init() +{ + +} + +void Quad(float x, float y, float z, float width, float tu_u,float tv_l, float tu_b , float tv_r) +{ +gfxBegin(PRIM_QUADLIST); +gfxTexCoord(tu_u, tv_l); +gfxVertex(x,y,z); +gfxTexCoord(tu_b, tv_l); +gfxVertex(x+width,y,z); +gfxTexCoord(tu_b, tv_r); +gfxVertex(x+width,y+width,z); +gfxTexCoord(tu_u, tv_r); +gfxVertex(x,y+width,z); + + +gfxEnd(); +} + + +float Length(float x, float y) +{ + return Sqrt(x*x+y*y); +} + +void Render() +{ + if (BASS>0.5f)angle += TIMEPASS*5; + if (BASS<0.5f)angle -= TIMEPASS*5; + + gfxTranslate(0, 0, 25.0f); + + gfxRotate(-100,1,0,0); + gfxRotate(angle,0,0,1); + + + gfxSetTexture(TEXTURE_ALBUMART); + + for (int i = -10; i < 10; i++) + { + for ( int j = -10; j < 10; j++) + { + if (Length(i,j) <= 10) + { + float height=(Length(i,j)/10.0f*BASS); + height+=((10.0f-Length(i,j))/10.0f*TREBLE); + height+=((5.0f-Length(i,j))/10*MIDDLE); + Quad(i,j,height,1,(i+10)/20.0f,(j+10)/20.0f,(i+1+10)/20.0f,(j+1+10)/20.0f); + } + } + } + + + + + gfxEnd(); + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/XBMCRain.vtx b/addons/visualization.vortex/resources/Presets/XBMCRain.vtx new file mode 100644 index 0000000000..224b4e1891 --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/XBMCRain.vtx @@ -0,0 +1,95 @@ +// Author - MrC +// Based on R4Rain.r4 by Gordon Williams + +int x,y, t; +float c,tm,tn,td, s; +float[] c_x(64),c_y(64),c_z(64),c_vz(64),c_rx(64),c_ry(64),c_sx(64),c_sy(64),c_sz(64); +float d; + +Texture texture; +Texture sky; + +void MakeNew(int n) +{ + c_x[n]=c_y[n]=0; + while (Mag(c_x[n],c_y[n])<1) + { + c_x[n] = (Rand()*6.0)-3.0; + c_y[n] = (Rand()*6.0)-3.0; + } + + c_z[n] = 10; + c_vz[n] = (1.0+Rand())*4; + c_rx[n] = (1.0+Rand())*80; + c_ry[n] = (1.0+Rand())*80; + c_sx[n] = (0.5+Rand())*0.5; + c_sy[n] = (0.5+Rand())*0.5; + c_sz[n] = (1.0+Rand())*0.05; +} + + +void Init() +{ + texture.LoadTexture("splash_original.dds"); + sky.LoadTexture("skybox.dds"); + + for (x=0;x<64;x=x+1) + { + MakeNew(x); + c_z[x] = Rand()*10; + } + tm = tn = 0; +} + +void mything(float x,float y,float z) +{ + gfxBegin(PRIM_QUADLIST); + for (t=0; t<1; t++) + { + s = z*((t/2.0f)-1.0); + gfxTexCoord(0,0); + gfxVertex(-x,y,s); + gfxTexCoord(1,0); + gfxVertex(x,y,s); + gfxTexCoord(1,1); + gfxVertex(x,-y,s); + gfxTexCoord(0,1); + gfxVertex(-x,-y,s); + + } + gfxEnd(); +} + +void Render() +{ + td = ((TREBLE+1.5f)*TIMEPASS); + tm = tm + td; + tn = tn + ((BASS+1.0)*TIMEPASS*2); + + gfxTranslate(Cos(tn * 1.23f) * 0.5f, Sin(tn) * 0.5f, 0.0f); + gfxRotate(Cos(tn*0.6734f)*20.0f, 1.0f, 0.0f, 0.0f); + gfxRotate(Sin(tn*0.2143f)*20.0f, 0.0f, 1.0f, 0.0f); + + gfxSetTexture(sky); + gfxCube(-100,-100,-100,100,100,100); + + gfxSetTexture(texture); + + gfxSetBlendMode(BLEND_ADD); + + for (x=0;x<64;x++) + { + c_z[x] = c_z[x] - (td*c_vz[x]); + if (c_z[x]<0) MakeNew(x); + + c = (10.0-c_z[x])*0.11; + gfxColour(c,c,c,1); + gfxPushMatrix(); + gfxTranslate(c_x[x],c_y[x],c_z[x]); + gfxRotate(c_rx[x]*tm,1.0f,0.0f,0.0f); + gfxRotate(c_ry[x]*tm,0.0f,1.0f,0.0f); + mything(c_sx[x],c_sy[x],c_sz[x]); + gfxPopMatrix(); + } + +}
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/Presets/tunnel.tra b/addons/visualization.vortex/resources/Presets/tunnel.tra new file mode 100644 index 0000000000..42cf0a6c0a --- /dev/null +++ b/addons/visualization.vortex/resources/Presets/tunnel.tra @@ -0,0 +1,56 @@ +// Tunnel.tra +// Author - MrC +// Based on FadeTunnel.r4 by Gordon Williams + +const int strips = 64; + +int x,y; +float dx,dy,sx,sy,tx,a,b,mytime; + +void Init() +{ +} + +void Render() +{ + mytime = mytime + (TIMEPASS * 0.25); + FINISHED = (mytime>1); + + gfxSetTexture(TEXTURE_NEXTPRESET); + gfxSetAspect(0); + gfxTranslate(0, 0, 2.414); + gfxColour(1, 1, 1, 1); + gfxTexRect(-1, 1, 1, -1); + gfxTranslate(0, 0, -2.414); + + a = mytime*2; + if (a>1.0) a=1.0; + a = (1.0-Cos(a*3.14159))/2.0; + + b = (mytime*2)-1.0; + if (b<0.0) b=0.0; + b = (1.0-Cos(b*3.14159))/2.0; + + gfxTranslate(0,0,2.414+(a*3.0)-(b*8)); + + gfxRotate((1.0-Cos(a*3.14159))*180,1,1,1); + gfxRotate(a*90,1,0,0); + gfxRotate((1.0-Cos(b*3.14159))*180,0,1,0); + + gfxSetTexture(TEXTURE_CURRPRESET); + + gfxColour(1,1,1,1); + gfxBegin(PRIM_QUADSTRIP); + + for (x=0;x<=strips;x=x+1) + { + dx = (1.0*x)/strips; + tx = dx*2; + if (tx>1) tx=2.0-tx; + gfxTexCoord(tx,1.0); + gfxVertex(((dx*4.0)-1.0)*(1.0-a)+(-Cos(3.14159*2.0*dx)*a),-1-a,(-Sin(3.14159*2.0*dx)*a)); + gfxTexCoord(tx,0.0); + gfxVertex(((dx*4.0)-1.0)*(1.0-a)+(-Cos(3.14159*2.0*dx)*a),1+a,(-Sin(3.14159*2.0*dx)*a)); + } + gfxEnd(); +} diff --git a/addons/visualization.vortex/resources/Textures/Plasma_edge.jpg b/addons/visualization.vortex/resources/Textures/Plasma_edge.jpg Binary files differnew file mode 100644 index 0000000000..27143d3950 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/Plasma_edge.jpg diff --git a/addons/visualization.vortex/resources/Textures/Skull_JawUD1.png b/addons/visualization.vortex/resources/Textures/Skull_JawUD1.png Binary files differnew file mode 100644 index 0000000000..ea58ba96b1 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/Skull_JawUD1.png diff --git a/addons/visualization.vortex/resources/Textures/Skull_JawUD2.png b/addons/visualization.vortex/resources/Textures/Skull_JawUD2.png Binary files differnew file mode 100644 index 0000000000..bd1bee0c1b --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/Skull_JawUD2.png diff --git a/addons/visualization.vortex/resources/Textures/Skull_JawUD3.png b/addons/visualization.vortex/resources/Textures/Skull_JawUD3.png Binary files differnew file mode 100644 index 0000000000..6daa4cd2e7 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/Skull_JawUD3.png diff --git a/addons/visualization.vortex/resources/Textures/Skull_JawUD4.png b/addons/visualization.vortex/resources/Textures/Skull_JawUD4.png Binary files differnew file mode 100644 index 0000000000..bbe0751141 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/Skull_JawUD4.png diff --git a/addons/visualization.vortex/resources/Textures/Skull_JawUD5.png b/addons/visualization.vortex/resources/Textures/Skull_JawUD5.png Binary files differnew file mode 100644 index 0000000000..ab93d76a63 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/Skull_JawUD5.png diff --git a/addons/visualization.vortex/resources/Textures/Skull_JawUD6.png b/addons/visualization.vortex/resources/Textures/Skull_JawUD6.png Binary files differnew file mode 100644 index 0000000000..83935d1f7b --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/Skull_JawUD6.png diff --git a/addons/visualization.vortex/resources/Textures/Skull_JawUD7.png b/addons/visualization.vortex/resources/Textures/Skull_JawUD7.png Binary files differnew file mode 100644 index 0000000000..a3c77610c0 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/Skull_JawUD7.png diff --git a/addons/visualization.vortex/resources/Textures/Skull_JawUD8.png b/addons/visualization.vortex/resources/Textures/Skull_JawUD8.png Binary files differnew file mode 100644 index 0000000000..93686da855 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/Skull_JawUD8.png diff --git a/addons/visualization.vortex/resources/Textures/Smiley.png b/addons/visualization.vortex/resources/Textures/Smiley.png Binary files differnew file mode 100644 index 0000000000..3b6d9d8cf4 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/Smiley.png diff --git a/addons/visualization.vortex/resources/Textures/Speaker.png b/addons/visualization.vortex/resources/Textures/Speaker.png Binary files differnew file mode 100644 index 0000000000..f7de0b693f --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/Speaker.png diff --git a/addons/visualization.vortex/resources/Textures/Tex_Edge.png b/addons/visualization.vortex/resources/Textures/Tex_Edge.png Binary files differnew file mode 100644 index 0000000000..380e12888d --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/Tex_Edge.png diff --git a/addons/visualization.vortex/resources/Textures/Vortex_Credits.png b/addons/visualization.vortex/resources/Textures/Vortex_Credits.png Binary files differnew file mode 100644 index 0000000000..3c46640107 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/Vortex_Credits.png diff --git a/addons/visualization.vortex/resources/Textures/alien.png b/addons/visualization.vortex/resources/Textures/alien.png Binary files differnew file mode 100644 index 0000000000..a2cbd012e2 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/alien.png diff --git a/addons/visualization.vortex/resources/Textures/aqua_ravines.jpg b/addons/visualization.vortex/resources/Textures/aqua_ravines.jpg Binary files differnew file mode 100644 index 0000000000..00835672d5 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/aqua_ravines.jpg diff --git a/addons/visualization.vortex/resources/Textures/bluestrip.dds b/addons/visualization.vortex/resources/Textures/bluestrip.dds Binary files differnew file mode 100644 index 0000000000..a48cada742 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/bluestrip.dds diff --git a/addons/visualization.vortex/resources/Textures/checker.png b/addons/visualization.vortex/resources/Textures/checker.png Binary files differnew file mode 100644 index 0000000000..4ca89c614b --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/checker.png diff --git a/addons/visualization.vortex/resources/Textures/checker_transp.png b/addons/visualization.vortex/resources/Textures/checker_transp.png Binary files differnew file mode 100644 index 0000000000..753c662077 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/checker_transp.png diff --git a/addons/visualization.vortex/resources/Textures/env2.jpg b/addons/visualization.vortex/resources/Textures/env2.jpg Binary files differnew file mode 100644 index 0000000000..ae425b7531 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/env2.jpg diff --git a/addons/visualization.vortex/resources/Textures/env3.png b/addons/visualization.vortex/resources/Textures/env3.png Binary files differnew file mode 100644 index 0000000000..a90b1a3326 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/env3.png diff --git a/addons/visualization.vortex/resources/Textures/env3_darker.png b/addons/visualization.vortex/resources/Textures/env3_darker.png Binary files differnew file mode 100644 index 0000000000..2e3cd96d63 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/env3_darker.png diff --git a/addons/visualization.vortex/resources/Textures/huemap.jpg b/addons/visualization.vortex/resources/Textures/huemap.jpg Binary files differnew file mode 100644 index 0000000000..ceb09176ba --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/huemap.jpg diff --git a/addons/visualization.vortex/resources/Textures/skull.png b/addons/visualization.vortex/resources/Textures/skull.png Binary files differnew file mode 100644 index 0000000000..a684418b94 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/skull.png diff --git a/addons/visualization.vortex/resources/Textures/sky.dds b/addons/visualization.vortex/resources/Textures/sky.dds Binary files differnew file mode 100644 index 0000000000..6c00f4170a --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/sky.dds diff --git a/addons/visualization.vortex/resources/Textures/skybox.dds b/addons/visualization.vortex/resources/Textures/skybox.dds Binary files differnew file mode 100644 index 0000000000..4d389ebaa4 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/skybox.dds diff --git a/addons/visualization.vortex/resources/Textures/splash_original.dds b/addons/visualization.vortex/resources/Textures/splash_original.dds Binary files differnew file mode 100644 index 0000000000..bed53fafb9 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/splash_original.dds diff --git a/addons/visualization.vortex/resources/Textures/trail2.dds b/addons/visualization.vortex/resources/Textures/trail2.dds Binary files differnew file mode 100644 index 0000000000..7d1178c7a3 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/trail2.dds diff --git a/addons/visualization.vortex/resources/Textures/vortex-v.jpg b/addons/visualization.vortex/resources/Textures/vortex-v.jpg Binary files differnew file mode 100644 index 0000000000..f70f906e76 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/vortex-v.jpg diff --git a/addons/visualization.vortex/resources/Textures/xbmc_icon.png b/addons/visualization.vortex/resources/Textures/xbmc_icon.png Binary files differnew file mode 100644 index 0000000000..f011789ad4 --- /dev/null +++ b/addons/visualization.vortex/resources/Textures/xbmc_icon.png diff --git a/addons/visualization.vortex/resources/language/English/strings.po b/addons/visualization.vortex/resources/language/English/strings.po new file mode 100644 index 0000000000..98aeb156dd --- /dev/null +++ b/addons/visualization.vortex/resources/language/English/strings.po @@ -0,0 +1,65 @@ +# XBMC Media Center language file +# Addon Name: vortex +# Addon id: visualization.vortex +# Addon Provider: Team XBMC +msgid "" +msgstr "" +"Project-Id-Version: XBMC Main\n" +"Report-Msgid-Bugs-To: http://trac.xbmc.org/\n" +"POT-Creation-Date: YEAR-MO-DA HO:MI+ZONE\n" +"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" +"Last-Translator: XBMC Translation Team\n" +"Language-Team: English (http://www.transifex.com/projects/p/xbmc-main/language/en/)\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: 8bit\n" +"Language: en\n" +"Plural-Forms: nplurals=2; plural=(n != 1);\n" + +#settings labels + +msgctxt "#30000" +msgid "Random Presets" +msgstr "" + +msgctxt "#30001" +msgid "Time Between Presets" +msgstr "" + +msgctxt "#30002" +msgid "Additional Random Time" +msgstr "" + +msgctxt "#30003" +msgid "Lock Preset" +msgstr "" + +msgctxt "#30004" +msgid "Enable Transitions" +msgstr "" + +msgctxt "#30005" +msgid "Stop first preset" +msgstr "" + +msgctxt "#30006" +msgid "Show FPS" +msgstr "" + +msgctxt "#30007" +msgid "Show debug console" +msgstr "" + +msgctxt "#30008" +msgid "Show audio analysis" +msgstr "" + +#setting value formats + +msgctxt "#30050" +msgid "%2.0f secs" +msgstr "" + +msgctxt "#30051" +msgid "%2.0f fps" +msgstr ""
\ No newline at end of file diff --git a/addons/visualization.vortex/resources/settings.xml b/addons/visualization.vortex/resources/settings.xml new file mode 100644 index 0000000000..de32b2695a --- /dev/null +++ b/addons/visualization.vortex/resources/settings.xml @@ -0,0 +1,12 @@ +<?xml version="1.0" encoding="UTF-8"?> +<settings> + <setting id="RandomPresets" type="bool" label="30000" default="true"/> + <setting id="TimeBetweenPresets" type="rangeofnum" label="30001" rangestart="5" rangeend="50" elements="10" valueformat="30050" default="0"/> + <setting id="AdditionalRandomTime" type="rangeofnum" label="30002" rangestart="5" rangeend="50" elements="10" valueformat="30050" default="0"/> + <setting id="LockPreset" type="bool" label="30003" default="false"/> + <setting id="EnableTransitions" type="bool" label="30004" default="true"/> + <setting id="StopFirstPreset" type="bool" label="30005" default="false"/> + <setting id="ShowFPS" type="bool" label="30006" default="false" visible="false"/> + <setting id="ShowDebugConsole" type="bool" label="30007" default="false" visible="false"/> + <setting id="ShowAudioAnalysis" type="bool" label="30008" default="false" visible="false"/> +</settings> |