Skip to content
This repository has been archived by the owner on Jan 2, 2025. It is now read-only.
/ tower-builder Public archive
forked from iamkun/tower_game

πŸ’’ webxdc tower building game 🏒🏬🏦🏯🏰

License

Notifications You must be signed in to change notification settings

webxdc/tower-builder

Β 
Β 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

73 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Tower Builder Game

a tower building game using ES6 and Canvas.

this version is ready to use with webxdc as well as for usage in a browser (just open index.html locally), based on https://github.com/iamkun/tower_game

Download .xdc from Release Assets, attach to a Delta Chat group and share highscores there!

Online Demo

Game Rule

The following are the default game rule:

  • In every game player starts with 3 hp. Every time a Tower block is dropped player is deduct 1 hp; game ends when hp is depleted.

  • Player is rewarded with 25 point for every successful stacked blocks(Success). If a block is stacked pefectly (Perfect) on top of the previous one, then player rewarded with 50 points instead. Consecutive Perfects awards additional 25 points. Note: Each Success or Perfect constitutes a floor.

For example, the first Perfect awards 50 point. The second consecutive Perfect awards 75 points. The third consecutive Perfect awards 100 points. etc.

Building

to create a .xdc file that can be attached to a Delta Chat group, execute:

./create-xdc.sh

Customizing

To customize image and sound resource files directly replace the corresponding file under assets directory. To customize game rules modify the option object in index.html.

Use following table of option constants to complete customization of game rules.

Note: all constants are optionally included

Option Type Description
width number Width of game interface
height number Height of game interface
canvasId string DOM ID in Canvas
soundOn boolean If sound is on
successScore number Points awarded for success
perfectScore number Additional points awarded for perfect
hookSpeed function Speed of hook's movement
hookAngle function Angle of hook
landBlockSpeed function Speed of block sway
setGameScore function hook for current score
setGameSuccess function hook for number of current succesful game
setGameFailed function hook for number of current failed game

hookSpeed

Speed of hook's movement This function takes in two parameters, currentFloor and currentScore, and returns a speed value.

function(currentFloor, currentScore) {
  return number
}

hookAngle

Angle of hook This function takes in two parameters, currentFloor and currentScore, and returns a angle value.

function(currentFloor, currentScore) {
  return number
}

landBlockSpeed

Speed of block sway This function takes in two parameters, currentFloor and currentScore, and returns a speed value.

function(currentFloor, currentScore) {
  return number
}

setGameScore

hook for current score This function takes in one parameters, score, and sets currentScore to score.

function(score) {
  // your logic
}

setGameSuccess

hook for number of current succesful game This function takes in one parameters, score, and sets GameSuccess to successCount.

function(successCount) {
  // your logic
}

setGameFailed

hook for number of current failed game This function takes in one parameters, score, and sets GameFailed to failedCount.

function(failedCount) {
  // your logic
}

License

MIT license.

Music CC-BY-SA 3.0 Matthew Pablo, Caketown, https://opengameart.org/content/caketown-cuteplayful

About

πŸ’’ webxdc tower building game 🏒🏬🏦🏯🏰

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 82.5%
  • HTML 15.9%
  • Shell 1.6%