From ef3a0f77b7a0e7cdfd71249538638249f64344ed Mon Sep 17 00:00:00 2001 From: tristan-c Date: Fri, 23 Nov 2012 10:48:39 +0100 Subject: [PATCH] add external rendering function for displayed value --- justgage.js | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/justgage.js b/justgage.js index e9965b7..0b7a49c 100644 --- a/justgage.js +++ b/justgage.js @@ -78,6 +78,10 @@ JustGage = function(config) { // number of decimal places for our human friendly number to contain humanFriendlyDecimal : (config.humanFriendlyDecimal) ? config.humanFriendlyDecimal : 0, + // textRenderer: func + // function applied before rendering text + textRenderer : (config.textRenderer) ? config.textRenderer : null, + // gaugeWidthScale : float // width of the gauge element gaugeWidthScale : (config.gaugeWidthScale) ? config.gaugeWidthScale : 1.0, @@ -414,8 +418,12 @@ JustGage = function(config) { this.txtTitle.id = this.config.id+"-txttitle"; // value - if( this.config.humanFriendly ) this.originalValue = humanFriendlyNumber( this.originalValue, this.config.humanFriendlyDecimal ); - this.txtValue = this.canvas.text(this.params.valueX, this.params.valueY, this.originalValue + this.config.symbol); + if(this.config.textRenderer) + this.originalValue = this.config.textRenderer(this.originalValue); + else if( this.config.humanFriendly ) + this.originalValue = humanFriendlyNumber( this.originalValue, this.config.humanFriendlyDecimal ) + this.config.symbol; + + this.txtValue = this.canvas.text(this.params.valueX, this.params.valueY, this.originalValue); this.txtValue. attr({ "font-size":this.params.valueFontSize, "font-weight":"bold", @@ -493,8 +501,13 @@ JustGage.prototype.refresh = function(val) { if (val < this.config.min) {val = this.config.min;} var color = getColorForPercentage((val - this.config.min) / (this.config.max - this.config.min), this.config.levelColors, this.config.levelColorsGradient); - if( this.config.humanFriendly ) displayVal = humanFriendlyNumber( displayVal, this.config.humanFriendlyDecimal ); - this.canvas.getById(this.config.id+"-txtvalue").attr({"text":displayVal + this.config.symbol}); + + if(this.config.textRenderer) + displayVal = this.config.textRenderer(displayVal); + else if( this.config.humanFriendly ) + displayVal = humanFriendlyNumber( displayVal, this.config.humanFriendlyDecimal ) + this.config.symbol; + + this.canvas.getById(this.config.id+"-txtvalue").attr({"text":displayVal}); this.canvas.getById(this.config.id+"-level").animate({pki: [val, this.config.min, this.config.max, this.params.widgetW, this.params.widgetH, this.params.dx, this.params.dy, this.config.gaugeWidthScale, this.config.donut], "fill":color}, this.config.refreshAnimationTime, this.config.refreshAnimationType); this.config.value = val; originalVal = null;