Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/melonjs/typescript-boilerplate

A simple TypeScript x Vite based boilerplate to create games with melonJS
https://github.com/melonjs/typescript-boilerplate

boilerplate canvas html5 melonjs template typescript vite webgl

Last synced: 3 months ago
JSON representation

A simple TypeScript x Vite based boilerplate to create games with melonJS

Awesome Lists containing this project

README

        

# melonJS TypeScript Vite Boilerplate
![melonJS Logo](https://github.com/melonjs/melonJS/raw/master/media/Banner/Banner%20-%20Billboard%20-%20Original%20Logo%20-%20horizontal.png)

[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://github.com/melonjs/es6-boilerplate/blob/master/LICENSE)

A simple TypeScript Vite based boilerplate to create games with [melonJS](https://github.com/melonjs/melonJS), built with :
- [melonJS 2](https://github.com/melonjs/melonJS)
- [TypeScript](https://www.typescriptlang.org) structure and semantic
- [Vite](https://vitejs.dev) ultra fast bundler
- Default transpiling to ES5 using target [option](./vite.config.ts) in the Vite config file
- Static Asset [management](https://www.npmjs.com/package/vite-plugin-static-copy) (used for the melonJS preloader)
- Favicon support using the [vite-plugin-favicons-inject](https://www.npmjs.com/package/vite-plugin-favicons-inject) plugin
- melonJS [debug plugin](https://github.com/melonjs/debug-plugin) to display stats on number of objects, memory usage, draw time, frame rate, etc...

## Prerequisites

Ensure you have [Node.js](http://nodejs.org/) installed, then install all the build dependencies in the folder where you cloned the repository :

$ [sudo] npm install

## Usage

- `npm run dev` to start the dev server on watch mode at `localhost:5173`.
- `npm run build` to generate a minified, production-ready build, in the `public` folder

if everything goes well, on running the dev server for the first time you should see this :
![boilerplate-helloworld](https://user-images.githubusercontent.com/4033090/134762171-6e1fac3d-8b41-4665-890b-daa217ba61dc.png)

## Folder structure

```none
src
└── data
│ ├── bgm
│ ├── fnt
| ├── img
| ├── map
| └── sfx
└── scripts
| ├── renderables
| └── stage
├── index.ts
├── index.css
├── index.html
├── manifest.ts
public
├── data
│ ├── bgm
│ ├── fnt
| ├── img
| ├── map
| └── sfx
├── build
| └── index-xxxxx.js
└── index.html
```

- `src`
- the root folder for your game source code
- The entry file is [index.ts](src/index.ts).
- [index.css](src/index.css) and [index.html](src/index.html) are default templates that can be customized
- [manifest.ts](src/manifest.ts) is a list of asset to be preloaded by melonJS
- `src/scripts`
- add your source classes here
- `src/data`
- where to add your game assets
- `public`
- where the production-ready build files will be copied/generated when using `npm run build`

Debug plugin
-------------------------------------------------------------------------------
The boilerplate include the melonJS plugin, and will automatically import and instantiate it when running under a development environement.

the Debug Panel is hidden by default and can be displayed using the "S" key, see [here](https://github.com/melonjs/debug-plugin/blob/main/README.md) for more details about the plugin.

Questions, need help ?
-------------------------------------------------------------------------------
If you need technical support, you can contact us through the following channels :
* Forums: with melonJS 2 we moved to a new discourse [forum](https://melonjs.discourse.group), but we can still also find the previous one [here](http://www.html5gamedevs.com/forum/32-melonjs/)
* Chat: come and chat with us on [discord](https://discord.gg/aur7JMk)
* we tried to keep our [wikipage](https://github.com/melonjs/melonJS/wiki) up-to-date with useful links, tutorials, and anything related melonJS.

Thank you and Final Note
-------------------------------------------------------------------------------
* Thank you @edmundg for providing a first version of this TypeScript x Vite boilerplate
* TypeScript support in melonJS is still a work in progress, if you notice any TS definition missing you can use `@ts-ignore` to ignore the error message for a specific line, please then please report it [here](https://github.com/melonjs/melonJS/issues)
* if you wish to request for a missing feature in the boileplate, open a ticket [here](https://github.com/melonjs/melonJS/issues) or submit a pull request