Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@antv/g-ecs

Package Overview
Dependencies
Maintainers
55
Versions
16
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@antv/g-ecs

A simple ECS implement

  • 1.0.0-alpha.13
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
19
increased by90%
Maintainers
55
Weekly downloads
 
Created
Source

English | 简体中文

g-ecs

  • a simple ECS implement for G

Architecture

A typical ECS architecture(borrow from ecsy), we use Matcher instead of Query:

Usage

import { Container } from 'inversify';
import { Component, System, World, containerModule } from '@antv/g-ecs';

// create a container
const container = new Container();
// load ECS module
container.load(containerModule, true);

// create a world
const world = container.get(World);

// register components
class C1 extends Component {
    static tag = 'c1';
    p1: number;
}
class C2 extends Component {
    static tag = 'c2';
}
class C3 extends Component {
    static tag = 'c3';
}
world.registerComponent(C1).registerComponent(C2).registerComponent(C3);

// register systems
class S1 extends System {
    static tag = 's1';

    trigger() {
        return new Matcher().allOf(C1);
    }

    execute(entities: Entity[]) {
        entities.forEach((entity) => {
            const c1 = entity.getComponent(C1);
            c1.p1++;
        });
    }
}
world.registerSystem(S1);

// create an entity
const entity = world.createEntity();
entity.addComponent(C1, { p1: 2 }).addComponent(C2).addComponent(C3);

// make a loop
let lastTime = performance.now();
const run = () => {
    const time = performance.now();
    const delta = time - lastTime;
    // run all the systems
    world.execute(delta, time);

    lastTime = time;
    requestAnimationFrame(run);
};
run();

World

A world is the container of ECS. We get a world from container instead of creating it manually.

import { Container } from 'inversify';
import { World, containerModule } from '@antv/g-ecs';

// create a container
const container = new Container();
// load ECS module
container.load(containerModule, true);

// create a world
const world = container.get(World);

createEntity

Create a new entity:

const entity = world.createEntity();

registerComponent

class C1 extends Component {
    static tag = 'c1';
    p1: number;
}
class C2 extends Component {
    static tag = 'c2';
}
class C3 extends Component {
    static tag = 'c3';
}
world.registerComponent(C1).registerComponent(C2).registerComponent(C3);

registerSystem

class S1 extends System {
    static tag = 's1';

    trigger() {
        return new Matcher().allOf(C1);
    }

    execute(entities: Entity[]) {
        entities.forEach((entity) => {
            const c1 = entity.getComponent(C1);
            c1.p1++;
        });
    }
}
world.registerSystem(S1);

Entitiy

addComponent

We can add a component and its initial data to an entity:

entity.addComponent(C1, { p1: 2 }).addComponent(C2).addComponent(C3);

removeComponent

We can remove a component from an entity:

entity.removeComponent(C1);

Component

System

See also

Keywords

FAQs

Package last updated on 12 Nov 2021

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc