Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/oguzhanumutlu/physics-engine

Physics engine that I made with the things we learned in school
https://github.com/oguzhanumutlu/physics-engine

canvas engine javascript js newton physics physics-engine render web

Last synced: 15 days ago
JSON representation

Physics engine that I made with the things we learned in school

Awesome Lists containing this project

README

        

# physics-engine

Physics engine that I made with the stuff we learned in school

Used lots of trig functions and "Newton"s equations

[Click to view old preview](https://oguzhanumutlu.github.io/physics-engine/legacy)

[Click to view new preview](https://oguzhanumutlu.github.io/physics-engine)

# Preview

![](./screenshots/ss.png)

# Importing

Just add this to your HTML to import it!

```html

```

# Example

## Add a canvas to your body, so you can use it for rendering

```html

```

## Initializing physics engine

```html

window.Phygic.then(Phygic => {
// your code goes here!
console.log("Phygic has been loaded! ", Phygic);
});

```

### Or just use await it!

```html

await window.Phygic;
// your code goes here!
console.log("Phygic has been loaded! ", Phygic);

```

## Getting canvas

```js
const canvas = document.querySelector("canvas");
```

## Creating a physics world

Note: If you don't want the renderer you don't have to enter the canvas element

```js
const world = new Phygic.World(canvas);
```

## Rendering

✨ Just run this function and done! ✨

```js
world.createAnimators();
```

## Adding camera movement, tile dragging etc.

✨ Again, just one line! ✨

```js
world.addHelpers();
```

## Adding a box

✨ Still one line! ✨

```js
new Phygic.Tile(50, 0, world);
```

## Adding a static tile so our box doesn't fall to the nothingness

✨ You get the idea everything is one line. ✨

```js
new Phygic.Tile(50, 500, {world, isStatic: true});
```

## Final product:

[Preview](https://oguzhanumutlu.github.io/physics-engine/example.html)

```html

window.Phygic.then(Phygic => {
const canvas = document.querySelector("canvas");

const world = new Phygic.World(canvas);

world.createAnimators();

world.addHelpers();

new Phygic.Tile(50, 0, world);

new Phygic.Tile(50, 500, {world, isStatic: true});
});

```