====== Projets processing ====== OpenCV: Il s'agit d'une librairie processing utilisant un flux d'images pour identifier et tracker des objets, des formes ou des visages en temps réel grâce à ses algorithmes.On utilise les pixels pour reconnaître des paternes qui sont interprétés selon les besoins. Dans ces programmes, c'est le visage de face que l'on reconnait, chaque visage est inscrit dans son tableau pour qu'on lui attribue du code, relatif à sa position sur l'écran. ===== ✔ Yeux qui suivent ===== int nb = 10; float mx; float my; eye [] eye = new eye[nb]; import gab.opencv.*; import processing.video.*; import java.awt.*; Capture video; OpenCV opencv; void setup() { fullScreen(); video = new Capture(this, 640/2, 480/2); opencv = new OpenCV(this, 640/2, 480/2); opencv.loadCascade(OpenCV.CASCADE_FRONTALFACE); video.start(); for (int i=0; i1000) { size = 0; time = floor(random(800)); x=floor(random(width)); y=floor(random(height)); } } } ==== ✔ Yeux qui suivent v2 ==== Pareil mais cette c'est une paire de yeux attribuée à chaque visage qui suit indépendamment cette fois-ci {{ :wiki:projets:projets:yeux1.png |}} //import des librairies import gab.opencv.*; import processing.video.*; import java.awt.*; //initialise openCV Capture video; OpenCV opencv; int nb = 5; //nombre max de paires de yeux eye [] eye = new eye[nb]; //déclare la classe void setup() { fullScreen(); //plein écran video = new Capture(this, 640/2, 480/2); //déclare vidéo comme capture webcam opencv = new OpenCV(this, 640/2, 480/2); //déclare openCV opencv.loadCascade(OpenCV.CASCADE_FRONTALFACE); //déclare le type de tracking video.start(); //lance la vidéo for (int i = 0; i < nb; i++) { eye[i] = new eye(); //instancie les différentes paires eye[i].set(); //donne des positions aléatoires } } void draw() { opencv.loadImage(video);//lance la vidéo image(video, 0, 0);//positionne l'image background(0);//fond noir Rectangle[] faces = opencv.detect();//tracking du visage for (int i = 0; i < nb; i++) { //boucle for effective pour chaque paire eye[i].shut(); //change l'état des yeux pour les fermer } for (int i = 0; i < faces.length; i++) { //boucle for pour chaque instance de visage eye[i].mx = (((faces[i].x+faces[i].width/2)*6)*-1+width); //définit la position d'un visage sur x eye[i].my = ((faces[i].y+faces[i].height/2)*4.5);//définit la position d'un visage sur y //ces valeurs sont ajustées pour transformer la taille de la capture vers un écran 1920x1080 eye[i].open(); //change l'état des yeux pour les fermer(si le visage n'est pas détecté on reste sur la valeur donné par eye.shut) eye[i].update(); //calcule la position de la pupille } for (int i = 0; i < nb; i++) {//boucle for effective pour chaque paire eye[i].opening();//selon l'état des yeux, va ouvrir ou les fermer eye[i].display(); // affiche les différents éléments //eye[i].debug(); //pour voir où est positionné le visage sur l'écran } } void captureEvent(Capture c) { c.read(); //lit la vidéo, nécessaire pour OpenCV } class eye { //classe pour chaque paire de yeux float x; //positionnement de la paire sur l'écran sur x float y;//positionnement de la paire sur l'écran sur y float mx;//positionnement du visage sur l'écran sur x float my;//positionnement du visage sur l'écran sur y float langle; float ldist; float lx;//valeur vers laquelle la rétine doit se déplacer par rapport au centre pour viser un visage sur x float ly;//valeur vers laquelle la rétine doit se déplacer par rapport au centre pour viser un visage sur y boolean shutch;//état de l'oeil; ouvert ou fermé float shut;//valeur y de l'ellipse qui crée l'oeil float pupil;//taille de la rétine eye() { } void shut() { shutch = false; //change l'état de la paire sur fermé } void open() { shutch = true; // change l'état de la paire sur ouvert } void opening() { if (shutch) { //si la paire est ouverte if (shut<100) { //si sa taille ne dépasse pas 100 shut+=10; //ouvre progressivement la paire } } else { // si la paire est fermée if (shut>0) {// si sa taille est supérieure à 0 shut+=-10; // ferme progressivement la paire } if (shut<10) { // si les yeux sont fermés x = random(200, -200+width); //attribue de nouvelles coordonnées à la paire sur x y = random(200, -200+height); //attribue de nouvelles coordonnées à la paire sur y } } } void update() { langle = atan2(mx-x, my-y); //calcule l'angle vers lequel la rétine doit s'orienter ldist = dist(mx, my, x, y); //calcule la distance entre la paire et le visage lx = sin(langle)*ldist/30; ly = cos(langle)*ldist/30; } void set() { x = random(200, -200+width); //donne des positions aléatoires sur x y = random(200, -200+height); //donne des positions aléatoires sur y } void display() { noStroke(); //pas de contours fill(255); //remplir en blanc ellipse(x-100, y, 100, shut); //premier globe blanc décalé sur la gauche ellipse(x+100, y, 100, shut); //deuxième globe blanc décalé sur la droite fill(0); //remplir en noir ellipse(x+lx-100, y+ly, pupil, pupil); //premiere rétine positionnée par rapport ellipse(x+lx+100, y+ly, pupil, pupil); if (shutch) { //si l'oeil est ouvert la rétine est à 50 pupil=50; } else { //sinon si l'oeil est fermé elle est sur 0 if (shut<10) { pupil = 0; } } } void debug() { //affiche la position d'un visage fill(255, 0, 0); ellipse(mx, my, 50, 50); } } ==== ✔ MutiPONG ==== Version jouable ici >>>>>> https://guyomarch.neocities.org//MUTIPONG.html {{ :wiki:projets:projets:pong.png |}} /* @pjs preload="MUTI.png"; */ int x; int y; int deplacementX; int deplacementY; PImage img; int xp; int yp; int xpp; int ypp; int score1 = 0; int score2 = 0; void setup() { img = loadImage("MUTI.png"); size(900, 900); x = 200; // commençons au centre de l'écran y = 200; deplacementX = 9; deplacementY = -3; xp = 0+50; xpp = width-50; noStroke(); fill(0, 0, 0); } void draw() { mouse(); auto(); nettoyer(); bouger(); rebondir(); dessiner(); image(img, x-50, y-50); fill(255); rect(xp, yp, 20, 60); rect(xpp, ypp, 20, 60); textSize(32); text((score1), width/2-100, 30); text((score2), width/2+100, 30); } void mouse(){ yp = mouseY; } void auto() { if (yypp+30) { ypp+=+4; } } void keyPressed() { if (key == 'q' == true) { yp= yp+10; } else if (key == 'a') { yp= yp-10; } if (key == 'm') { ypp= ypp+10; } else if (key == 'p') { ypp= ypp-10; } } void nettoyer() { fill(0); rect(0, 0, width, height); } void rebondir() { if ( (x > width-70 && x < width-50 && y>ypp && y 50 && y>yp && y width && deplacementY > 0) || (y < 0 && deplacementY < 0) ) { deplacementY = -deplacementY; } if (x < 0) { x= height/2; y=width/2; score2++; } if (x > width) { x= height/2; y=width/2; score1++; } } void bouger() { x = x + deplacementX; y = y + deplacementY; } void dessiner() { fill(255); ellipse(x, y, 20, 20); } ==== ✔ Cercle qui fait des formes ==== Un cercle qui suit la souris, ça fait de belles formes {{ :wiki:projets:projets:sans-titre-5.gif |}} float t; float t2; float CELL_SIZE = 50; float a; float b; void setup() { fullScreen(); background(0); } void draw() { //translate(width/2, height/2); t+=0.01; t2+=0.001; noStroke(); fill(0, 50); rect(0, 0, width, height); pushMatrix(); translate(width/2, height/2); //scale(2,2); //rotate(t); for (float y = 0; y<2400; y+=CELL_SIZE) { PVector p = new PVector(x1(t+y), (y1(t+y))); for (int i = 0; i<200; i++) { float oldX = p.x; float oldY = p.y; float angle = noise(p.x /200, p.y /200 )*PI*(mouseX/100); //float angle = noise(x1(t+y)/p.x/200,(y1(t+y))/p.y/200)*PI*10; float vx = cos(angle)*mouseY/100; float vy = sin(angle)*mouseY/100; p.x+=vx; p.y+=vy; strokeWeight(0.01); stroke(255); stroke(x1(t+y),y1(t+y),-x1(t+y)+-y1(t+y)); line(oldX, oldY, p.x, p.y); } } noStroke(); fill(0); //ellipse(0, 0, 300, 300); popMatrix(); } float x1(float t) { return cos(t/2)*300; } float y1(float t) { return sin(t/2)*300; } ==== ✔ Et encore ==== Pareil, c'est joli {{ :wiki:projets:projets:sans-titre-4.gif |}} color c; float a; int b; int d; int aa =1; int bb=2; int dd=3; float r; float s=60; int ss=1; void setup() { fullScreen(); background(0); } void draw() { pushMatrix(); translate(width/2, height/2); rotate(r+=0.01); scale(s/100); for (int i = -width; i 255 || a < 0) { aa=-aa; } if (b>255 || b < 0) { bb=-bb; } if (d>255 || d < 0) { dd=-dd; } if (s>100 || s<60) { ss=-ss; } popMatrix(); } ==== ✔ Parametric ==== Un code utile pour comprendre la fonction retour {{ :wiki:projets:projets:para.gif |}} float t; int NUM_LINES = 20; void setup() { size(1000, 1000); background(20); } void draw() { background(20, 20, 20); stroke(200, 200, 200); strokeWeight(1); translate(width/2, height/2); scale(3, 3); for (int i = 0; i < NUM_LINES; i++) { PVector p = new PVector(x1(t+i), y1(t+i)); PVector p2 = new PVector(x2(t+i), y2(t+i)); float oldX = p.x; float oldY = p.y; float angle = noise(p.x /200 + t, p.y /200)*PI*2; float vx = cos(angle)*20; float vy = sin(angle)*15; p.x+=vx; p.y+=vy; line(oldX, oldY,p2.x,p2.y); } t++; } float x1(float t) { return cos(t/10)*50; } float y1(float t) { return sin(t/10)*60+sin(t/20)*40; } float x2(float t) { return cos(t/20)*70; } float y2(float t) { return sin(t/10)*40+sin(t/5)*15; } Sources: https://www.openprocessing.org/sketch/622355 utilisation des lignes de code pour le calcul du déplacement de la rétine. https://www.youtube.com/watch?v=LaarVR1AOvs&t=555s utilisation de la fonction retour. https://www.youtube.com/watch?v=DuhH6s-afNQ&t=27s utilisation du noise.