├── README.md ├── index.d.ts ├── index.js └── package.json /README.md: -------------------------------------------------------------------------------- 1 | ## What 2 | This is part of the [Phaser Component Library](https://github.com/SaFrMo/phaser-component-library). 3 | 4 | A percentage bar is a self-contained, self-updating bar with solid foreground and background colors. It can be attached to a sprite or created in a static location on the camera. 5 | 6 | ## How 7 | `npm install phaser-percent-bar` 8 | 9 | Then, in your Phaser source code 10 | 11 | ```js 12 | import HealthBar from 'phaser-percent-bar' 13 | 14 | // Sprite to track 15 | const sprite = this.game.add.sprite(0, 0, 'your-key') 16 | 17 | // Set health and max-health values 18 | sprite.health = 100 19 | sprite.maxHealth = 100 20 | 21 | // Create percentage bar as health bar 22 | const healthBar = this.game.add.existing(new HealthBar({ 23 | game: this.game, 24 | host: sprite 25 | })) 26 | ``` 27 | 28 | This will create a functioning, auto-updating health bar and attach it to the given sprite. When the sprite's health changes, the bar will update to reflect that. 29 | 30 | ## API 31 | 32 | ### `new PercentBar( { options } )` 33 | 34 | #### options 35 | 36 | ##### `bgSprite` 37 | 38 | Type: `string` 39 | 40 | Key to the desired sprite for the percent-bar background. Use `sprite` for setting this and `fgSprite` to the same sprite. 41 | 42 | ##### `bgTint` 43 | 44 | Type: `hex`
45 | Default: `0x00cc00` 46 | 47 | Hex value of the tint of the percentage bar's foreground (the bar itself). 48 | 49 | ##### `fgSprite` 50 | 51 | Type: `string` 52 | 53 | Key to the desired sprite for the percent bar itself. Use `sprite` for setting this and `bgSprite` to the same sprite. 54 | 55 | 56 | ##### `fgTint` 57 | 58 | Type: `hex`
59 | Default: `0x333333` 60 | Hex value of the tint of the percentage bar's background. 61 | 62 | ##### `game` 63 | 64 | Required
65 | Type: `Phaser.Game` 66 | 67 | Host game for the percent-bar. 68 | 69 | ##### `height` 70 | 71 | Type: `number`
72 | Default: `10` 73 | 74 | The height, in pixels, of the percentage bar. 75 | 76 | ##### `host` 77 | 78 | Required
79 | Type: `Phaser.Sprite` 80 | 81 | The parent sprite for this percentage bar. 82 | 83 | ##### `resize` 84 | 85 | Type: `boolean`
86 | Default: `false` 87 | 88 | If `false`, the bar will crop rather than growing or shrinking. If `true`, the bar will grow and shrink rather than cropping. 89 | 90 | ##### `sprite` 91 | 92 | Type: `string` 93 | 94 | Shortcut to setting both `bgSprite` and `fgSprite`. Key of the sprite to use as the percentage bar. 95 | 96 | ##### `watch` 97 | 98 | Type: `Object` 99 | 100 | The values that the percentage bar will represent. Accepts the following properties: 101 | 102 | * `host` - Object containing the value to watch (optional - default top-level `host`) 103 | * `value` - String with the name of the property to watch (optional - default `'health'`) 104 | * `max` - Number indicating the maximum value of the progress bar (optional - default `host.maxHealth`) 105 | 106 | Example implementation: 107 | 108 | ```js 109 | new PercentBar({ 110 | // ... 111 | watch: { 112 | host: hostSprite, 113 | value: 'health', 114 | max: 100 115 | } 116 | // ... 117 | }) 118 | ``` 119 | 120 | ##### `width` 121 | 122 | Type: `number`
123 | Default: `width` of `host` 124 | 125 | The width, in pixels, of the percentage bar. 126 | 127 | ##### `xOffset` 128 | 129 | Type: `number`
130 | Default: `0` 131 | 132 | Number of pixels to offset from the host sprite horizontally. 133 | 134 | ##### `yOffset` 135 | 136 | Type: `number`
137 | Default: `-25` 138 | 139 | Number of pixels to offset from the host sprite vertically. 140 | 141 | #### Methods 142 | 143 | ##### `hide()` 144 | 145 | Parameters: none 146 | 147 | Shortcut for `setAlpha(0)`. 148 | 149 | ##### `setAlpha( newAlpha )` 150 | 151 | Parameters: 152 | * `newAlpha` (number) - new alpha value for percent bar components 153 | 154 | Set health bar components to a given opacity. 155 | 156 | ##### `show()` 157 | 158 | Parameters: none 159 | 160 | Shortcut for `setAlpha(1)`. 161 | 162 | ## Versions 163 | 164 | * `1.1.5` - TypeScript definitions, tint bugfix (thanks @sohan) 165 | * `1.1.4` - Added show, hide, and setAlpha functions 166 | * `1.1.31` - Added defaults for `watch` and updated readme 167 | * `1.1.2` - Added xOffset 168 | * `1.1.0` - Automatically centers bar to host on X axis. Added custom sprite support. 169 | * `1.0.0` - First release 170 | -------------------------------------------------------------------------------- /index.d.ts: -------------------------------------------------------------------------------- 1 | declare module 'phaser-percent-bar' { 2 | export default class HealthBar { 3 | constructor (opts: { 4 | game: Phaser.Game, 5 | host: Phaser.Sprite, 6 | bgSprite?: string, 7 | bgTint?: number, 8 | fgSprite?: string, 9 | fgTint?: number, 10 | frame?: any, 11 | height?: number, 12 | key?: string, 13 | resize?: boolean, 14 | sprite?: Phaser.Sprite, 15 | watch?: { host: Phaser.Sprite, value: string, max: number }, 16 | width?: number, 17 | x?: number, 18 | xOffset?: number, 19 | y?: number, 20 | yOffset?: number, 21 | }); 22 | 23 | hide(): void; 24 | 25 | setAlpha(newAlpha: number): void; 26 | 27 | show(): void; 28 | } 29 | } -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | import Phaser from 'phaser' 2 | 3 | export default class extends Phaser.Sprite { 4 | constructor (opts) { 5 | super(opts.game, opts.x || 0, opts.y || 0, opts.key || '', opts.frame || '') 6 | 7 | // add 1x1 white pixel to cache if necessary 8 | if (!opts.game.cache.checkImageKey('white1x1pixel')) { 9 | // loads 1x1 white gif from data URI 10 | opts.game.load.image('white1x1pixel', '') 11 | opts.game.load.onLoadComplete.add(() => this.runCreation(opts)) 12 | opts.game.load.start() 13 | } else { 14 | this.runCreation(opts) 15 | } 16 | } 17 | 18 | // this has to be in a separate function so that the white1x1pixel sprite can load asynchronously 19 | runCreation (opts) { 20 | // set sprites, if applicable 21 | if (!opts.bgSprite && opts.sprite) { 22 | opts.bgSprite = opts.sprite 23 | opts.fgSprite = opts.sprite 24 | } 25 | 26 | // Prep watch, if unset 27 | if (!opts.watch) { 28 | opts.watch = {} 29 | } 30 | 31 | // Save watch.host, if unset 32 | if (opts.watch && !opts.watch.host) { 33 | opts.watch.host = opts.host 34 | } 35 | 36 | // Save width 37 | let width = 0 38 | if (opts.bgSprite) { 39 | // Look for the background sprite's width first 40 | width = this.game.cache.getImage(opts.bgSprite).width 41 | // Let the user override with the `width` option 42 | width = opts.width || width 43 | } else { 44 | width = opts.width || opts.host.width 45 | } 46 | 47 | // Save height 48 | let height = 0 49 | if (opts.bgSprite) { 50 | // Look for the background sprite's height first 51 | height = this.game.cache.getImage(opts.bgSprite).height 52 | // Let the user override with the `width` option 53 | height = opts.height || height 54 | } else { 55 | height = opts.height || 10 56 | } 57 | 58 | // Background to progress bar 59 | const x = (opts.host.width / 2 - width / 2) + (opts.xOffset || 0) 60 | this.bg = opts.host.addChild(this.game.make.sprite(x, opts.hasOwnProperty('yOffset') ? opts.yOffset : -25, opts.bgSprite || 'white1x1pixel')) 61 | this.bg.width = width 62 | this.bg.height = height 63 | this.bg.tint = opts.hasOwnProperty('bgTint') ? opts.bgTint : 0x333333 64 | 65 | // Foreground 66 | let fgSprite = opts.fgSprite || 'white1x1pixel' 67 | this.bar = opts.host.addChild(this.game.make.sprite(x, opts.hasOwnProperty('yOffset') ? opts.yOffset : -25, fgSprite)) 68 | this.bar.width = width 69 | this.bar.height = height 70 | this.bar.tint = opts.hasOwnProperty('fgTint') ? opts.fgTint : 0x00cc00 71 | 72 | // Crop 73 | this.cropRect = new Phaser.Rectangle(0, 0, width, height) 74 | 75 | // Save options 76 | this.opts = opts 77 | } 78 | 79 | show(){ 80 | this.setAlpha(1) 81 | } 82 | 83 | hide(){ 84 | this.setAlpha(0) 85 | } 86 | 87 | setAlpha(newAlpha){ 88 | this.bg.alpha = this.bar.alpha = newAlpha 89 | } 90 | 91 | update () { 92 | super.update() 93 | if (this.opts && this.opts.watch) { 94 | const newWidth = this.bg.width * (this.opts.watch.host[this.opts.watch.value || 'health'] / (this.opts.watch.max || this.opts.watch.host.maxHealth)) 95 | 96 | if (this.opts.resize || (!this.opts.bgSprite && !this.opts.fgSprite)) { 97 | this.bar.width = newWidth 98 | } else { 99 | this.cropRect.width = newWidth 100 | this.bar.crop(this.cropRect) 101 | } 102 | } 103 | } 104 | } 105 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "phaser-percent-bar", 3 | "version": "1.1.5", 4 | "description": "This is part of the [Phaser Component Library](https://github.com/SaFrMo/phaser-component-library).", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "repository": { 10 | "type": "git", 11 | "url": "git+https://github.com/safrmo/phaser-percent-bar.git" 12 | }, 13 | "keywords": ["phaser", "component"], 14 | "author": "", 15 | "license": "ISC", 16 | "bugs": { 17 | "url": "https://github.com/safrmo/phaser-percent-bar/issues" 18 | }, 19 | "homepage": "https://github.com/safrmo/phaser-percent-bar#readme" 20 | } 21 | --------------------------------------------------------------------------------