“This is the 14th day of my participation in the Gwen Challenge in November. Check out the details: The Last Gwen Challenge in 2021.”

Although I almost don’t play games anymore, games are the dream of every big boy. When I was a child, I often had to wait for one or two hours to play games. I remember that I used to draw games on paper to play, and I still remember those things clearly. This is also one of the motives of coding today. There is no purpose, but it is only for a little bit of my childhood. Suddenly I don’t know what the right word is.

The p5.js API for drawing libraries on Canvas is easy to understand, but it may feel a bit unfamiliar to the physical system simulation library, so let’s stop and briefly explain how to use Matterjs.

The Matter.Engine module contains methods to create and manipulate an Engine. The engine is a controller that manages the more physical simulation world.

engine = Engine.create();
Copy the code

To create a new engine, the option argument is an object. If no option object is specified, the engine is created using the default value of the engine’s properties.

Create a rigid body model with a rectangular shell. The option argument is an object that overrides the default property value by passing in the option object’s property value, returning a Matter.Body.

The matter.body module contains methods to create and manipulate the Body model. Matter.Body is a rigid Body that can be simulated by Matter.Engine. The Matter.Bodies module acts like a factory class and can be thought of as a factory for creating Bodies such as rectangles, circles, and other polygons.

Matter.Bodies.[circle](x, y, radius, [options], [maxSides])
Copy the code
Matter.Bodies.[rectangle](x, y, width, height, [options])
Copy the code

Create circles and Rectangle rigidbodies using Matter.Bodies

Matter.Body.[rotate](body,rotation,option)

World.add(world,this.body)

The constraint

mConstraint = MouseConstraint.create(engine,options);
Composite.add(world,mConstraint);
Copy the code

The Matter.MouseConstraint module contains methods for creating mouse constraints. Mouse constraints are used to allow users to interact, providing the ability to move objects with a mouse or touch.

The Matter.Mouse module contains methods for creating and manipulating Mouse input.

Sort code

All usage should be migrated to the corresponding function on matter.composite. For example, world.add (World, body) now becomes comp. Add (World, body).

class Bird{
    constructor(x,y,r){
        this.body =Matter.Bodies.circle(x, y, r);
        Composite.add(world,this.body);
        this.r = r;
    }

    show(){
        const pos = this.body.position;
        const angle = this.body.angle;
        push();
        translate(pos.x,pos.y);
        rotate(angle);
        fill(255);
        rectMode(CENTER);
        circle(0.0.this.r); pop(); }}Copy the code