xxxxxxxxxx
//Q how to make the only one shape to have its trace?
/*
animate character ; moves around the creen,
has internal moving parts
use p5 graphics transformation(rotate, translate, scale) command,
object literal/ custom function to draw it self & maintain its state
*/
var headposition = 30
var headincr = 1
var a = 0
var b = 0
var angleincr = 1
var bincr=1
var size = 100
function preload() {
leftwing = loadImage("leftwing.jfif")
rightwing = loadImage("rightwing.jfif")
feet = loadImage("feet.png")
crow = loadSound("crow.mp3")
face = loadImage("face.png")
}
function setup() {
createCanvas(windowWidth, windowHeight);
angleMode(DEGREES)
rectMode(CENTER)
}
function draw() {
translate(mouseX, mouseY)
background(255);
//wings
//image source
/**/
push(); // move up one level IN THE DRAWING STACK
translate(0, 40);
a = a+angleincr;
if(a>20) angleincr = -angleincr; // reverse it
if(a<-20) angleincr = -angleincr; // reverse it
rotate(a);
image(leftwing, -130, -30, 100, 40)
pop();
push(); // move up one level IN THE DRAWING STACK
b = b+bincr;
translate(0, 40);
if(b>20) bincr = -bincr; // reverse it
if(b<-20) bincr = -bincr; // reverse it
rotate(-b);
image(rightwing, 30, -30, 100, 40)
pop();
//feet
//image source
/*https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcRPlBfha1AJSuS5hepQUWFeA5XpNpuF_58c-A&usqp=CAU*/
image(feet, -50, 70, size, size)
size = size + 0.5
if(size>120) size = 90
//body
fill(0)
ellipse(0, 50, 70, 100)
//head
//image source
/*https://www.google.com/imgres?imgurl=https%3A%2F%2Fcreazilla-store.fra1.digitaloceanspaces.com%2Fcliparts%2F68150%2Fraven-face-clipart-sm.png&imgrefurl=https%3A%2F%2Fcreazilla.com%2Fsections%2F4-clipart%2Ftags%2F2337-crow&tbnid=p-a6yEepgkrZzM&vet=12ahUKEwjD18H1zJHzAhUgrXIEHXiBAMwQMygXegUIARDVAQ..i&docid=vwnMg-2fDJ6TiM&w=300&h=270&q=crow%20face%20png&ved=2ahUKEwjD18H1zJHzAhUgrXIEHXiBAMwQMygXegUIARDVAQ*/
push();
translate(headposition, -50);
fill("teal")
image(face, -50, -20, 100, 100)
pop();
headposition+=headincr;
if(headposition>30) headincr*=-1;
if(headposition<-30) headincr*=-1;
//sound
if(a==20) crow.play()
}