Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/zeh/key-action-binder
A keyboard/gamepad binder for easier game input in TypeScript and JavaScript
https://github.com/zeh/key-action-binder
Last synced: about 2 months ago
JSON representation
A keyboard/gamepad binder for easier game input in TypeScript and JavaScript
- Host: GitHub
- URL: https://github.com/zeh/key-action-binder
- Owner: zeh
- License: mit
- Archived: true
- Created: 2015-04-18T20:23:05.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2015-09-27T20:57:18.000Z (over 9 years ago)
- Last Synced: 2024-04-26T16:46:58.097Z (9 months ago)
- Language: TypeScript
- Size: 453 KB
- Stars: 3
- Watchers: 4
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-actionscript-sorted - key-action-binder - A keyboard/gamepad binder for easier game input in ActionScript (Video Games / Game Engine)
README
[![Build Status](https://travis-ci.org/zeh/key-action-binder.ts.svg?branch=master)](https://travis-ci.org/zeh/key-action-binder.ts)
# KeyActionBinder
KeyActionBinder aims to provide universal game input control for both keyboard and game controllers in JavaScript. It works independently of the game engine, the browser, or the hardware platform it is running in.
## Goals
* Having a clear, easy to use interface.
* Minimizing the amount of support logic needed in a game loop.
* Providing support for typical game functionality such as button press time tolerance, dead zone protection, and others.
* Requiring no device or control references to store.
* Working around browser limitations where appropriate (and possible).
* Self-containment and independence from any other system, framework, or game engine.
* Auto-management of gamepad order for sensible party/multi-player support.## Quick usage
Include one of the [build files](https://github.com/zeh/key-action-binder.ts/tree/master/build):
Create a `KeyActionBinder` instance:
var binder = new KeyActionBinder();
Setup actions with as many bindings as you want:
binder.action("move-left")
.bind(KeyActionBinder.KeyCodes.LEFT)
.bind(KeyActionBinder.GamepadButtons.DPAD_LEFT);binder.action("move-right")
.bind(KeyActionBinder.KeyCodes.RIGHT)
.bind(KeyActionBinder.GamepadButtons.DPAD_RIGHT);binder.action("jump")
.bind(KeyActionBinder.KeyCodes.SPACE)
.bind(KeyActionBinder.GamepadButtons.ACTION_DOWN);Then, evaluate the actions inside your game loop:
function myGameLoop() {
// Check whether the player should move
if (binder.action("move-left").activated) {
// (...code for moving left...)
} else if (binder.action("move-right").activated) {
// (...code for moving right...)
}if (playerIsOnGround && binder.action("jump").activated) {
// (...code for performing jump...)
}
}Read more about the project in the [wiki](https://github.com/zeh/key-action-binder.ts/wiki).