2013-04-09 20:32:19 -04:00
|
|
|
/*
|
|
|
|
* Paper.js - The Swiss Army Knife of Vector Graphics Scripting.
|
|
|
|
* http://paperjs.org/
|
|
|
|
*
|
|
|
|
* Copyright (c) 2011 - 2013, Juerg Lehni & Jonathan Puckey
|
|
|
|
* http://lehni.org/ & http://jonathanpuckey.com/
|
|
|
|
*
|
|
|
|
* Distributed under the MIT license. See LICENSE file for details.
|
|
|
|
*
|
|
|
|
* All rights reserved.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Formatter
|
2013-12-28 16:34:00 -05:00
|
|
|
* @class
|
2013-04-09 20:32:19 -04:00
|
|
|
* @private
|
|
|
|
*/
|
2013-12-28 16:34:00 -05:00
|
|
|
var Formatter = Base.extend(/** @lends Formatter# */{
|
2013-04-09 20:32:19 -04:00
|
|
|
/**
|
|
|
|
* @param {Number} [precision=5] the amount of fractional digits.
|
|
|
|
*/
|
|
|
|
initialize: function(precision) {
|
|
|
|
this.precision = precision || 5;
|
|
|
|
this.multiplier = Math.pow(10, this.precision);
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Utility function for rendering numbers as strings at a precision of
|
|
|
|
* up to the amount of fractional digits.
|
|
|
|
*
|
|
|
|
* @param {Number} num the number to be converted to a string
|
|
|
|
*/
|
|
|
|
number: function(val) {
|
2013-05-26 18:44:52 -04:00
|
|
|
// It would be nice to use Number#toFixed() instead, but it pads with 0,
|
|
|
|
// unecessarily consuming space.
|
2013-04-09 20:32:19 -04:00
|
|
|
return Math.round(val * this.multiplier) / this.multiplier;
|
|
|
|
},
|
|
|
|
|
|
|
|
point: function(val, separator) {
|
|
|
|
return this.number(val.x) + (separator || ',') + this.number(val.y);
|
|
|
|
},
|
|
|
|
|
|
|
|
size: function(val, separator) {
|
|
|
|
return this.number(val.width) + (separator || ',')
|
|
|
|
+ this.number(val.height);
|
|
|
|
},
|
|
|
|
|
|
|
|
rectangle: function(val, separator) {
|
|
|
|
return this.point(val, separator) + (separator || ',')
|
|
|
|
+ this.size(val, separator);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2013-10-10 17:09:18 -04:00
|
|
|
Formatter.instance = new Formatter();
|