We are about to switch to a new forum software. Until then we have removed the registration on this forum.
Here I have created a music Visualization...
Link to the Project: https://www.behance.net/gallery/Processing-Music-Visualization/15659061
Code:
import ddf.minim.*;
import ddf.minim.analysis.*;
Minim minim;
AudioPlayer player;
AudioMetaData meta;
BeatDetect beat;
int r = 200;
float rad = 70;
void setup()
{
size(displayWidth, displayHeight);
//size(600, 400);
minim = new Minim(this);
player = minim.loadFile("song.mp3");
meta = player.getMetaData();
beat = new BeatDetect();
player.loop();
//player.play();
background(-1);
noCursor();
}
void draw()
{
float t = map(mouseX, 0, width, 0, 1);
beat.detect(player.mix);
fill(#1A1F18, 20);
noStroke();
rect(0, 0, width, height);
translate(width/2, height/2);
noFill();
fill(-1, 10);
if (beat.isOnset()) rad = rad*0.9;
else rad = 70;
ellipse(0, 0, 2*rad, 2*rad);
stroke(-1, 50);
int bsize = player.bufferSize();
for (int i = 0; i < bsize - 1; i+=5)
{
float x = (r)*cos(i*2*PI/bsize);
float y = (r)*sin(i*2*PI/bsize);
float x2 = (r + player.left.get(i)*100)*cos(i*2*PI/bsize);
float y2 = (r + player.left.get(i)*100)*sin(i*2*PI/bsize);
line(x, y, x2, y2);
}
beginShape();
noFill();
stroke(-1, 50);
for (int i = 0; i < bsize; i+=30)
{
float x2 = (r + player.left.get(i)*100)*cos(i*2*PI/bsize);
float y2 = (r + player.left.get(i)*100)*sin(i*2*PI/bsize);
vertex(x2, y2);
pushStyle();
stroke(-1);
strokeWeight(2);
point(x2, y2);
popStyle();
}
endShape();
if (flag) showMeta();
}
void showMeta() {
int time = meta.length();
textSize(50);
textAlign(CENTER);
text( (int)(time/1000-millis()/1000)/60 + ":"+ (time/1000-millis()/1000)%60, -7, 21);
}
boolean flag =false;
void mousePressed() {
if (dist(mouseX, mouseY, width/2, height/2)<150) flag =!flag;
}
//
boolean sketchFullScreen() {
return true;
}
void keyPressed() {
if(key==' ')exit();
if(key=='s')saveFrame("###.jpeg");
}
Comments
i like the gray one. very nice. the red one kills my eyes. the animation reacts a bit jumpy. maybe it would be good to make some interpolation between the different positions to make it smoother. but then it wouldn't be in sync with the music.
Thanks :) I know the grey one is better so I have uploaded it. :)
Hi man this looks fantastic! Would you be able to do a sound visualization on more complex shapes lets say somthing like type a latrer 'A'?