Angry Birds (Part 6) (Sketch.js)

Angry Birds

(Part 6)


Sketch.js:

const Engine = Matter.Engine;
const World = Matter.World;
const Bodies = Matter.Bodies;
const Constraint = Matter.Constraint;

var engine, world;

var box1;

var gameState = 'onSling';

var score = 0;

function preload() {
  backgroundImage = loadImage('sprites/bg.png');

  getBackgroundImage();
}

function setup() {
  createCanvas(1200400);

  engine = Engine.create();
  world = engine.world;

  //First Floor
  box1 = new Box(8003207070);
  box2 = new Box(10003207070);
  pig1 = new Pig1(910350);
  log1 = new Log(91027027090);

  //Second Floor
  box3 = new Box(8262107070);
  box4 = new Box(9902107070);
  pig2 = new Pig2(9101905050);
  log2 = new Log(91010030090);

  //Third Floor
  box5 = new Box(890507070);
  log3 = new Log(8803215030);
  log4 = new Log(95033150, -30);

  bird = new Bird(20050);

  platform = new Ground(150305300170);

  slingshot = new SlingShot(bird.body, { x: 200, y: 50 });

  ground = new Ground(600, height, 120020);
}

function draw() {
  if (backgroundImage) {
    background(backgroundImage);
  }

  Engine.update(engine);

  fill('white');
  textSize(30);
  text('Score: ' + score, width - 30050);

  box1.display();
  box2.display();
  pig1.display();
  pig1.Score();
  log1.display();

  box3.display();
  box4.display();
  pig2.display();
  pig2.Score();
  log2.display();

  box5.display();
  log3.display();
  log4.display();

  bird.display();
  platform.display();

  slingshot.display();

  ground.display();
}

function mouseDragged() {
  if (gameState != 'launch') {
    Matter.Body.setPosition(bird.body, { x: mouseX, y: mouseY });
  }
}

function mouseReleased() {
  slingshot.fly();
  gameState = 'onSling';
}

function keyPressed() {
  if (keyCode === 32 && (bird.body.speed < 1 || bird.body.speed > 50)) {
    slingshot.attach(bird.body);
    bird.tranjectory = [];
    Matter.Body.setPosition(bird.body, { x: 200, y: 50 });
  }
}

async function getBackgroundImage() {
  var response = await fetch(
    'http://worldtimeapi.org/api/timezone/Asia/Kolkata'
  );
  var responseJson = await response.json();

  var datetime = responseJson.datetime;
  var hour = datetime.slice(1113);

  if (hour >= 6 && hour <= 18) {
    bg = 'sprites/bg.png';
  } else {
    bg = 'sprites/bg2.jpg';
  }

  backgroundImage = loadImage(bg);

  console.log(hour);
}

 

0 Comments: