This is a documentation for Board Game Arena: play board games online !
Counter: Difference between revisions
Jump to navigation
Jump to search
Tilalilalou (talk | contribs) No edit summary |
|||
Line 3: | Line 3: | ||
== Dependency == | == Dependency == | ||
Don't forget to add | Don't forget to add '''ebg/counter''' as a dependency: | ||
// in | // in your game js | ||
define([ | define([ | ||
"dojo","dojo/_base/declare", | "dojo","dojo/_base/declare", |
Revision as of 01:59, 1 August 2019
Dependency
Don't forget to add ebg/counter as a dependency:
// in your game js define([ "dojo","dojo/_base/declare", "ebg/core/gamegui", "ebg/counter" /// <==== HERE],
Setup a counter
player.handSizeCounter = new ebg.counter(); player.handSizeCounter.create('hand_size_player_' + player_id);
Update counter
player.handSizeCounter.setValue(player.handSize);
Players panels
Adding stuff to player's panel
First, create a new JS template string in your template (tpl) file.
From the Gomoku example:
var jstpl_player_board = '\<div class="cp_board">\ <div id="stoneicon_p${id}" class="gmk_stoneicon gmk_stoneicon_${color}"></div><span id="stonecount_p${id}">0</span>\ </div>';
Then, add this piece of code in the setup function of your JS file to add this template to each player panel:
// Setting up player boards for( var player_id in gamedatas.players ) { var player = gamedatas.players[player_id]; // Setting up players boards if needed var player_board_div = $('player_board_'+player_id); dojo.place( this.format_block('jstpl_player_board', player ), player_board_div ); }
Often, you have to distinguish between the current player and other players. In this case, create another JS template (ex: jstpl_otherplayer_board) and use it where "player_id" is different than "this.player_id".