Commit eed3c9f6796d09b299da70cd306e50e3f375ade5
0 parents
Exists in
master
and in
11 other branches
first file
Signed-off-by: tom200e <tom200e@hotmail.com>
Showing
200 changed files
with
21301 additions
and
0 deletions
Show diff stats
Too many changes.
To preserve performance only 100 of 200 files displayed.
amcharts/amcharts.js
File was created | 1 | if(!AmCharts)var AmCharts={themes:{},maps:{},inheriting:{},charts:[],onReadyArray:[],useUTC:!1,updateRate:40,uid:0,lang:{},translations:{},mapTranslations:{}}; | |
2 | AmCharts.Class=function(a){var b=function(){arguments[0]!==AmCharts.inheriting&&(this.events={},this.construct.apply(this,arguments))};a.inherits?(b.prototype=new a.inherits(AmCharts.inheriting),b.base=a.inherits.prototype,delete a.inherits):(b.prototype.createEvents=function(){for(var a=0,b=arguments.length;a<b;a++)this.events[arguments[a]]=[]},b.prototype.listenTo=function(a,b,c){this.removeListener(a,b,c);a.events[b].push({handler:c,scope:this})},b.prototype.addListener=function(a,b,c){this.removeListener(this, | ||
3 | a,b);this.events[a].push({handler:b,scope:c})},b.prototype.removeListener=function(a,b,c){if(a&&a.events)for(a=a.events[b],b=a.length-1;0<=b;b--)a[b].handler===c&&a.splice(b,1)},b.prototype.fire=function(a,b){for(var c=this.events[a],g=0,h=c.length;g<h;g++){var k=c[g];k.handler.call(k.scope,b)}});for(var c in a)b.prototype[c]=a[c];return b};AmCharts.addChart=function(a){AmCharts.charts.push(a)};AmCharts.removeChart=function(a){for(var b=AmCharts.charts,c=b.length-1;0<=c;c--)b[c]==a&&b.splice(c,1)}; | ||
4 | AmCharts.isModern=!0;AmCharts.getIEVersion=function(){var a=0;if("Microsoft Internet Explorer"==navigator.appName){var b=navigator.userAgent,c=/MSIE ([0-9]{1,}[.0-9]{0,})/;null!=c.exec(b)&&(a=parseFloat(RegExp.$1))}else"Netscape"==navigator.appName&&(b=navigator.userAgent,c=/Trident\/.*rv:([0-9]{1,}[.0-9]{0,})/,null!=c.exec(b)&&(a=parseFloat(RegExp.$1)));return a}; | ||
5 | AmCharts.applyLang=function(a){var b=AmCharts.translations;b&&(a=b[a])&&(AmCharts.lang=a,a.monthNames&&(AmCharts.dayNames=a.dayNames,AmCharts.shortDayNames=a.shortDayNames,AmCharts.monthNames=a.monthNames,AmCharts.shortMonthNames=a.shortMonthNames))};AmCharts.IEversion=AmCharts.getIEVersion();9>AmCharts.IEversion&&0<AmCharts.IEversion&&(AmCharts.isModern=!1,AmCharts.isIE=!0);AmCharts.dx=0;AmCharts.dy=0; | ||
6 | if(document.addEventListener||window.opera)AmCharts.isNN=!0,AmCharts.isIE=!1,AmCharts.dx=.5,AmCharts.dy=.5;document.attachEvent&&(AmCharts.isNN=!1,AmCharts.isIE=!0,AmCharts.isModern||(AmCharts.dx=0,AmCharts.dy=0));window.chrome&&(AmCharts.chrome=!0);AmCharts.handleResize=function(){for(var a=AmCharts.charts,b=0;b<a.length;b++){var c=a[b];c&&c.div&&c.handleResize()}};AmCharts.handleMouseUp=function(a){for(var b=AmCharts.charts,c=0;c<b.length;c++){var d=b[c];d&&d.handleReleaseOutside(a)}}; | ||
7 | AmCharts.handleMouseMove=function(a){for(var b=AmCharts.charts,c=0;c<b.length;c++){var d=b[c];d&&d.handleMouseMove(a)}};AmCharts.resetMouseOver=function(){for(var a=AmCharts.charts,b=0;b<a.length;b++){var c=a[b];c&&(c.mouseIsOver=!1)}};AmCharts.ready=function(a){AmCharts.onReadyArray.push(a)};AmCharts.handleLoad=function(){AmCharts.isReady=!0;for(var a=AmCharts.onReadyArray,b=0;b<a.length;b++){var c=a[b];isNaN(AmCharts.processDelay)?c():setTimeout(c,AmCharts.processDelay*b)}}; | ||
8 | AmCharts.getUniqueId=function(){AmCharts.uid++;return"AmChartsEl-"+AmCharts.uid};AmCharts.isNN&&(document.addEventListener("mousemove",AmCharts.handleMouseMove,!0),window.addEventListener("resize",AmCharts.handleResize,!0),document.addEventListener("mouseup",AmCharts.handleMouseUp,!0),window.addEventListener("load",AmCharts.handleLoad,!0)); | ||
9 | AmCharts.isIE&&(document.attachEvent("onmousemove",AmCharts.handleMouseMove),window.attachEvent("onresize",AmCharts.handleResize),document.attachEvent("onmouseup",AmCharts.handleMouseUp),window.attachEvent("onload",AmCharts.handleLoad)); | ||
10 | AmCharts.clear=function(){var a=AmCharts.charts;if(a)for(var b=0;b<a.length;b++)a[b].clear();AmCharts.charts=null;AmCharts.isNN&&(document.removeEventListener("mousemove",AmCharts.handleMouseMove,!0),window.removeEventListener("resize",AmCharts.handleResize,!0),document.removeEventListener("mouseup",AmCharts.handleMouseUp,!0),window.removeEventListener("load",AmCharts.handleLoad,!0));AmCharts.isIE&&(document.detachEvent("onmousemove",AmCharts.handleMouseMove),window.detachEvent("onresize",AmCharts.handleResize), | ||
11 | document.detachEvent("onmouseup",AmCharts.handleMouseUp),window.detachEvent("onload",AmCharts.handleLoad))}; | ||
12 | AmCharts.makeChart=function(a,b,c){var d=b.type,e=b.theme;AmCharts.isString(e)&&(e=AmCharts.themes[e],b.theme=e);var f;switch(d){case "serial":f=new AmCharts.AmSerialChart(e);break;case "xy":f=new AmCharts.AmXYChart(e);break;case "pie":f=new AmCharts.AmPieChart(e);break;case "radar":f=new AmCharts.AmRadarChart(e);break;case "gauge":f=new AmCharts.AmAngularGauge(e);break;case "funnel":f=new AmCharts.AmFunnelChart(e);break;case "map":f=new AmCharts.AmMap(e);break;case "stock":f=new AmCharts.AmStockChart(e)}AmCharts.extend(f, | ||
13 | b);AmCharts.isReady?isNaN(c)?f.write(a):setTimeout(function(){AmCharts.realWrite(f,a)},c):AmCharts.ready(function(){isNaN(c)?f.write(a):setTimeout(function(){AmCharts.realWrite(f,a)},c)});return f};AmCharts.realWrite=function(a,b){a.write(b)};AmCharts.toBoolean=function(a,b){if(void 0===a)return b;switch(String(a).toLowerCase()){case "true":case "yes":case "1":return!0;case "false":case "no":case "0":case null:return!1;default:return Boolean(a)}};AmCharts.removeFromArray=function(a,b){var c;for(c=a.length-1;0<=c;c--)a[c]==b&&a.splice(c,1)};AmCharts.getDecimals=function(a){var b=0;isNaN(a)||(a=String(a),-1!=a.indexOf("e-")?b=Number(a.split("-")[1]):-1!=a.indexOf(".")&&(b=a.split(".")[1].length));return b}; | ||
14 | AmCharts.wrappedText=function(a,b,c,d,e,f,g,h,k){var l=AmCharts.text(a,b,c,d,e,f,g),m="\n";AmCharts.isModern||(m="<br>");if(10<k)return l;if(l){var n=l.getBBox();if(n.width>h){l.remove();for(var l=[],p=0;-1<(index=b.indexOf(" ",p));)l.push(index),p=index+1;for(var q=Math.round(b.length/2),r=1E3,s,p=0;p<l.length;p++){var v=Math.abs(l[p]-q);v<r&&(s=l[p],r=v)}if(isNaN(s)){h=Math.ceil(n.width/h);for(p=1;p<h;p++)s=Math.round(b.length/h*p),b=b.substr(0,s)+m+b.substr(s);return AmCharts.text(a,b,c,d,e,f, | ||
15 | g)}b=b.substr(0,s)+m+b.substr(s+1);return AmCharts.wrappedText(a,b,c,d,e,f,g,h,k+1)}return l}};AmCharts.getStyle=function(a,b){var c="";document.defaultView&&document.defaultView.getComputedStyle?c=document.defaultView.getComputedStyle(a,"").getPropertyValue(b):a.currentStyle&&(b=b.replace(/\-(\w)/g,function(a,b){return b.toUpperCase()}),c=a.currentStyle[b]);return c};AmCharts.removePx=function(a){if(void 0!=a)return Number(a.substring(0,a.length-2))}; | ||
16 | AmCharts.getURL=function(a,b){if(a)if("_self"!=b&&b)if("_top"==b&&window.top)window.top.location.href=a;else if("_parent"==b&&window.parent)window.parent.location.href=a;else{var c=document.getElementsByName(b)[0];c?c.src=a:window.open(a)}else window.location.href=a};AmCharts.ifArray=function(a){return a&&0<a.length?!0:!1};AmCharts.callMethod=function(a,b){var c;for(c=0;c<b.length;c++){var d=b[c];if(d){if(d[a])d[a]();var e=d.length;if(0<e){var f;for(f=0;f<e;f++){var g=d[f];if(g&&g[a])g[a]()}}}}}; | ||
17 | AmCharts.toNumber=function(a){return"number"==typeof a?a:Number(String(a).replace(/[^0-9\-.]+/g,""))};AmCharts.toColor=function(a){if(""!==a&&void 0!==a)if(-1!=a.indexOf(",")){a=a.split(",");var b;for(b=0;b<a.length;b++){var c=a[b].substring(a[b].length-6,a[b].length);a[b]="#"+c}}else a=a.substring(a.length-6,a.length),a="#"+a;return a}; | ||
18 | AmCharts.toCoordinate=function(a,b,c){var d;void 0!==a&&(a=String(a),c&&c<b&&(b=c),d=Number(a),-1!=a.indexOf("!")&&(d=b-Number(a.substr(1))),-1!=a.indexOf("%")&&(d=b*Number(a.substr(0,a.length-1))/100));return d};AmCharts.fitToBounds=function(a,b,c){a<b&&(a=b);a>c&&(a=c);return a};AmCharts.isDefined=function(a){return void 0===a?!1:!0};AmCharts.stripNumbers=function(a){return a.replace(/[0-9]+/g,"")};AmCharts.roundTo=function(a,b){if(0>b)return a;var c=Math.pow(10,b);return Math.round(a*c)/c}; | ||
19 | AmCharts.toFixed=function(a,b){var c=String(Math.round(a*Math.pow(10,b)));if(0<b){var d=c.length;if(d<b){var e;for(e=0;e<b-d;e++)c="0"+c}d=c.substring(0,c.length-b);""===d&&(d=0);return d+"."+c.substring(c.length-b,c.length)}return String(c)}; | ||
20 | AmCharts.formatDuration=function(a,b,c,d,e,f){var g=AmCharts.intervals,h=f.decimalSeparator;if(a>=g[b].contains){var k=a-Math.floor(a/g[b].contains)*g[b].contains;"ss"==b&&(k=AmCharts.formatNumber(k,f),1==k.split(h)[0].length&&(k="0"+k));("mm"==b||"hh"==b)&&10>k&&(k="0"+k);c=k+""+d[b]+""+c;a=Math.floor(a/g[b].contains);b=g[b].nextInterval;return AmCharts.formatDuration(a,b,c,d,e,f)}"ss"==b&&(a=AmCharts.formatNumber(a,f),1==a.split(h)[0].length&&(a="0"+a));("mm"==b||"hh"==b)&&10>a&&(a="0"+a);c=a+""+ | ||
21 | d[b]+""+c;if(g[e].count>g[b].count)for(a=g[b].count;a<g[e].count;a++)b=g[b].nextInterval,"ss"==b||"mm"==b||"hh"==b?c="00"+d[b]+""+c:"DD"==b&&(c="0"+d[b]+""+c);":"==c.charAt(c.length-1)&&(c=c.substring(0,c.length-1));return c}; | ||
22 | AmCharts.formatNumber=function(a,b,c,d,e){a=AmCharts.roundTo(a,b.precision);isNaN(c)&&(c=b.precision);var f=b.decimalSeparator;b=b.thousandsSeparator;var g;g=0>a?"-":"";a=Math.abs(a);var h=String(a),k=!1;-1!=h.indexOf("e")&&(k=!0);0<=c&&!k&&(h=AmCharts.toFixed(a,c));var l="";if(k)l=h;else{var h=h.split("."),k=String(h[0]),m;for(m=k.length;0<=m;m-=3)l=m!=k.length?0!==m?k.substring(m-3,m)+b+l:k.substring(m-3,m)+l:k.substring(m-3,m);void 0!==h[1]&&(l=l+f+h[1]);void 0!==c&&0<c&&"0"!=l&&(l=AmCharts.addZeroes(l, | ||
23 | f,c))}l=g+l;""===g&&!0===d&&0!==a&&(l="+"+l);!0===e&&(l+="%");return l};AmCharts.addZeroes=function(a,b,c){a=a.split(b);void 0===a[1]&&0<c&&(a[1]="0");return a[1].length<c?(a[1]+="0",AmCharts.addZeroes(a[0]+b+a[1],b,c)):void 0!==a[1]?a[0]+b+a[1]:a[0]}; | ||
24 | AmCharts.scientificToNormal=function(a){var b;a=String(a).split("e");var c;if("-"==a[1].substr(0,1)){b="0.";for(c=0;c<Math.abs(Number(a[1]))-1;c++)b+="0";b+=a[0].split(".").join("")}else{var d=0;b=a[0].split(".");b[1]&&(d=b[1].length);b=a[0].split(".").join("");for(c=0;c<Math.abs(Number(a[1]))-d;c++)b+="0"}return b}; | ||
25 | AmCharts.toScientific=function(a,b){if(0===a)return"0";var c=Math.floor(Math.log(Math.abs(a))*Math.LOG10E);Math.pow(10,c);mantissa=String(mantissa).split(".").join(b);return String(mantissa)+"e"+c};AmCharts.randomColor=function(){return"#"+("00000"+(16777216*Math.random()<<0).toString(16)).substr(-6)}; | ||
26 | AmCharts.hitTest=function(a,b,c){var d=!1,e=a.x,f=a.x+a.width,g=a.y,h=a.y+a.height,k=AmCharts.isInRectangle;d||(d=k(e,g,b));d||(d=k(e,h,b));d||(d=k(f,g,b));d||(d=k(f,h,b));d||!0===c||(d=AmCharts.hitTest(b,a,!0));return d};AmCharts.isInRectangle=function(a,b,c){return a>=c.x-5&&a<=c.x+c.width+5&&b>=c.y-5&&b<=c.y+c.height+5?!0:!1};AmCharts.isPercents=function(a){if(-1!=String(a).indexOf("%"))return!0}; | ||
27 | AmCharts.findPosX=function(a){var b=a,c=a.offsetLeft;if(a.offsetParent){for(;a=a.offsetParent;)c+=a.offsetLeft;for(;(b=b.parentNode)&&b!=document.body;)c-=b.scrollLeft||0}return c};AmCharts.findPosY=function(a){var b=a,c=a.offsetTop;if(a.offsetParent){for(;a=a.offsetParent;)c+=a.offsetTop;for(;(b=b.parentNode)&&b!=document.body;)c-=b.scrollTop||0}return c};AmCharts.findIfFixed=function(a){if(a.offsetParent)for(;a=a.offsetParent;)if("fixed"==AmCharts.getStyle(a,"position"))return!0;return!1}; | ||
28 | AmCharts.findIfAuto=function(a){return a.style&&"auto"==AmCharts.getStyle(a,"overflow")?!0:a.parentNode?AmCharts.findIfAuto(a.parentNode):!1};AmCharts.findScrollLeft=function(a,b){a.scrollLeft&&(b+=a.scrollLeft);return a.parentNode?AmCharts.findScrollLeft(a.parentNode,b):b};AmCharts.findScrollTop=function(a,b){a.scrollTop&&(b+=a.scrollTop);return a.parentNode?AmCharts.findScrollTop(a.parentNode,b):b}; | ||
29 | AmCharts.formatValue=function(a,b,c,d,e,f,g,h){if(b){void 0===e&&(e="");var k;for(k=0;k<c.length;k++){var l=c[k],m=b[l];void 0!==m&&(m=f?AmCharts.addPrefix(m,h,g,d):AmCharts.formatNumber(m,d),a=a.replace(new RegExp("\\[\\["+e+""+l+"\\]\\]","g"),m))}}return a};AmCharts.formatDataContextValue=function(a,b){if(a){var c=a.match(/\[\[.*?\]\]/g),d;for(d=0;d<c.length;d++){var e=c[d],e=e.substr(2,e.length-4);void 0!==b[e]&&(a=a.replace(new RegExp("\\[\\["+e+"\\]\\]","g"),b[e]))}}return a}; | ||
30 | AmCharts.massReplace=function(a,b){for(var c in b)if(b.hasOwnProperty(c)){var d=b[c];void 0===d&&(d="");a=a.replace(c,d)}return a};AmCharts.cleanFromEmpty=function(a){return a.replace(/\[\[[^\]]*\]\]/g,"")}; | ||
31 | AmCharts.addPrefix=function(a,b,c,d,e){var f=AmCharts.formatNumber(a,d),g="",h,k,l;if(0===a)return"0";0>a&&(g="-");a=Math.abs(a);if(1<a)for(h=b.length-1;-1<h;h--){if(a>=b[h].number&&(k=a/b[h].number,l=Number(d.precision),1>l&&(l=1),c=AmCharts.roundTo(k,l),l=AmCharts.formatNumber(c,{precision:-1,decimalSeparator:d.decimalSeparator,thousandsSeparator:d.thousandsSeparator}),!e||k==c)){f=g+""+l+""+b[h].prefix;break}}else for(h=0;h<c.length;h++)if(a<=c[h].number){k=a/c[h].number;l=Math.abs(Math.round(Math.log(k)* | ||
32 | Math.LOG10E));k=AmCharts.roundTo(k,l);f=g+""+k+""+c[h].prefix;break}return f};AmCharts.remove=function(a){a&&a.remove()};AmCharts.recommended=function(){var a="js";document.implementation.hasFeature("http://www.w3.org/TR/SVG11/feature#BasicStructure","1.1")||swfobject&&swfobject.hasFlashPlayerVersion("8")&&(a="flash");return a};AmCharts.getEffect=function(a){">"==a&&(a="easeOutSine");"<"==a&&(a="easeInSine");"elastic"==a&&(a="easeOutElastic");return a}; | ||
33 | AmCharts.getObjById=function(a,b){var c,d;for(d=0;d<a.length;d++){var e=a[d];e.id==b&&(c=e)}return c};AmCharts.applyTheme=function(a,b,c){b||(b=AmCharts.theme);b&&b[c]&&AmCharts.extend(a,b[c])};AmCharts.isString=function(a){return"string"==typeof a?!0:!1};AmCharts.extend=function(a,b,c){for(var d in b)c?a.hasOwnProperty(d)||(a[d]=b[d]):a[d]=b[d];return a}; | ||
34 | AmCharts.copyProperties=function(a,b){for(var c in a)a.hasOwnProperty(c)&&"events"!=c&&void 0!==a[c]&&"function"!=typeof a[c]&&"cname"!=c&&(b[c]=a[c])};AmCharts.processObject=function(a,b,c){!1===a instanceof b&&(a=AmCharts.extend(new b(c),a));return a};AmCharts.fixNewLines=function(a){var b=RegExp("\\n","g");a&&(a=a.replace(b,"<br />"));return a};AmCharts.fixBrakes=function(a){if(AmCharts.isModern){var b=RegExp("<br>","g");a&&(a=a.replace(b,"\n"))}else a=AmCharts.fixNewLines(a);return a}; | ||
35 | AmCharts.deleteObject=function(a,b){if(a){if(void 0===b||null===b)b=20;if(0!==b)if("[object Array]"===Object.prototype.toString.call(a))for(var c=0;c<a.length;c++)AmCharts.deleteObject(a[c],b-1),a[c]=null;else if(a&&!a.tagName)try{for(c in a)a[c]&&("object"==typeof a[c]&&AmCharts.deleteObject(a[c],b-1),"function"!=typeof a[c]&&(a[c]=null))}catch(d){}}}; | ||
36 | AmCharts.bounce=function(a,b,c,d,e){return(b/=e)<1/2.75?7.5625*d*b*b+c:b<2/2.75?d*(7.5625*(b-=1.5/2.75)*b+.75)+c:b<2.5/2.75?d*(7.5625*(b-=2.25/2.75)*b+.9375)+c:d*(7.5625*(b-=2.625/2.75)*b+.984375)+c};AmCharts.easeInSine=function(a,b,c,d,e){return-d*Math.cos(b/e*(Math.PI/2))+d+c};AmCharts.easeOutSine=function(a,b,c,d,e){return d*Math.sin(b/e*(Math.PI/2))+c}; | ||
37 | AmCharts.easeOutElastic=function(a,b,c,d,e){a=1.70158;var f=0,g=d;if(0===b)return c;if(1==(b/=e))return c+d;f||(f=.3*e);g<Math.abs(d)?(g=d,a=f/4):a=f/(2*Math.PI)*Math.asin(d/g);return g*Math.pow(2,-10*b)*Math.sin(2*(b*e-a)*Math.PI/f)+d+c};AmCharts.AxisBase=AmCharts.Class({construct:function(a){this.createEvents("clickItem","rollOverItem","rollOutItem");this.viY=this.viX=this.y=this.x=this.dy=this.dx=0;this.axisThickness=1;this.axisColor="#000000";this.axisAlpha=1;this.gridCount=this.tickLength=5;this.gridAlpha=.15;this.gridThickness=1;this.gridColor="#000000";this.dashLength=0;this.labelFrequency=1;this.showLastLabel=this.showFirstLabel=!0;this.fillColor="#FFFFFF";this.fillAlpha=0;this.labelsEnabled=!0;this.labelRotation=0;this.autoGridCount= | ||
38 | !0;this.valueRollOverColor="#CC0000";this.offset=0;this.guides=[];this.visible=!0;this.counter=0;this.guides=[];this.ignoreAxisWidth=this.inside=!1;this.minHorizontalGap=75;this.minVerticalGap=35;this.titleBold=!0;this.minorGridEnabled=!1;this.minorGridAlpha=.07;this.autoWrap=!1;this.titleAlign="middle";this.labelOffset=0;AmCharts.applyTheme(this,a,"AxisBase")},zoom:function(a,b){this.start=a;this.end=b;this.dataChanged=!0;this.draw()},fixAxisPosition:function(){var a=this.position;"H"==this.orientation? | ||
39 | ("left"==a&&(a="bottom"),"right"==a&&(a="top")):("bottom"==a&&(a="left"),"top"==a&&(a="right"));this.position=a},draw:function(){var a=this.chart;this.allLabels=[];this.counter=0;this.destroy();this.fixAxisPosition();this.labels=[];var b=a.container,c=b.set();a.gridSet.push(c);this.set=c;b=b.set();a.axesLabelsSet.push(b);this.labelsSet=b;this.axisLine=new this.axisRenderer(this);this.autoGridCount?("V"==this.orientation?(a=this.height/this.minVerticalGap,3>a&&(a=3)):a=this.width/this.minHorizontalGap, | ||
40 | this.gridCountR=Math.max(a,1)):this.gridCountR=this.gridCount;this.axisWidth=this.axisLine.axisWidth;this.addTitle()},setOrientation:function(a){this.orientation=a?"H":"V"},addTitle:function(){var a=this.title;if(a){var b=this.chart,c=this.titleColor;void 0===c&&(c=b.color);var d=this.titleFontSize;isNaN(d)&&(d=b.fontSize+1);this.titleLabel=AmCharts.text(b.container,a,c,b.fontFamily,d,this.titleAlign,this.titleBold)}},positionTitle:function(){var a=this.titleLabel;if(a){var b,c,d=this.labelsSet,e= | ||
41 | {};0<d.length()?e=d.getBBox():(e.x=0,e.y=0,e.width=this.viW,e.height=this.viH);d.push(a);var d=e.x,f=e.y;AmCharts.VML&&(this.rotate?d-=this.x:f-=this.y);var g=e.width,e=e.height,h=this.viW,k=this.viH,l=0,m=a.getBBox().height/2,n=this.inside,p=this.titleAlign;switch(this.position){case "top":b="left"==p?-1:"right"==p?h:h/2;c=f-10-m;break;case "bottom":b="left"==p?-1:"right"==p?h:h/2;c=f+e+10+m;break;case "left":b=d-10-m;n&&(b-=5);c="left"==p?k+1:"right"==p?-1:k/2;l=-90;break;case "right":b=d+g+10+ | ||
42 | m-3,n&&(b+=7),c="left"==p?k+2:"right"==p?-2:k/2,l=-90}this.marginsChanged?(a.translate(b,c),this.tx=b,this.ty=c):a.translate(this.tx,this.ty);this.marginsChanged=!1;0!==l&&a.rotate(l)}},pushAxisItem:function(a,b){var c=this,d=a.graphics();0<d.length()&&(b?c.labelsSet.push(d):c.set.push(d));if(d=a.getLabel())this.labelsSet.push(d),d.click(function(b){c.handleMouse(b,a,"clickItem")}).mouseover(function(b){c.handleMouse(b,a,"rollOverItem")}).mouseout(function(b){c.handleMouse(b,a,"rollOutItem")})},handleMouse:function(a, | ||
43 | b,c){this.fire(c,{type:c,value:b.value,serialDataItem:b.serialDataItem,axis:this,target:b.label,chart:this.chart,event:a})},addGuide:function(a){for(var b=this.guides,c=!1,d=0;d<b.length;d++)b[d]==a&&(c=!0);c||b.push(a)},removeGuide:function(a){var b=this.guides,c;for(c=0;c<b.length;c++)b[c]==a&&b.splice(c,1)},handleGuideOver:function(a){clearTimeout(this.chart.hoverInt);var b=a.graphics.getBBox(),c=b.x+b.width/2,b=b.y+b.height/2,d=a.fillColor;void 0===d&&(d=a.lineColor);this.chart.showBalloon(a.balloonText, | ||
44 | d,!0,c,b)},handleGuideOut:function(a){this.chart.hideBalloon()},addEventListeners:function(a,b){var c=this;a.mouseover(function(){c.handleGuideOver(b)});a.mouseout(function(){c.handleGuideOut(b)})},getBBox:function(){var a=this.labelsSet.getBBox();AmCharts.VML||(a={x:a.x+this.x,y:a.y+this.y,width:a.width,height:a.height});return a},destroy:function(){AmCharts.remove(this.set);AmCharts.remove(this.labelsSet);var a=this.axisLine;a&&AmCharts.remove(a.set);AmCharts.remove(this.grid0)}});AmCharts.ValueAxis=AmCharts.Class({inherits:AmCharts.AxisBase,construct:function(a){this.cname="ValueAxis";this.createEvents("axisChanged","logarithmicAxisFailed","axisSelfZoomed","axisZoomed");AmCharts.ValueAxis.base.construct.call(this,a);this.dataChanged=!0;this.stackType="none";this.position="left";this.unitPosition="right";this.recalculateToPercents=this.includeHidden=this.includeGuidesInMinMax=this.integersOnly=!1;this.durationUnits={DD:"d. ",hh:":",mm:":",ss:""};this.scrollbar=!1;this.baseValue= | ||
45 | 0;this.radarCategoriesEnabled=!0;this.gridType="polygons";this.useScientificNotation=!1;this.axisTitleOffset=10;this.minMaxMultiplier=1;this.logGridLimit=2;AmCharts.applyTheme(this,a,this.cname)},updateData:function(){0>=this.gridCountR&&(this.gridCountR=1);this.totals=[];this.data=this.chart.chartData;var a=this.chart;"xy"!=a.type&&(this.stackGraphs("smoothedLine"),this.stackGraphs("line"),this.stackGraphs("column"),this.stackGraphs("step"));this.recalculateToPercents&&this.recalculate();this.synchronizationMultiplier&& | ||
46 | this.synchronizeWith?(AmCharts.isString(this.synchronizeWith)&&(this.synchronizeWith=a.getValueAxisById(this.synchronizeWith)),this.synchronizeWith&&(this.synchronizeWithAxis(this.synchronizeWith),this.foundGraphs=!0)):(this.foundGraphs=!1,this.getMinMax())},draw:function(){AmCharts.ValueAxis.base.draw.call(this);var a=this.chart,b=this.set;"duration"==this.type&&(this.duration="ss");!0===this.dataChanged&&(this.updateData(),this.dataChanged=!1);if(this.logarithmic&&(0>=this.getMin(0,this.data.length- | ||
47 | 1)||0>=this.minimum))this.fire("logarithmicAxisFailed",{type:"logarithmicAxisFailed",chart:a});else{this.grid0=null;var c,d,e=a.dx,f=a.dy,g=!1,h=this.logarithmic;if(isNaN(this.min)||isNaN(this.max)||!this.foundGraphs||Infinity==this.min||-Infinity==this.max)g=!0;else{var k=this.labelFrequency,l=this.showFirstLabel,m=this.showLastLabel,n=1,p=0,q=Math.round((this.max-this.min)/this.step)+1,r;!0===h?(r=Math.log(this.max)*Math.LOG10E-Math.log(this.minReal)*Math.LOG10E,this.stepWidth=this.axisWidth/r, | ||
48 | r>this.logGridLimit&&(q=Math.ceil(Math.log(this.max)*Math.LOG10E)+1,p=Math.round(Math.log(this.minReal)*Math.LOG10E),q>this.gridCountR&&(n=Math.ceil(q/this.gridCountR)))):this.stepWidth=this.axisWidth/(this.max-this.min);var s=0;1>this.step&&-1<this.step&&(s=AmCharts.getDecimals(this.step));this.integersOnly&&(s=0);s>this.maxDecCount&&(s=this.maxDecCount);var v=this.precision;isNaN(v)||(s=v);this.max=AmCharts.roundTo(this.max,this.maxDecCount);this.min=AmCharts.roundTo(this.min,this.maxDecCount); | ||
49 | var w={};w.precision=s;w.decimalSeparator=a.nf.decimalSeparator;w.thousandsSeparator=a.nf.thousandsSeparator;this.numberFormatter=w;var t,u=this.guides,y=u.length;if(0<y){c=this.fillAlpha;for(d=this.fillAlpha=0;d<y;d++){var E=u[d],A=NaN,z=E.above;isNaN(E.toValue)||(A=this.getCoordinate(E.toValue),t=new this.axisItemRenderer(this,A,"",!0,NaN,NaN,E),this.pushAxisItem(t,z));var K=NaN;isNaN(E.value)||(K=this.getCoordinate(E.value),t=new this.axisItemRenderer(this,K,E.label,!0,NaN,(A-K)/2,E),this.pushAxisItem(t, | ||
50 | z));isNaN(A-K)||(t=new this.guideFillRenderer(this,K,A,E),this.pushAxisItem(t,z),t=t.graphics(),E.graphics=t,E.balloonText&&this.addEventListeners(t,E))}this.fillAlpha=c}u=!1;for(d=p;d<q;d+=n)y=AmCharts.roundTo(this.step*d+this.min,s),-1!=String(y).indexOf("e")&&(u=!0,String(y).split("e"));this.duration&&(this.maxInterval=AmCharts.getMaxInterval(this.max,this.duration));var s=this.step,I,y=this.minorGridAlpha;this.minorGridEnabled&&(I=this.getMinorGridStep(s,this.stepWidth*s));for(d=p;d<q;d+=n)if(p= | ||
51 | s*d+this.min,h&&this.max-this.min>5*this.min&&(p-=this.min),p=AmCharts.roundTo(p,this.maxDecCount+1),!this.integersOnly||Math.round(p)==p)if(isNaN(v)||Number(AmCharts.toFixed(p,v))==p){!0===h&&(0===p&&(p=this.minReal),r>this.logGridLimit&&(p=Math.pow(10,d)),u=-1!=String(p).indexOf("e")?!0:!1);this.useScientificNotation&&(u=!0);this.usePrefixes&&(u=!1);u?(t=-1==String(p).indexOf("e")?p.toExponential(15):String(p),c=t.split("e"),t=Number(c[0]),c=Number(c[1]),t=AmCharts.roundTo(t,14),10==t&&(t=1,c+= | ||
52 | 1),t=t+"e"+c,0===p&&(t="0"),1==p&&(t="1")):(h&&(t=String(p).split("."),t[1]?(w.precision=t[1].length,0>d&&(w.precision=Math.abs(d))):w.precision=-1),t=this.usePrefixes?AmCharts.addPrefix(p,a.prefixesOfBigNumbers,a.prefixesOfSmallNumbers,w,!0):AmCharts.formatNumber(p,w,w.precision));this.duration&&(t=AmCharts.formatDuration(p,this.duration,"",this.durationUnits,this.maxInterval,w));this.recalculateToPercents?t+="%":(c=this.unit)&&(t="left"==this.unitPosition?c+t:t+c);Math.round(d/k)!=d/k&&(t=void 0); | ||
53 | if(0===d&&!l||d==q-1&&!m)t=" ";c=this.getCoordinate(p);this.labelFunction&&(t=this.labelFunction(p,t,this).toString());t=new this.axisItemRenderer(this,c,t,void 0,void 0,void 0,void 0,this.boldLabels);this.pushAxisItem(t);if(p==this.baseValue&&"radar"!=a.type){var F,H,z=this.viW,A=this.viH;t=this.viX;E=this.viY;"H"==this.orientation?0<=c&&c<=z+1&&(F=[c,c,c+e],H=[A,0,f]):0<=c&&c<=A+1&&(F=[0,z,z+e],H=[c,c,c+f]);F&&(c=AmCharts.fitToBounds(2*this.gridAlpha,0,1),c=AmCharts.line(a.container,F,H,this.gridColor, | ||
54 | c,1,this.dashLength),c.translate(t,E),this.grid0=c,a.axesSet.push(c),c.toBack())}if(!isNaN(I)&&0<y&&d<q-1){t=this.gridAlpha;this.gridAlpha=this.minorGridAlpha;for(c=1;c<s/I;c++)E=this.getCoordinate(p+I*c),E=new this.axisItemRenderer(this,E,"",!1,0,0,!1,!1,0,!0),this.pushAxisItem(E);this.gridAlpha=t}}d=this.baseValue;this.min>this.baseValue&&this.max>this.baseValue&&(d=this.min);this.min<this.baseValue&&this.max<this.baseValue&&(d=this.max);h&&d<this.minReal&&(d=this.minReal);this.baseCoord=this.getCoordinate(d); | ||
55 | d={type:"axisChanged",target:this,chart:a};d.min=h?this.minReal:this.min;d.max=this.max;this.fire("axisChanged",d);this.axisCreated=!0}h=this.axisLine.set;d=this.labelsSet;this.positionTitle();"radar"!=a.type?(a=this.viX,e=this.viY,b.translate(a,e),d.translate(a,e)):h.toFront();!this.visible||g?(b.hide(),h.hide(),d.hide()):(b.show(),h.show(),d.show());this.axisY=this.y-this.viY;this.axisX=this.x-this.viX}},getMinorGridStep:function(a,b){var c=[5,4,2];60>b&&c.shift();for(var d=Math.floor(Math.log(Math.abs(a))* | ||
56 | Math.LOG10E),e=0;e<c.length;e++){var f=a/c[e],g=Math.floor(Math.log(Math.abs(f))*Math.LOG10E);if(!(0<Math.abs(d-g)))if(1>a){if(g=Math.pow(10,-g)*f,g==Math.round(g))return f}else if(f==Math.round(f))return f}},stackGraphs:function(a){var b=this.stackType;"stacked"==b&&(b="regular");"line"==b&&(b="none");"100% stacked"==b&&(b="100%");this.stackType=b;var c=[],d=[],e=[],f=[],g,h=this.chart.graphs,k,l,m,n,p=this.baseValue,q=!1;if("line"==a||"step"==a||"smoothedLine"==a)q=!0;if(q&&("regular"==b||"100%"== | ||
57 | b))for(n=0;n<h.length;n++)m=h[n],m.hidden||(l=m.type,m.chart==this.chart&&m.valueAxis==this&&a==l&&m.stackable&&(k&&(m.stackGraph=k),k=m));for(k=this.start;k<=this.end;k++){var r=0;for(n=0;n<h.length;n++)if(m=h[n],m.hidden)m.newStack&&(e[k]=NaN,d[k]=NaN);else if(l=m.type,m.chart==this.chart&&m.valueAxis==this&&a==l&&m.stackable&&(l=this.data[k].axes[this.id].graphs[m.id],g=l.values.value,!isNaN(g))){var s=AmCharts.getDecimals(g);r<s&&(r=s);isNaN(f[k])?f[k]=Math.abs(g):f[k]+=Math.abs(g);f[k]=AmCharts.roundTo(f[k], | ||
58 | r);s=m.fillToGraph;q&&s&&(s=this.data[k].axes[this.id].graphs[s.id])&&(l.values.open=s.values.value);"regular"==b&&(q&&(isNaN(c[k])?(c[k]=g,l.values.close=g,l.values.open=this.baseValue):(isNaN(g)?l.values.close=c[k]:l.values.close=g+c[k],l.values.open=c[k],c[k]=l.values.close)),"column"!=a||isNaN(g)||(m.newStack&&(e[k]=NaN,d[k]=NaN),l.values.close=g,0>g?(l.values.close=g,isNaN(d[k])?l.values.open=p:(l.values.close+=d[k],l.values.open=d[k]),d[k]=l.values.close):(l.values.close=g,isNaN(e[k])?l.values.open= | ||
59 | p:(l.values.close+=e[k],l.values.open=e[k]),e[k]=l.values.close)))}}for(k=this.start;k<=this.end;k++)for(n=0;n<h.length;n++)(m=h[n],m.hidden)?m.newStack&&(e[k]=NaN,d[k]=NaN):(l=m.type,m.chart==this.chart&&m.valueAxis==this&&a==l&&m.stackable&&(l=this.data[k].axes[this.id].graphs[m.id],g=l.values.value,isNaN(g)||(c=g/f[k]*100,l.values.percents=c,l.values.total=f[k],m.newStack&&(e[k]=NaN,d[k]=NaN),"100%"==b&&(isNaN(d[k])&&(d[k]=0),isNaN(e[k])&&(e[k]=0),0>c?(l.values.close=AmCharts.fitToBounds(c+d[k], | ||
60 | -100,100),l.values.open=d[k],d[k]=l.values.close):(l.values.close=AmCharts.fitToBounds(c+e[k],-100,100),l.values.open=e[k],e[k]=l.values.close)))))},recalculate:function(){var a=this.chart,b=a.graphs,c;for(c=0;c<b.length;c++){var d=b[c];if(d.valueAxis==this){var e="value";if("candlestick"==d.type||"ohlc"==d.type)e="open";var f,g,h=this.end+2,h=AmCharts.fitToBounds(this.end+1,0,this.data.length-1),k=this.start;0<k&&k--;var l;g=this.start;d.compareFromStart&&(g=0);if(!isNaN(a.startTime)&&(l=a.categoryAxis)){minDuration= | ||
61 | l.minDuration();var m=new Date(a.startTime+minDuration/2),n=AmCharts.resetDateToMin(new Date(a.startTime),l.minPeriod).getTime();AmCharts.resetDateToMin(new Date(m),l.minPeriod).getTime()>n&&g++}if(l=a.recalculateFromDate)a.dataDateFormat&&(l=AmCharts.stringToDate(l,a.dataDateFormat)),g=a.getClosestIndex(a.chartData,"time",l.getTime(),!0,0,a.chartData.length),h=a.chartData.length-1;for(l=g;l<=h&&(g=this.data[l].axes[this.id].graphs[d.id],f=g.values[e],isNaN(f));l++);this.recBaseValue=f;for(e=k;e<= | ||
62 | h;e++){g=this.data[e].axes[this.id].graphs[d.id];g.percents={};var k=g.values,p;for(p in k)g.percents[p]="percents"!=p?k[p]/f*100-100:k[p]}}}},getMinMax:function(){var a=!1,b=this.chart,c=b.graphs,d;for(d=0;d<c.length;d++){var e=c[d].type;("line"==e||"step"==e||"smoothedLine"==e)&&this.expandMinMax&&(a=!0)}a&&(0<this.start&&this.start--,this.end<this.data.length-1&&this.end++);"serial"==b.type&&(!0!==b.categoryAxis.parseDates||a||this.end<this.data.length-1&&this.end++);a=this.minMaxMultiplier;this.min= | ||
63 | this.getMin(this.start,this.end);this.max=this.getMax();a=(this.max-this.min)*(a-1);this.min-=a;this.max+=a;a=this.guides.length;if(this.includeGuidesInMinMax&&0<a)for(b=0;b<a;b++)c=this.guides[b],c.toValue<this.min&&(this.min=c.toValue),c.value<this.min&&(this.min=c.value),c.toValue>this.max&&(this.max=c.toValue),c.value>this.max&&(this.max=c.value);isNaN(this.minimum)||(this.min=this.minimum);isNaN(this.maximum)||(this.max=this.maximum);this.min>this.max&&(a=this.max,this.max=this.min,this.min= | ||
64 | a);isNaN(this.minTemp)||(this.min=this.minTemp);isNaN(this.maxTemp)||(this.max=this.maxTemp);this.minReal=this.min;this.maxReal=this.max;0===this.min&&0===this.max&&(this.max=9);this.min>this.max&&(this.min=this.max-1);a=this.min;b=this.max;c=this.max-this.min;d=0===c?Math.pow(10,Math.floor(Math.log(Math.abs(this.max))*Math.LOG10E))/10:Math.pow(10,Math.floor(Math.log(Math.abs(c))*Math.LOG10E))/10;isNaN(this.maximum)&&isNaN(this.maxTemp)&&(this.max=Math.ceil(this.max/d)*d+d);isNaN(this.minimum)&&isNaN(this.minTemp)&& | ||
65 | (this.min=Math.floor(this.min/d)*d-d);0>this.min&&0<=a&&(this.min=0);0<this.max&&0>=b&&(this.max=0);"100%"==this.stackType&&(this.min=0>this.min?-100:0,this.max=0>this.max?0:100);c=this.max-this.min;d=Math.pow(10,Math.floor(Math.log(Math.abs(c))*Math.LOG10E))/10;this.step=Math.ceil(c/this.gridCountR/d)*d;c=Math.pow(10,Math.floor(Math.log(Math.abs(this.step))*Math.LOG10E));c=this.fixStepE(c);d=Math.ceil(this.step/c);5<d&&(d=10);5>=d&&2<d&&(d=5);this.step=Math.ceil(this.step/(c*d))*c*d;1>c?(this.maxDecCount= | ||
66 | Math.abs(Math.log(Math.abs(c))*Math.LOG10E),this.maxDecCount=Math.round(this.maxDecCount),this.step=AmCharts.roundTo(this.step,this.maxDecCount+1)):this.maxDecCount=0;this.min=this.step*Math.floor(this.min/this.step);this.max=this.step*Math.ceil(this.max/this.step);0>this.min&&0<=a&&(this.min=0);0<this.max&&0>=b&&(this.max=0);1<this.minReal&&1<this.max-this.minReal&&(this.minReal=Math.floor(this.minReal));c=Math.pow(10,Math.floor(Math.log(Math.abs(this.minReal))*Math.LOG10E));0===this.min&&(this.minReal= | ||
67 | c);0===this.min&&1<this.minReal&&(this.minReal=1);0<this.min&&0<this.minReal-this.step&&(this.minReal=this.min+this.step<this.minReal?this.min+this.step:this.min);c=Math.log(b)*Math.LOG10E-Math.log(a)*Math.LOG10E;this.logarithmic&&(2<c?(this.minReal=this.min=Math.pow(10,Math.floor(Math.log(Math.abs(a))*Math.LOG10E)),this.max=Math.pow(10,Math.ceil(Math.log(Math.abs(b))*Math.LOG10E))):(b=Math.pow(10,Math.floor(Math.log(Math.abs(this.min))*Math.LOG10E))/10,a=Math.pow(10,Math.floor(Math.log(Math.abs(a))* | ||
68 | Math.LOG10E))/10,b<a&&(this.minReal=this.min=10*a)))},fixStepE:function(a){a=a.toExponential(0).split("e");var b=Number(a[1]);9==Number(a[0])&&b++;return this.generateNumber(1,b)},generateNumber:function(a,b){var c="",d;d=0>b?Math.abs(b)-1:Math.abs(b);var e;for(e=0;e<d;e++)c+="0";return 0>b?Number("0."+c+String(a)):Number(String(a)+c)},getMin:function(a,b){var c,d;for(d=a;d<=b;d++){var e=this.data[d].axes[this.id].graphs,f;for(f in e)if(e.hasOwnProperty(f)){var g=this.chart.getGraphById(f);if(g.includeInMinMax&& | ||
69 | (!g.hidden||this.includeHidden)){isNaN(c)&&(c=Infinity);this.foundGraphs=!0;g=e[f].values;this.recalculateToPercents&&(g=e[f].percents);var h;if(this.minMaxField)h=g[this.minMaxField],h<c&&(c=h);else for(var k in g)g.hasOwnProperty(k)&&"percents"!=k&&"total"!=k&&(h=g[k],h<c&&(c=h))}}}return c},getMax:function(){var a,b;for(b=this.start;b<=this.end;b++){var c=this.data[b].axes[this.id].graphs,d;for(d in c)if(c.hasOwnProperty(d)){var e=this.chart.getGraphById(d);if(e.includeInMinMax&&(!e.hidden||this.includeHidden)){isNaN(a)&& | ||
70 | (a=-Infinity);this.foundGraphs=!0;e=c[d].values;this.recalculateToPercents&&(e=c[d].percents);var f;if(this.minMaxField)f=e[this.minMaxField],f>a&&(a=f);else for(var g in e)e.hasOwnProperty(g)&&"percents"!=g&&"total"!=g&&(f=e[g],f>a&&(a=f))}}}return a},dispatchZoomEvent:function(a,b){var c={type:"axisZoomed",startValue:a,endValue:b,target:this,chart:this.chart};this.fire(c.type,c)},zoomToValues:function(a,b){if(b<a){var c=b;b=a;a=c}a<this.min&&(a=this.min);b>this.max&&(b=this.max);c={type:"axisSelfZoomed"}; | ||
71 | c.chart=this.chart;c.valueAxis=this;c.multiplier=this.axisWidth/Math.abs(this.getCoordinate(b)-this.getCoordinate(a));c.position="V"==this.orientation?this.reversed?this.getCoordinate(a):this.getCoordinate(b):this.reversed?this.getCoordinate(b):this.getCoordinate(a);this.fire(c.type,c)},coordinateToValue:function(a){if(isNaN(a))return NaN;var b=this.axisWidth,c=this.stepWidth,d=this.reversed,e=this.rotate,f=this.min,g=this.minReal;return!0===this.logarithmic?Math.pow(10,(e?!0===d?(b-a)/c:a/c:!0=== | ||
72 | d?a/c:(b-a)/c)+Math.log(g)*Math.LOG10E):!0===d?e?f-(a-b)/c:a/c+f:e?a/c+f:f-(a-b)/c},getCoordinate:function(a){if(isNaN(a))return NaN;var b=this.rotate,c=this.reversed,d=this.axisWidth,e=this.stepWidth,f=this.min,g=this.minReal;!0===this.logarithmic?(a=Math.log(a)*Math.LOG10E-Math.log(g)*Math.LOG10E,b=b?!0===c?d-e*a:e*a:!0===c?e*a:d-e*a):b=!0===c?b?d-e*(a-f):e*(a-f):b?e*(a-f):d-e*(a-f);b=this.rotate?b+(this.x-this.viX):b+(this.y-this.viY);1E7<Math.abs(b)&&(b=1E7*(b/Math.abs(b)));return Math.round(b)}, | ||
73 | synchronizeWithAxis:function(a){this.synchronizeWith=a;this.listenTo(this.synchronizeWith,"axisChanged",this.handleSynchronization)},handleSynchronization:function(a){var b=this.synchronizeWith;a=b.min;var c=b.max,b=b.step,d=this.synchronizationMultiplier;d&&(this.min=a*d,this.max=c*d,this.step=b*d,a=Math.pow(10,Math.floor(Math.log(Math.abs(this.step))*Math.LOG10E)),a=Math.abs(Math.log(Math.abs(a))*Math.LOG10E),this.maxDecCount=a=Math.round(a),this.draw())}});AmCharts.RecAxis=AmCharts.Class({construct:function(a){var b=a.chart,c=a.axisThickness,d=a.axisColor,e=a.axisAlpha,f=a.offset,g=a.dx,h=a.dy,k=a.viX,l=a.viY,m=a.viH,n=a.viW,p=b.container;"H"==a.orientation?(d=AmCharts.line(p,[0,n],[0,0],d,e,c),this.axisWidth=a.width,"bottom"==a.position?(a=c/2+f+m+l-1,c=k):(a=-c/2-f+l+h,c=g+k)):(this.axisWidth=a.height,"right"==a.position?(d=AmCharts.line(p,[0,0,-g],[0,m,m-h],d,e,c),a=l+h,c=c/2+f+g+n+k-1):(d=AmCharts.line(p,[0,0],[0,m],d,e,c),a=l,c=-c/2-f+k));d.translate(c, | ||
74 | a);b.axesSet.push(d);this.set=d}});AmCharts.RecItem=AmCharts.Class({construct:function(a,b,c,d,e,f,g,h,k,l,m){b=Math.round(b);this.value=c;void 0==c&&(c="");k||(k=0);void 0==d&&(d=!0);var n=a.chart.fontFamily,p=a.fontSize;void 0==p&&(p=a.chart.fontSize);var q=a.color;void 0==q&&(q=a.chart.color);void 0!==m&&(q=m);var r=a.chart.container,s=r.set();this.set=s;var v=a.axisThickness,w=a.axisColor,t=a.axisAlpha,u=a.tickLength,y=a.gridAlpha,E=a.gridThickness,A=a.gridColor,z=a.dashLength,K=a.fillColor,I=a.fillAlpha,F=a.labelsEnabled;m=a.labelRotation; | ||
75 | var H=a.counter,L=a.inside,ha=a.labelOffset,ba=a.dx,$=a.dy,Ra=a.orientation,na=a.position,ta=a.previousCoord,V=a.viH,X=a.viW,Z=a.offset,oa,R;g?(F=!0,isNaN(g.tickLength)||(u=g.tickLength),void 0!=g.lineColor&&(A=g.lineColor),void 0!=g.color&&(q=g.color),isNaN(g.lineAlpha)||(y=g.lineAlpha),isNaN(g.dashLength)||(z=g.dashLength),isNaN(g.lineThickness)||(E=g.lineThickness),!0===g.inside&&(L=!0),isNaN(g.labelRotation)||(m=g.labelRotation),isNaN(g.fontSize)||(p=g.fontSize),g.position&&(na=g.position),void 0!== | ||
76 | g.boldLabel&&(h=g.boldLabel),isNaN(g.labelOffset)||(ha=g.labelOffset)):""===c&&(u=0);R="start";e&&(R="middle");var Y=m*Math.PI/180,qa,G=0,B=0,W=0,ca=qa=0,ja=0;"V"==Ra&&(m=0);var x;F&&(x=a.autoWrap&&0===m?AmCharts.wrappedText(r,c,q,n,p,R,h,e,0):AmCharts.text(r,c,q,n,p,R,h),R=x.getBBox(),ca=R.width,ja=R.height);if("H"==Ra){if(0<=b&&b<=X+1&&(0<u&&0<t&&b+k<=X+1&&(oa=AmCharts.line(r,[b+k,b+k],[0,u],w,t,E),s.push(oa)),0<y&&(R=AmCharts.line(r,[b,b+ba,b+ba],[V,V+$,$],A,y,E,z),s.push(R))),B=0,G=b,g&&90==m&& | ||
77 | L&&(G-=p),!1===d?(R="start",B="bottom"==na?L?B+u:B-u:L?B-u:B+u,G+=3,e&&(G+=e/2-3,R="middle"),0<m&&(R="middle")):R="middle",1==H&&0<I&&!g&&!l&&ta<X&&(d=AmCharts.fitToBounds(b,0,X),ta=AmCharts.fitToBounds(ta,0,X),qa=d-ta,0<qa&&(fill=AmCharts.rect(r,qa,a.height,K,I),fill.translate(d-qa+ba,$),s.push(fill))),"bottom"==na?(B+=V+p/2+Z,L?(0<m?(B=V-ca/2*Math.sin(Y)-u-3,G+=ca/2*Math.cos(Y)-4+2):0>m?(B=V+ca*Math.sin(Y)-u-3+2,G+=-ca*Math.cos(Y)-ja*Math.sin(Y)-4):B-=u+p+3+3,B-=ha):(0<m?(B=V+ca/2*Math.sin(Y)+u+ | ||
78 | 3,G-=ca/2*Math.cos(Y)):0>m?(B=V+u+3-ca/2*Math.sin(Y)+2,G+=ca/2*Math.cos(Y)):B+=u+v+3+3,B+=ha)):(B+=$+p/2-Z,G+=ba,L?(0<m?(B=ca/2*Math.sin(Y)+u+3,G-=ca/2*Math.cos(Y)):B+=u+3,B+=ha):(0<m?(B=-(ca/2)*Math.sin(Y)-u-6,G+=ca/2*Math.cos(Y)):B-=u+p+3+v+3,B-=ha)),"bottom"==na?qa=(L?V-u-1:V+v-1)+Z:(W=ba,qa=(L?$:$-u-v+1)-Z),f&&(G+=f),f=G,0<m&&(f+=ca/2*Math.cos(Y)),x&&(p=0,L&&(p=ca/2*Math.cos(Y)),f+p>X+2||0>f))x.remove(),x=null}else{0<=b&&b<=V+1&&(0<u&&0<t&&b+k<=V+1&&(oa=AmCharts.line(r,[0,u],[b+k,b+k],w,t,E), | ||
79 | s.push(oa)),0<y&&(R=AmCharts.line(r,[0,ba,X+ba],[b,b+$,b+$],A,y,E,z),s.push(R)));R="end";if(!0===L&&"left"==na||!1===L&&"right"==na)R="start";B=b-p/2;1==H&&0<I&&!g&&!l&&(d=AmCharts.fitToBounds(b,0,V),ta=AmCharts.fitToBounds(ta,0,V),Y=d-ta,fill=AmCharts.polygon(r,[0,a.width,a.width,0],[0,0,Y,Y],K,I),fill.translate(ba,d-Y+$),s.push(fill));B+=p/2;"right"==na?(G+=ba+X+Z,B+=$,L?(f||(B-=p/2+3),G=G-(u+4)-ha):(G+=u+4+v,B-=2,G+=ha)):L?(G+=u+4-Z,f||(B-=p/2+3),g&&(G+=ba,B+=$),G+=ha):(G+=-u-v-4-2-Z,B-=2,G-=ha); | ||
80 | oa&&("right"==na?(W+=ba+Z+X,qa+=$,W=L?W-v:W+v):(W-=Z,L||(W-=u+v)));f&&(B+=f);L=-3;"right"==na&&(L+=$);x&&(B>V+1||B<L)&&(x.remove(),x=null)}oa&&oa.translate(W,qa);!1===a.visible&&(oa&&oa.remove(),x&&(x.remove(),x=null));x&&(x.attr({"text-anchor":R}),x.translate(G,B),0!==m&&x.rotate(-m,a.chart.backgroundColor),a.allLabels.push(x)," "!=c&&(this.label=x));l||(a.counter=0===H?1:0,a.previousCoord=b);0===this.set.node.childNodes.length&&this.set.remove()},graphics:function(){return this.set},getLabel:function(){return this.label}});AmCharts.RecFill=AmCharts.Class({construct:function(a,b,c,d){var e=a.dx,f=a.dy,g=a.orientation,h=0;if(c<b){var k=b;b=c;c=k}var l=d.fillAlpha;isNaN(l)&&(l=0);k=a.chart.container;d=d.fillColor;"V"==g?(b=AmCharts.fitToBounds(b,0,a.viH),c=AmCharts.fitToBounds(c,0,a.viH)):(b=AmCharts.fitToBounds(b,0,a.viW),c=AmCharts.fitToBounds(c,0,a.viW));c-=b;isNaN(c)&&(c=4,h=2,l=0);0>c&&"object"==typeof d&&(d=d.join(",").split(",").reverse());"V"==g?(a=AmCharts.rect(k,a.width,c,d,l),a.translate(e,b-h+f)):(a=AmCharts.rect(k, | ||
81 | c,a.height,d,l),a.translate(b-h+e,f));this.set=k.set([a])},graphics:function(){return this.set},getLabel:function(){}});AmCharts.AmChart=AmCharts.Class({construct:function(a){this.theme=a;this.version="3.10.0C";AmCharts.addChart(this);this.createEvents("dataUpdated","init","rendered","drawn");this.height=this.width="100%";this.dataChanged=!0;this.chartCreated=!1;this.previousWidth=this.previousHeight=0;this.backgroundColor="#FFFFFF";this.borderAlpha=this.backgroundAlpha=0;this.color=this.borderColor="#000000";this.fontFamily="Verdana";this.fontSize=11;this.usePrefixes=!1;this.precision=-1;this.percentPrecision=2;this.decimalSeparator= | ||
82 | ".";this.thousandsSeparator=",";this.labels=[];this.allLabels=[];this.titles=[];this.marginRight=this.marginLeft=this.autoMarginOffset=0;this.timeOuts=[];this.creditsPosition="top-left";var b=document.createElement("div"),c=b.style;c.overflow="hidden";c.position="relative";c.textAlign="left";this.chartDiv=b;b=document.createElement("div");c=b.style;c.overflow="hidden";c.position="relative";c.textAlign="left";this.legendDiv=b;this.titleHeight=0;this.hideBalloonTime=150;this.handDrawScatter=2;this.handDrawThickness= | ||
83 | 1;this.prefixesOfBigNumbers=[{number:1E3,prefix:"k"},{number:1E6,prefix:"M"},{number:1E9,prefix:"G"},{number:1E12,prefix:"T"},{number:1E15,prefix:"P"},{number:1E18,prefix:"E"},{number:1E21,prefix:"Z"},{number:1E24,prefix:"Y"}];this.prefixesOfSmallNumbers=[{number:1E-24,prefix:"y"},{number:1E-21,prefix:"z"},{number:1E-18,prefix:"a"},{number:1E-15,prefix:"f"},{number:1E-12,prefix:"p"},{number:1E-9,prefix:"n"},{number:1E-6,prefix:"\u03bc"},{number:.001,prefix:"m"}];this.panEventsEnabled=!0;AmCharts.bezierX= | ||
84 | 3;AmCharts.bezierY=6;this.product="amcharts";this.animations=[];this.balloon=new AmCharts.AmBalloon(this.theme);this.balloon.chart=this;AmCharts.applyTheme(this,a,"AmChart")},drawChart:function(){this.drawBackground();this.redrawLabels();this.drawTitles();this.brr()},drawBackground:function(){AmCharts.remove(this.background);var a=this.container,b=this.backgroundColor,c=this.backgroundAlpha,d=this.set;AmCharts.isModern||0!==c||(c=.001);var e=this.updateWidth();this.realWidth=e;var f=this.updateHeight(); | ||
85 | this.realHeight=f;this.background=b=AmCharts.polygon(a,[0,e-1,e-1,0],[0,0,f-1,f-1],b,c,1,this.borderColor,this.borderAlpha);d.push(b);if(b=this.backgroundImage)this.path&&(b=this.path+b),this.bgImg=a=a.image(b,0,0,e,f),d.push(a)},drawTitles:function(){var a=this.titles;if(AmCharts.ifArray(a)){var b=20,c;for(c=0;c<a.length;c++){var d=a[c],e=d.color;void 0===e&&(e=this.color);var f=d.size;isNaN(f)&&(f=this.fontSize+2);isNaN(d.alpha);var g=this.marginLeft,e=AmCharts.text(this.container,d.text,e,this.fontFamily, | ||
86 | f);e.translate(g+(this.realWidth-this.marginRight-g)/2,b);g=!0;void 0!==d.bold&&(g=d.bold);g&&e.attr({"font-weight":"bold"});e.attr({opacity:d.alpha});b+=f+6;this.freeLabelsSet.push(e)}}},write:function(a){if(a="object"!=typeof a?document.getElementById(a):a){a.innerHTML="";this.div=a;a.style.overflow="hidden";a.style.textAlign="left";var b=this.chartDiv,c=this.legendDiv,d=this.legend,e=c.style,f=b.style;this.measure();var g,h=document.createElement("div");g=h.style;g.position="relative";this.containerDiv= | ||
87 | h;a.appendChild(h);var k=this.exportConfig;k&&AmCharts.AmExport&&!this.AmExport&&(this.AmExport=new AmCharts.AmExport(this,k));this.amExport&&AmCharts.AmExport&&(this.AmExport=AmCharts.extend(this.amExport,new AmCharts.AmExport(this),!0));this.AmExport&&this.AmExport.init&&this.AmExport.init();if(d)switch(d=this.addLegend(d,d.divId),d.position){case "bottom":h.appendChild(b);h.appendChild(c);break;case "top":h.appendChild(c);h.appendChild(b);break;case "absolute":g.width=a.style.width;g.height=a.style.height; | ||
88 | e.position="absolute";f.position="absolute";void 0!==d.left&&(e.left=d.left+"px");void 0!==d.right&&(e.right=d.right+"px");void 0!==d.top&&(e.top=d.top+"px");void 0!==d.bottom&&(e.bottom=d.bottom+"px");d.marginLeft=0;d.marginRight=0;h.appendChild(b);h.appendChild(c);break;case "right":g.width=a.style.width;g.height=a.style.height;e.position="relative";f.position="absolute";h.appendChild(b);h.appendChild(c);break;case "left":g.width=a.style.width;g.height=a.style.height;e.position="absolute";f.position= | ||
89 | "relative";h.appendChild(b);h.appendChild(c);break;case "outside":h.appendChild(b)}else h.appendChild(b);this.listenersAdded||(this.addListeners(),this.listenersAdded=!0);this.initChart()}},createLabelsSet:function(){AmCharts.remove(this.labelsSet);this.labelsSet=this.container.set();this.freeLabelsSet.push(this.labelsSet)},initChart:function(){AmCharts.applyLang(this.language);var a=this.numberFormatter;a&&(isNaN(a.precision)||(this.precision=a.precision),void 0!==a.thousandsSeparator&&(this.thousandsSeparator= | ||
90 | a.thousandsSeparator),void 0!==a.decimalSeparator&&(this.decimalSeparator=a.decimalSeparator));(a=this.percentFormatter)&&!isNaN(a.precision)&&(this.percentPrecision=a.precision);this.nf={precision:this.precision,thousandsSeparator:this.thousandsSeparator,decimalSeparator:this.decimalSeparator};this.pf={precision:this.percentPrecision,thousandsSeparator:this.thousandsSeparator,decimalSeparator:this.decimalSeparator};this.divIsFixed=AmCharts.findIfFixed(this.chartDiv);this.previousHeight=this.divRealHeight; | ||
91 | this.previousWidth=this.divRealWidth;this.destroy();this.startInterval();a=0;document.attachEvent&&!window.opera&&(a=1);this.dmouseX=this.dmouseY=0;var b=document.getElementsByTagName("html")[0];b&&window.getComputedStyle&&(b=window.getComputedStyle(b,null))&&(this.dmouseY=AmCharts.removePx(b.getPropertyValue("margin-top")),this.dmouseX=AmCharts.removePx(b.getPropertyValue("margin-left")));this.mouseMode=a;(a=this.container)?(a.container.innerHTML="",this.chartDiv.appendChild(a.container),a.setSize(this.realWidth, | ||
92 | this.realHeight)):a=new AmCharts.AmDraw(this.chartDiv,this.realWidth,this.realHeight,this);if(AmCharts.VML||AmCharts.SVG)a.handDrawn=this.handDrawn,a.handDrawScatter=this.handDrawScatter,a.handDrawThickness=this.handDrawThickness,this.container=a,this.set&&this.set.remove(),this.set=a.set(),this.gridSet&&this.gridSet.remove(),this.gridSet=a.set(),this.cursorLineSet&&this.cursorLineSet.remove(),this.cursorLineSet=a.set(),this.graphsBehindSet&&this.graphsBehindSet.remove(),this.graphsBehindSet=a.set(), | ||
93 | this.bulletBehindSet&&this.bulletBehindSet.remove(),this.bulletBehindSet=a.set(),this.columnSet&&this.columnSet.remove(),this.columnSet=a.set(),this.graphsSet&&this.graphsSet.remove(),this.graphsSet=a.set(),this.trendLinesSet&&this.trendLinesSet.remove(),this.trendLinesSet=a.set(),this.axesLabelsSet&&this.axesLabelsSet.remove(),this.axesLabelsSet=a.set(),this.axesSet&&this.axesSet.remove(),this.axesSet=a.set(),this.cursorSet&&this.cursorSet.remove(),this.cursorSet=a.set(),this.scrollbarsSet&&this.scrollbarsSet.remove(), | ||
94 | this.scrollbarsSet=a.set(),this.bulletSet&&this.bulletSet.remove(),this.bulletSet=a.set(),this.freeLabelsSet&&this.freeLabelsSet.remove(),this.freeLabelsSet=a.set(),this.balloonsSet&&this.balloonsSet.remove(),this.balloonsSet=a.set(),this.zoomButtonSet&&this.zoomButtonSet.remove(),this.zoomButtonSet=a.set(),this.linkSet&&this.linkSet.remove(),this.linkSet=a.set(),this.renderFix()},measure:function(){var a=this.div;if(a){var b=this.chartDiv,c=a.offsetWidth,d=a.offsetHeight,e=this.container;a.clientHeight&& | ||
95 | (c=a.clientWidth,d=a.clientHeight);var f=AmCharts.removePx(AmCharts.getStyle(a,"padding-left")),g=AmCharts.removePx(AmCharts.getStyle(a,"padding-right")),h=AmCharts.removePx(AmCharts.getStyle(a,"padding-top")),k=AmCharts.removePx(AmCharts.getStyle(a,"padding-bottom"));isNaN(f)||(c-=f);isNaN(g)||(c-=g);isNaN(h)||(d-=h);isNaN(k)||(d-=k);f=a.style;a=f.width;f=f.height;-1!=a.indexOf("px")&&(c=AmCharts.removePx(a));-1!=f.indexOf("px")&&(d=AmCharts.removePx(f));a=AmCharts.toCoordinate(this.width,c);f=AmCharts.toCoordinate(this.height, | ||
96 | d);this.balloon=AmCharts.processObject(this.balloon,AmCharts.AmBalloon,this.theme);this.balloon.chart=this;(a!=this.previousWidth||f!=this.previousHeight)&&0<a&&0<f&&(b.style.width=a+"px",b.style.height=f+"px",e&&e.setSize(a,f));this.balloon.setBounds(2,2,a-2,f);this.realWidth=a;this.realHeight=f;this.divRealWidth=c;this.divRealHeight=d}},destroy:function(){this.chartDiv.innerHTML="";this.clearTimeOuts();this.interval&&clearInterval(this.interval);this.interval=NaN},clearTimeOuts:function(){var a= | ||
97 | this.timeOuts;if(a){var b;for(b=0;b<a.length;b++)clearTimeout(a[b])}this.timeOuts=[]},clear:function(a){AmCharts.callMethod("clear",[this.chartScrollbar,this.scrollbarV,this.scrollbarH,this.chartCursor]);this.chartCursor=this.scrollbarH=this.scrollbarV=this.chartScrollbar=null;this.clearTimeOuts();this.interval&&clearInterval(this.interval);this.container&&(this.container.remove(this.chartDiv),this.container.remove(this.legendDiv));a||AmCharts.removeChart(this)},setMouseCursor:function(a){"auto"== | ||
98 | a&&AmCharts.isNN&&(a="default");this.chartDiv.style.cursor=a;this.legendDiv.style.cursor=a},redrawLabels:function(){this.labels=[];var a=this.allLabels;this.createLabelsSet();var b;for(b=0;b<a.length;b++)this.drawLabel(a[b])},drawLabel:function(a){if(this.container){var b=a.y,c=a.text,d=a.align,e=a.size,f=a.color,g=a.rotation,h=a.alpha,k=a.bold,l=AmCharts.toCoordinate(a.x,this.realWidth),b=AmCharts.toCoordinate(b,this.realHeight);l||(l=0);b||(b=0);void 0===f&&(f=this.color);isNaN(e)&&(e=this.fontSize); | ||
99 | d||(d="start");"left"==d&&(d="start");"right"==d&&(d="end");"center"==d&&(d="middle",g?b=this.realHeight-b+b/2:l=this.realWidth/2-l);void 0===h&&(h=1);void 0===g&&(g=0);b+=e/2;c=AmCharts.text(this.container,c,f,this.fontFamily,e,d,k,h);c.translate(l,b);0!==g&&c.rotate(g);a.url&&(c.setAttr("cursor","pointer"),c.click(function(){AmCharts.getURL(a.url)}));this.labelsSet.push(c);this.labels.push(c)}},addLabel:function(a,b,c,d,e,f,g,h,k,l){a={x:a,y:b,text:c,align:d,size:e,color:f,alpha:h,rotation:g,bold:k, | ||
100 | url:l};this.container&&this.drawLabel(a);this.allLabels.push(a)},clearLabels:function(){var a=this.labels,b;for(b=a.length-1;0<=b;b--)a[b].remove();this.labels=[];this.allLabels=[]},updateHeight:function(){var a=this.divRealHeight,b=this.legend;if(b){var c=this.legendDiv.offsetHeight,b=b.position;if("top"==b||"bottom"==b){a-=c;if(0>a||isNaN(a))a=0;this.chartDiv.style.height=a+"px"}}return a},updateWidth:function(){var a=this.divRealWidth,b=this.divRealHeight,c=this.legend;if(c){var d=this.legendDiv, | ||
101 | e=d.offsetWidth;isNaN(c.width)||(e=c.width);var f=d.offsetHeight,d=d.style,g=this.chartDiv.style,c=c.position;if("right"==c||"left"==c){a-=e;if(0>a||isNaN(a))a=0;g.width=a+"px";"left"==c?g.left=e+"px":d.left=a+"px";d.top=(b-f)/2+"px"}}return a},getTitleHeight:function(){var a=0,b=this.titles;if(0<b.length){var a=15,c;for(c=0;c<b.length;c++){var d=b[c].size;isNaN(d)&&(d=this.fontSize+2);a+=d+6}}return a},addTitle:function(a,b,c,d,e){isNaN(b)&&(b=this.fontSize+2);a={text:a,size:b,color:c,alpha:d,bold:e}; | ||
102 | this.titles.push(a);return a},addMouseWheel:function(){var a=this;window.addEventListener&&!a.wheelAdded&&(window.addEventListener("DOMMouseScroll",function(b){a.handleWheel.call(a,b)},!1),document.addEventListener("mousewheel",function(b){a.handleWheel.call(a,b)},!1),a.wheelAdded=!0)},handleWheel:function(a){if(this.mouseIsOver){var b=0;a||(a=window.event);a.wheelDelta?b=a.wheelDelta/120:a.detail&&(b=-a.detail/3);b&&this.handleWheelReal(b,a.shiftKey);a.preventDefault&&a.preventDefault()}},handleWheelReal:function(a){}, | ||
103 | addListeners:function(){var a=this,b=a.chartDiv;document.addEventListener?(a.panEventsEnabled&&"ontouchstart"in document.documentElement&&(b.addEventListener("touchstart",function(b){a.handleTouchMove.call(a,b);a.handleTouchStart.call(a,b)},!0),b.addEventListener("touchmove",function(b){a.handleTouchMove.call(a,b)},!0),b.addEventListener("touchend",function(b){a.handleTouchEnd.call(a,b)},!0)),b.addEventListener("mousedown",function(b){a.handleMouseDown.call(a,b)},!0),b.addEventListener("mouseover", | ||
104 | function(b){a.handleMouseOver.call(a,b)},!0),b.addEventListener("mouseout",function(b){a.handleMouseOut.call(a,b)},!0)):(b.attachEvent("onmousedown",function(b){a.handleMouseDown.call(a,b)}),b.attachEvent("onmouseover",function(b){a.handleMouseOver.call(a,b)}),b.attachEvent("onmouseout",function(b){a.handleMouseOut.call(a,b)}))},dispDUpd:function(){var a;this.dispatchDataUpdated&&(this.dispatchDataUpdated=!1,a="dataUpdated",this.fire(a,{type:a,chart:this}));this.chartCreated||(a="init",this.fire(a, | ||
105 | {type:a,chart:this}));this.chartRendered||(a="rendered",this.fire(a,{type:a,chart:this}),this.chartRendered=!0);a="drawn";this.fire(a,{type:a,chart:this})},validateSize:function(){var a=this;a.measure();var b=a.legend;if((a.realWidth!=a.previousWidth||a.realHeight!=a.previousHeight)&&0<a.realWidth&&0<a.realHeight){a.sizeChanged=!0;if(b){clearTimeout(a.legendInitTO);var c=setTimeout(function(){b.invalidateSize()},100);a.timeOuts.push(c);a.legendInitTO=c}a.marginsUpdated="xy"!=a.type?!1:!0;clearTimeout(a.initTO); | ||
106 | c=setTimeout(function(){a.initChart()},150);a.timeOuts.push(c);a.initTO=c}a.renderFix();b&&b.renderFix()},invalidateSize:function(){this.previousHeight=this.previousWidth=NaN;this.invalidateSizeReal()},invalidateSizeReal:function(){var a=this;a.marginsUpdated=!1;clearTimeout(a.validateTO);var b=setTimeout(function(){a.validateSize()},5);a.timeOuts.push(b);a.validateTO=b},validateData:function(a){this.chartCreated&&(this.dataChanged=!0,this.marginsUpdated="xy"!=this.type?!1:!0,this.initChart(a))}, | ||
107 | validateNow:function(){this.chartRendered=this.listenersAdded=!1;this.write(this.div)},showItem:function(a){a.hidden=!1;this.initChart()},hideItem:function(a){a.hidden=!0;this.initChart()},hideBalloon:function(){var a=this;clearInterval(a.hoverInt);clearTimeout(a.balloonTO);a.hoverInt=setTimeout(function(){a.hideBalloonReal.call(a)},a.hideBalloonTime)},cleanChart:function(){},hideBalloonReal:function(){var a=this.balloon;a&&a.hide()},showBalloon:function(a,b,c,d,e){var f=this;clearTimeout(f.balloonTO); | ||
108 | clearInterval(f.hoverInt);f.balloonTO=setTimeout(function(){f.showBalloonReal.call(f,a,b,c,d,e)},1)},showBalloonReal:function(a,b,c,d,e){this.handleMouseMove();var f=this.balloon;f.enabled&&(f.followCursor(!1),f.changeColor(b),!c||f.fixedPosition?(f.setPosition(d,e),f.followCursor(!1)):f.followCursor(!0),a&&f.showBalloon(a))},handleTouchMove:function(a){this.hideBalloon();var b=this.chartDiv;a.touches&&(a=a.touches.item(0),this.mouseX=a.pageX-AmCharts.findPosX(b),this.mouseY=a.pageY-AmCharts.findPosY(b))}, | ||
109 | handleMouseOver:function(a){AmCharts.resetMouseOver();this.mouseIsOver=!0},handleMouseOut:function(a){AmCharts.resetMouseOver();this.mouseIsOver=!1},handleMouseMove:function(a){if(this.mouseIsOver){var b=this.chartDiv;a||(a=window.event);var c,d;if(a){this.posX=AmCharts.findPosX(b);this.posY=AmCharts.findPosY(b);switch(this.mouseMode){case 1:c=a.clientX-this.posX;d=a.clientY-this.posY;if(!this.divIsFixed){var b=document.body,e,f;b&&(e=b.scrollLeft,y1=b.scrollTop);if(b=document.documentElement)f=b.scrollLeft, | ||
110 | y2=b.scrollTop;e=Math.max(e,f);f=Math.max(y1,y2);c+=e;d+=f}break;case 0:this.divIsFixed?(c=a.clientX-this.posX,d=a.clientY-this.posY):(c=a.pageX-this.posX,d=a.pageY-this.posY)}a.touches&&(a=a.touches.item(0),c=a.pageX-this.posX,d=a.pageY-this.posY);this.mouseX=c-this.dmouseX;this.mouseY=d-this.dmouseY}}},handleTouchStart:function(a){this.handleMouseDown(a)},handleTouchEnd:function(a){AmCharts.resetMouseOver();this.handleReleaseOutside(a)},handleReleaseOutside:function(a){},handleMouseDown:function(a){AmCharts.resetMouseOver(); | ||
111 | this.mouseIsOver=!0;a&&a.preventDefault&&a.preventDefault()},addLegend:function(a,b){a=AmCharts.processObject(a,AmCharts.AmLegend,this.theme);a.divId=b;var c;c="object"!=typeof b&&b?document.getElementById(b):b;this.legend=a;a.chart=this;c?(a.div=c,a.position="outside",a.autoMargins=!1):a.div=this.legendDiv;c=this.handleLegendEvent;this.listenTo(a,"showItem",c);this.listenTo(a,"hideItem",c);this.listenTo(a,"clickMarker",c);this.listenTo(a,"rollOverItem",c);this.listenTo(a,"rollOutItem",c);this.listenTo(a, | ||
112 | "rollOverMarker",c);this.listenTo(a,"rollOutMarker",c);this.listenTo(a,"clickLabel",c);return a},removeLegend:function(){this.legend=void 0;this.legendDiv.innerHTML=""},handleResize:function(){(AmCharts.isPercents(this.width)||AmCharts.isPercents(this.height))&&this.invalidateSizeReal();this.renderFix()},renderFix:function(){if(!AmCharts.VML){var a=this.container;a&&a.renderFix()}},getSVG:function(){if(AmCharts.hasSVG)return this.container},animate:function(a,b,c,d,e,f,g){a["an_"+b]&&AmCharts.removeFromArray(this.animations, | ||
113 | a["an_"+b]);c={obj:a,frame:0,attribute:b,from:c,to:d,time:e,effect:f,suffix:g};a["an_"+b]=c;this.animations.push(c);return c},setLegendData:function(a){var b=this.legend;b&&b.setData(a)},startInterval:function(){var a=this;clearInterval(a.interval);a.interval=setInterval(function(){a.updateAnimations.call(a)},AmCharts.updateRate)},stopAnim:function(a){AmCharts.removeFromArray(this.animations,a)},updateAnimations:function(){var a;this.container&&this.container.update();for(a=this.animations.length- | ||
114 | 1;0<=a;a--){var b=this.animations[a],c=1E3*b.time/AmCharts.updateRate,d=b.frame+1,e=b.obj,f=b.attribute;if(d<=c){b.frame++;var g=Number(b.from),h=Number(b.to)-g,c=AmCharts[b.effect](0,d,g,h,c);0===h?(this.animations.splice(a,1),e.node.style[f]=Number(b.to)+b.suffix):e.node.style[f]=c+b.suffix}else e.node.style[f]=Number(b.to)+b.suffix,this.animations.splice(a,1)}},inIframe:function(){try{return window.self!==window.top}catch(a){return!0}},brr:function(){var a=window.location.hostname.split("."),b; | ||
115 | 2<=a.length&&(b=a[a.length-2]+"."+a[a.length-1]);this.amLink&&(a=this.amLink.parentNode)&&a.removeChild(this.amLink);a=this.creditsPosition;if("amcharts.com"!=b||!0===this.inIframe()){var c=b=0,d=this.realWidth,e=this.realHeight;if("serial"==this.type||"xy"==this.type)b=this.marginLeftReal,c=this.marginTopReal,d=b+this.plotAreaWidth,e=c+this.plotAreaHeight;var f="http://www.amcharts.com/javascript-charts/",g="JavaScript charts",h="JS chart by amCharts";"ammap"==this.product&&(f="http://www.ammap.com/javascript-maps/", | ||
116 | g="Interactive JavaScript maps",h="JS map by amCharts");var k=document.createElement("a"),h=document.createTextNode(h);k.setAttribute("href",f);k.setAttribute("title",g);k.appendChild(h);this.chartDiv.appendChild(k);this.amLink=k;f=k.style;f.position="absolute";f.textDecoration="none";f.color=this.color;f.fontFamily=this.fontFamily;f.fontSize=this.fontSize+"px";f.opacity=.7;f.display="block";var g=k.offsetWidth,k=k.offsetHeight,h=5+b,l=c+5;"bottom-left"==a&&(h=5+b,l=e-k-3);"bottom-right"==a&&(h=d- | ||
117 | g-5,l=e-k-3);"top-right"==a&&(h=d-g-5,l=c+5);f.left=h+"px";f.top=l+"px"}}});AmCharts.Slice=AmCharts.Class({construct:function(){}});AmCharts.SerialDataItem=AmCharts.Class({construct:function(){}});AmCharts.GraphDataItem=AmCharts.Class({construct:function(){}});AmCharts.Guide=AmCharts.Class({construct:function(a){this.cname="Guide";AmCharts.applyTheme(this,a,this.cname)}});AmCharts.AmGraph=AmCharts.Class({construct:function(a){this.cname="AmGraph";this.createEvents("rollOverGraphItem","rollOutGraphItem","clickGraphItem","doubleClickGraphItem","rightClickGraphItem","clickGraph","rollOverGraph","rollOutGraph");this.type="line";this.stackable=!0;this.columnCount=1;this.columnIndex=0;this.centerCustomBullets=this.showBalloon=!0;this.maxBulletSize=50;this.minBulletSize=4;this.balloonText="[[value]]";this.hidden=this.scrollbar=this.animationPlayed=!1;this.pointPosition="middle"; | ||
118 | this.depthCount=1;this.includeInMinMax=!0;this.negativeBase=0;this.visibleInLegend=!0;this.showAllValueLabels=!1;this.showBulletsAt=this.showBalloonAt="close";this.lineThickness=1;this.dashLength=0;this.connect=!0;this.lineAlpha=1;this.bullet="none";this.bulletBorderThickness=2;this.bulletBorderAlpha=0;this.bulletAlpha=1;this.bulletSize=8;this.hideBulletsCount=this.bulletOffset=0;this.labelPosition="top";this.cornerRadiusTop=0;this.cursorBulletAlpha=1;this.gradientOrientation="vertical";this.dy=this.dx= | ||
119 | 0;this.periodValue="";this.clustered=!0;this.periodSpan=1;this.y=this.x=0;this.switchable=!0;this.tcc=this.minDistance=1;AmCharts.applyTheme(this,a,this.cname)},draw:function(){var a=this.chart;isNaN(this.precision)||(this.numberFormatter?this.numberFormatter.precision=this.precision:this.numberFormatter={precision:this.precision,decimalSeparator:a.decimalSeparator,thousandsSeparator:a.thousandsSeparator});var b=a.container;this.container=b;this.destroy();var c=b.set(),d=b.set();this.behindColumns? | ||
120 | (a.graphsBehindSet.push(c),a.bulletBehindSet.push(d)):(a.graphsSet.push(c),a.bulletSet.push(d));var e=this.bulletAxis;AmCharts.isString(e)&&(this.bulletAxis=a.getValueAxisById(e));this.bulletSet=d;this.scrollbar||(e=a.marginLeftReal,a=a.marginTopReal,c.translate(e,a),d.translate(e,a));b=b.set();AmCharts.remove(this.columnsSet);c.push(b);this.set=c;this.columnsSet=b;this.columnsArray=[];this.ownColumns=[];this.allBullets=[];this.animationArray=[];AmCharts.ifArray(this.data)&&(c=!1,"xy"==this.chart.type? | ||
121 | this.xAxis.axisCreated&&this.yAxis.axisCreated&&(c=!0):this.valueAxis.axisCreated&&(c=!0),!this.hidden&&c&&this.createGraph())},createGraph:function(){var a=this,b=a.chart;"inside"==a.labelPosition&&"column"!=a.type&&(a.labelPosition="bottom");a.startAlpha=b.startAlpha;a.seqAn=b.sequencedAnimation;a.baseCoord=a.valueAxis.baseCoord;void 0===a.fillAlphas&&(a.fillAlphas=0);a.bulletColorR=a.bulletColor;void 0===a.bulletColorR&&(a.bulletColorR=a.lineColorR,a.bulletColorNegative=a.negativeLineColor);void 0=== | ||
122 | a.bulletAlpha&&(a.bulletAlpha=a.lineAlpha);clearTimeout(a.playedTO);if(!isNaN(a.valueAxis.min)&&!isNaN(a.valueAxis.max)){switch(b.type){case "serial":a.categoryAxis&&(a.createSerialGraph(),"candlestick"==a.type&&1>a.valueAxis.minMaxMultiplier&&a.positiveClip(a.set));break;case "radar":a.createRadarGraph();break;case "xy":a.createXYGraph(),a.positiveClip(a.set)}a.playedTO=setTimeout(function(){a.setAnimationPlayed.call(a)},500*a.chart.startDuration)}},setAnimationPlayed:function(){this.animationPlayed= | ||
123 | !0},createXYGraph:function(){var a=[],b=[],c=this.xAxis,d=this.yAxis;this.pmh=d.viH+1;this.pmw=c.viW+1;this.pmy=this.pmx=0;var e;for(e=this.start;e<=this.end;e++){var f=this.data[e].axes[c.id].graphs[this.id],g=f.values,h=g.x,k=g.y,g=c.getCoordinate(h),l=d.getCoordinate(k);!isNaN(h)&&!isNaN(k)&&(a.push(g),b.push(l),(h=this.createBullet(f,g,l,e))||(h=0),k=this.labelText)&&(f=this.createLabel(f,g,l,k),this.allBullets.push(f),this.positionLabel(g,l,f,this.labelPosition,h))}this.drawLineGraph(a,b);this.launchAnimation()}, | ||
124 | createRadarGraph:function(){var a=this.valueAxis.stackType,b=[],c=[],d,e,f;for(f=this.start;f<=this.end;f++){var g=this.data[f].axes[this.valueAxis.id].graphs[this.id],h;h="none"==a||"3d"==a?g.values.value:g.values.close;if(isNaN(h))this.drawLineGraph(b,c),b=[],c=[];else{var k=this.y-(this.valueAxis.getCoordinate(h)-this.height),l=180-360/(this.end-this.start+1)*f;h=k*Math.sin(l/180*Math.PI);k*=Math.cos(l/180*Math.PI);b.push(h);c.push(k);(l=this.createBullet(g,h,k,f))||(l=0);var m=this.labelText; | ||
125 | m&&(g=this.createLabel(g,h,k,m),this.allBullets.push(g),this.positionLabel(h,k,g,this.labelPosition,l));isNaN(d)&&(d=h);isNaN(e)&&(e=k)}}b.push(d);c.push(e);this.drawLineGraph(b,c);this.launchAnimation()},positionLabel:function(a,b,c,d,e){var f=c.getBBox();switch(d){case "left":a-=(f.width+e)/2+2;break;case "top":b-=(e+f.height)/2+1;break;case "right":a+=(f.width+e)/2+2;break;case "bottom":b+=(e+f.height)/2+1}c.translate(a,b)},getGradRotation:function(){var a=270;"horizontal"==this.gradientOrientation&& | ||
126 | (a=0);return this.gradientRotation=a},createSerialGraph:function(){this.dashLengthSwitched=this.fillColorsSwitched=this.lineColorSwitched=void 0;var a=this.chart,b=this.id,c=this.index,d=this.data,e=this.chart.container,f=this.valueAxis,g=this.type,h=this.columnWidthReal,k=this.showBulletsAt;isNaN(this.columnWidth)||(h=this.columnWidth);isNaN(h)&&(h=.8);var l=this.useNegativeColorIfDown,m=this.width,n=this.height,p=this.y,q=this.rotate,r=this.columnCount,s=AmCharts.toCoordinate(this.cornerRadiusTop, | ||
127 | h/2),v=this.connect,w=[],t=[],u,y,E,A,z=this.chart.graphs.length,K,I=this.dx/this.tcc,F=this.dy/this.tcc;var H=f.stackType,L=this.labelPosition,ha=this.start,ba=this.end,$=this.scrollbar,Ra=this.categoryAxis,na=this.baseCoord,ta=this.negativeBase,V=this.columnIndex,X=this.lineThickness,Z=this.lineAlpha,oa=this.lineColorR,R=this.dashLength,Y=this.set,qa=L,G=this.getGradRotation(),B=this.chart.columnSpacing,W=Ra.cellWidth,ca=(W*h-r)/r;B>ca&&(B=ca);var ja,x,ab,jb=n+1,kb=m+1,bb= | ||
128 | 0,lb=0,mb,nb,cb,db,ob=this.fillColorsR,Da=this.negativeFillColors,wa=this.negativeLineColor,Sa=this.fillAlphas,Ta=this.negativeFillAlphas;"object"==typeof Sa&&(Sa=Sa[0]);"object"==typeof Ta&&(Ta=Ta[0]);var eb=f.getCoordinate(f.min);f.logarithmic&&(eb=f.getCoordinate(f.minReal));this.minCoord=eb;this.resetBullet&&(this.bullet="none");if(!($||"line"!=g&&"smoothedLine"!=g&&"step"!=g||(1==d.length&&"step"!=g&&"none"==this.bullet&&(this.bullet="round",this.resetBullet=!0),!Da&&void 0==wa||l))){var La= | ||
129 | ta;La>f.max&&(La=f.max);La<f.min&&(La=f.min);f.logarithmic&&(La=f.minReal);var Aa=f.getCoordinate(La),Fb=f.getCoordinate(f.max);q?(jb=n,kb=Math.abs(Fb-Aa),mb=n,nb=Math.abs(eb-Aa),db=lb=0,f.reversed?(bb=0,cb=Aa):(bb=Aa,cb=0)):(kb=m,jb=Math.abs(Fb-Aa),nb=m,mb=Math.abs(eb-Aa),cb=bb=0,f.reversed?(db=p,lb=Aa):db=Aa+1)}var Ba=Math.round;this.pmx=Ba(bb);this.pmy=Ba(lb);this.pmh=Ba(jb);this.pmw=Ba(kb);this.nmx=Ba(cb);this.nmy=Ba(db);this.nmh=Ba(mb);this.nmw=Ba(nb);AmCharts.isModern||(this.nmy=this.nmx=0, | ||
130 | this.nmh=this.height);h="column"==g?(W*h-B*(r-1))/r:W*h;1>h&&(h=1);var J;if("line"==g||"step"==g||"smoothedLine"==g){if(0<ha){for(J=ha-1;-1<J;J--)if(ja=d[J],x=ja.axes[f.id].graphs[b],ab=x.values.value,!isNaN(ab)){ha=J;break}if(this.lineColorField)for(J=ha;-1<J;J--)if(ja=d[J],x=ja.axes[f.id].graphs[b],x.lineColor){this.bulletColorSwitched=this.lineColorSwitched=x.lineColor;break}if(this.fillColorsField)for(J=ha;-1<J;J--)if(ja=d[J],x=ja.axes[f.id].graphs[b],x.fillColors){this.fillColorsSwitched=x.fillColors; | ||
131 | break}if(this.dashLengthField)for(J=ha;-1<J;J--)if(ja=d[J],x=ja.axes[f.id].graphs[b],!isNaN(x.dashLength)){this.dashLengthSwitched=x.dashLength;break}}if(ba<d.length-1)for(J=ba+1;J<d.length;J++)if(ja=d[J],x=ja.axes[f.id].graphs[b],ab=x.values.value,!isNaN(ab)){ba=J;break}}ba<d.length-1&&ba++;var O=[],P=[],Ea=!1;if("line"==g||"step"==g||"smoothedLine"==g)if(this.stackable&&"regular"==H||"100%"==H||this.fillToGraph)Ea=!0;var Gb=this.noStepRisers,fb=-1E3,gb=-1E3,hb=this.minDistance,Ma=!0,Ua=!1;for(J= | ||
132 | ha;J<=ba;J++){ja=d[J];x=ja.axes[f.id].graphs[b];x.index=J;var Va,Na=NaN;if(l&&void 0==this.openField)for(var pb=J+1;pb<d.length&&(!d[pb]||!(Va=d[J+1].axes[f.id].graphs[b])||!Va.values||(Na=Va.values.value,isNaN(Na)));pb++);var S,T,Q,da,la=NaN,D=NaN,C=NaN,N=NaN,M=NaN,Fa=NaN,xa=NaN,Ga=NaN,ya=NaN,aa=NaN,ia=NaN,ea=NaN,fa=NaN,U=NaN,qb=NaN,rb=NaN,ka=NaN,ra=void 0,Ca=ob,Wa=Sa,ua=oa,pa,sa,Xa=this.pattern;void 0!=x.pattern&&(Xa=x.pattern);void 0!=x.color&&(Ca=x.color);x.fillColors&&(Ca=x.fillColors);isNaN(x.alpha)|| | ||
133 | (Wa=x.alpha);isNaN(x.dashLength)||(R=x.dashLength);var va=x.values;f.recalculateToPercents&&(va=x.percents);if(va){U=this.stackable&&"none"!=H&&"3d"!=H?va.close:va.value;if("candlestick"==g||"ohlc"==g)U=va.close,rb=va.low,xa=f.getCoordinate(rb),qb=va.high,ya=f.getCoordinate(qb);ka=va.open;C=f.getCoordinate(U);isNaN(ka)||(M=f.getCoordinate(ka),l&&(Na=ka,ka=M=NaN));l&&(void 0==this.openField?Va&&(Va.isNegative=Na<U?!0:!1):x.isNegative=Na>U?!0:!1);if(!$)switch(this.showBalloonAt){case "close":x.y=C; | ||
134 | break;case "open":x.y=M;break;case "high":x.y=ya;break;case "low":x.y=xa}var la=ja.x[Ra.id],Oa=this.periodSpan-1,ma=Math.floor(W/2)+Math.floor(Oa*W/2),za=ma,Hb=0;"left"==this.stepDirection&&(Hb=(2*W+Oa*W)/2,la-=Hb);"start"==this.pointPosition&&(la-=W/2+Math.floor(Oa*W/2),ma=0,za=Math.floor(W)+Math.floor(Oa*W));"end"==this.pointPosition&&(la+=W/2+Math.floor(Oa*W/2),ma=Math.floor(W)+Math.floor(Oa*W),za=0);if(Gb){var sb=this.columnWidth;isNaN(sb)||(ma*=sb,za*=sb)}$||(x.x=la);-1E5>la&&(la=-1E5);la>m+ | ||
135 | 1E5&&(la=m+1E5);q?(D=C,N=M,M=C=la,isNaN(ka)&&!this.fillToGraph&&(N=na),Fa=xa,Ga=ya):(N=D=la,isNaN(ka)&&!this.fillToGraph&&(M=na));U<ka&&(x.isNegative=!0,Da&&(Ca=Da),Ta&&(Wa=Ta),void 0!=wa&&(ua=wa));Ua=!1;isNaN(U)||(l?U>Na?(Ma&&(Ua=!0),Ma=!1):(Ma||(Ua=!0),Ma=!0):x.isNegative=U<ta?!0:!1);switch(g){case "line":if(isNaN(U))v||(this.drawLineGraph(w,t,O,P),w=[],t=[],O=[],P=[]);else{if(Math.abs(D-fb)>=hb||Math.abs(C-gb)>=hb)w.push(D),t.push(C),fb=D,gb=C;aa=D;ia=C;ea=D;fa=C;!Ea||isNaN(M)||isNaN(N)||(O.push(N), | ||
136 | P.push(M));if(Ua||void 0!=x.lineColor||void 0!=x.fillColors||!isNaN(x.dashLength))this.drawLineGraph(w,t,O,P),w=[D],t=[C],O=[],P=[],!Ea||isNaN(M)||isNaN(N)||(O.push(N),P.push(M)),l?Ma?(this.lineColorSwitched=oa,this.fillColorsSwitched=ob):(this.lineColorSwitched=wa,this.fillColorsSwitched=Da):(this.lineColorSwitched=x.lineColor,this.fillColorsSwitched=x.fillColors),this.dashLengthSwitched=x.dashLength;x.gap&&(this.drawLineGraph(w,t,O,P),w=[],t=[],O=[],P=[])}break;case "smoothedLine":if(isNaN(U))v|| | ||
137 | (this.drawSmoothedGraph(w,t,O,P),w=[],t=[],O=[],P=[]);else{if(Math.abs(D-fb)>=hb||Math.abs(C-gb)>=hb)w.push(D),t.push(C),fb=D,gb=C;aa=D;ia=C;ea=D;fa=C;!Ea||isNaN(M)||isNaN(N)||(O.push(N),P.push(M));void 0==x.lineColor&&void 0==x.fillColors&&isNaN(x.dashLength)||(this.drawSmoothedGraph(w,t,O,P),w=[D],t=[C],O=[],P=[],!Ea||isNaN(M)||isNaN(N)||(O.push(N),P.push(M)),this.lineColorSwitched=x.lineColor,this.fillColorsSwitched=x.fillColors,this.dashLengthSwitched=x.dashLength);x.gap&&(this.drawSmoothedGraph(w, | ||
138 | t,O,P),w=[],t=[],O=[],P=[])}break;case "step":if(!isNaN(U)){if(void 0==x.lineColor&&void 0==x.fillColors&&isNaN(x.dashLength)||(this.drawLineGraph(w,t,O,P),w=[],t=[],O=[],P=[],this.lineColorSwitched=x.lineColor,this.fillColorsSwitched=x.fillColors,this.dashLengthSwitched=x.dashLength),q?(isNaN(u)||(w.push(u),t.push(C-ma)),t.push(C-ma),w.push(D),t.push(C+za),w.push(D),!Ea||isNaN(M)||isNaN(N)||(O.push(E),P.push(M-ma),O.push(N),P.push(M-ma),O.push(N),P.push(M+za))):(isNaN(y)||(t.push(y),w.push(u),t.push(y), | ||
139 | w.push(D-ma)),w.push(D-ma),t.push(C),w.push(D+za),t.push(C),!Ea||isNaN(M)||isNaN(N)||(O.push(N-ma),P.push(A),O.push(N-ma),P.push(M),O.push(N+za),P.push(M))),u=D,y=C,E=N,A=M,aa=D,ia=C,ea=D,fa=C,Ua&&(this.drawLineGraph(w,t,O,P),w=[],t=[],O=[],P=[],l&&(Ma?(this.lineColorSwitched=oa,this.fillColorsSwitched=ob):(this.lineColorSwitched=wa,this.fillColorsSwitched=Da))),Gb||x.gap)u=y=NaN,this.drawLineGraph(w,t,O,P),w=[],t=[],O=[],P=[]}else if(!v){if(1>=this.periodSpan||1<this.periodSpan&&D-u>ma+za)u=y=NaN; | ||
140 | this.drawLineGraph(w,t,O,P);w=[];t=[];O=[];P=[]}break;case "column":pa=ua;void 0!=x.lineColor&&(pa=x.lineColor);if(!isNaN(U)){l||(x.isNegative=U<ta?!0:!1);x.isNegative&&(Da&&(Ca=Da),void 0!=wa&&(pa=wa));var Ib=f.min,Jb=f.max;if(!(U<Ib&&ka<Ib||U>Jb&&ka>Jb))if(q){"3d"==H?(T=C-(r/2-this.depthCount+1)*(h+B)+B/2+F*V,S=N+I*V):(T=Math.floor(C-(r/2-V)*(h+B)+B/2),S=N);Q=h;aa=D;ia=T+h/2;ea=D;fa=T+h/2;T+Q>n&&(Q=n-T);0>T&&(Q+=T,T=0);da=D-N;var Vb=S;S=AmCharts.fitToBounds(S,0,m);da+=Vb-S;da=AmCharts.fitToBounds(da, | ||
141 | -S,m-S+I*V);T<n&&0<Q&&(ra=new AmCharts.Cuboid(e,da,Q,I-a.d3x,F-a.d3y,Ca,Wa,X,pa,Z,G,s,q,R,Xa),"bottom"!=L&&"inside"!=L&&"middle"!=L&&(L=f.reversed?"left":"right",0>U&&(L=f.reversed?"right":"left")),"regular"==H||"100%"==H)&&(aa+=this.dx)}else{"3d"==H?(S=D-(r/2-this.depthCount+1)*(h+B)+B/2+I*V,T=M+F*V):(S=D-(r/2-V)*(h+B)+B/2,T=M);Q=h;aa=S+h/2;ia=C;ea=S+h/2;fa=C;S+Q>m+V*I&&(Q=m-S+V*I);0>S&&(Q+=S,S=0);da=C-M;var Wb=T;T=AmCharts.fitToBounds(T,this.dy,n);da+=Wb-T;da=AmCharts.fitToBounds(da,-T+F*V,n-T); | ||
142 | if(S<m+V*I&&0<Q)if(ra=new AmCharts.Cuboid(e,Q,da,I-a.d3x,F-a.d3y,Ca,Wa,X,pa,this.lineAlpha,G,s,q,R,Xa),0>U&&"middle"!=L&&"inside"!=L)L="bottom";else if(L=qa,"regular"==H||"100%"==H)ia+=this.dy}if(ra&&(sa=ra.set,x.columnGraphics=sa,sa.translate(S,T),this.columnsSet.push(sa),(x.url||this.showHandOnHover)&&sa.setAttr("cursor","pointer"),!$)){"none"==H&&(K=q?(this.end+1-J)*z-c:z*J+c);"3d"==H&&(q?(K=(this.end+1-J)*z-c-1E3*this.depthCount,aa+=I*this.columnIndex,ea+=I*this.columnIndex,x.y+=I*this.columnIndex): | ||
143 | (K=(z-c)*(J+1)+1E3*this.depthCount,aa+=3,ia+=F*this.columnIndex+7,fa+=F*this.columnIndex,x.y+=F*this.columnIndex));if("regular"==H||"100%"==H)"inside"!=L&&(L="middle"),K=q?0<va.value?(this.end+1-J)*z+c:(this.end+1-J)*z-c:0<va.value?z*J+c:z*J-c;this.columnsArray.push({column:ra,depth:K});x.x=q?T+Q/2:S+Q/2;this.ownColumns.push(ra);this.animateColumns(ra,J,D,N,C,M);this.addListeners(sa,x)}}break;case "candlestick":if(!isNaN(ka)&&!isNaN(U)){var ib,tb;pa=ua;void 0!=x.lineColor&&(pa=x.lineColor);if(q){if(T= | ||
144 | C-h/2,S=N,Q=h,T+Q>n&&(Q=n-T),0>T&&(Q+=T,T=0),T<n&&0<Q){var ub,vb;U>ka?(ub=[D,Ga],vb=[N,Fa]):(ub=[N,Ga],vb=[D,Fa]);!isNaN(Ga)&&!isNaN(Fa)&&C<n&&0<C&&(ib=AmCharts.line(e,ub,[C,C],pa,Z,X),tb=AmCharts.line(e,vb,[C,C],pa,Z,X));da=D-N;ra=new AmCharts.Cuboid(e,da,Q,I,F,Ca,Sa,X,pa,Z,G,s,q,R,Xa)}}else if(S=D-h/2,T=M+X/2,Q=h,S+Q>m&&(Q=m-S),0>S&&(Q+=S,S=0),da=C-M,S<m&&0<Q){var ra=new AmCharts.Cuboid(e,Q,da,I,F,Ca,Wa,X,pa,Z,G,s,q,R,Xa),wb,xb;U>ka?(wb=[C,ya],xb=[M,xa]):(wb=[M,ya],xb=[C,xa]);!isNaN(ya)&&!isNaN(xa)&& | ||
145 | D<m&&0<D&&(ib=AmCharts.line(e,[D,D],wb,pa,Z,X),tb=AmCharts.line(e,[D,D],xb,pa,Z,X))}ra&&(sa=ra.set,x.columnGraphics=sa,Y.push(sa),sa.translate(S,T-X/2),(x.url||this.showHandOnHover)&&sa.setAttr("cursor","pointer"),ib&&(Y.push(ib),Y.push(tb)),aa=D,ia=C,q?(fa=C,ea=D,"open"==k&&(ea=N),"high"==k&&(ea=Ga),"low"==k&&(ea=Fa)):(fa=C,"open"==k&&(fa=M),"high"==k&&(fa=ya),"low"==k&&(fa=xa),ea=D),$||(x.x=q?T+Q/2:S+Q/2,this.animateColumns(ra,J,D,N,C,M),this.addListeners(sa,x)))}break;case "ohlc":if(!(isNaN(ka)|| | ||
146 | isNaN(qb)||isNaN(rb)||isNaN(U))){U<ka&&(x.isNegative=!0,void 0!=wa&&(ua=wa));var yb,zb,Ab;if(q){var Bb=C-h/2,Bb=AmCharts.fitToBounds(Bb,0,n),Kb=AmCharts.fitToBounds(C,0,n),Cb=C+h/2,Cb=AmCharts.fitToBounds(Cb,0,n);zb=AmCharts.line(e,[N,N],[Bb,Kb],ua,Z,X,R);0<C&&C<n&&(yb=AmCharts.line(e,[Fa,Ga],[C,C],ua,Z,X,R));Ab=AmCharts.line(e,[D,D],[Kb,Cb],ua,Z,X,R);fa=C;ea=D;"open"==k&&(ea=N);"high"==k&&(ea=Ga);"low"==k&&(ea=Fa)}else{var Db=D-h/2,Db=AmCharts.fitToBounds(Db,0,m),Lb=AmCharts.fitToBounds(D,0,m),Eb= | ||
147 | D+h/2,Eb=AmCharts.fitToBounds(Eb,0,m);zb=AmCharts.line(e,[Db,Lb],[M,M],ua,Z,X,R);0<D&&D<m&&(yb=AmCharts.line(e,[D,D],[xa,ya],ua,Z,X,R));Ab=AmCharts.line(e,[Lb,Eb],[C,C],ua,Z,X,R);fa=C;"open"==k&&(fa=M);"high"==k&&(fa=ya);"low"==k&&(fa=xa);ea=D}Y.push(zb);Y.push(yb);Y.push(Ab);aa=D;ia=C}}if(!$&&!isNaN(U)){var Mb=this.hideBulletsCount;if(this.end-this.start<=Mb||0===Mb){var Ha=this.createBullet(x,ea,fa,J);Ha||(Ha=0);var Nb=this.labelText;if(Nb){var ga=this.createLabel(x,0,0,Nb),Ia=0,Ja=0,Ob=ga.getBBox(), | ||
148 | Pa=Ob.width,Ka=Ob.height;switch(L){case "left":Ia=-(Pa/2+Ha/2+3);break;case "top":Ja=-(Ka/2+Ha/2+3);break;case "right":Ia=Ha/2+2+Pa/2;break;case "bottom":q&&"column"==g?(aa=na,0>U||0<U&&f.reversed?(Ia=-6,ga.attr({"text-anchor":"end"})):(Ia=6,ga.attr({"text-anchor":"start"}))):(Ja=Ha/2+Ka/2,ga.x=-(Pa/2+2));break;case "middle":"column"==g&&(q?(Ja=-(Ka/2)+this.fontSize/2,Ia=-(D-N)/2-I,Math.abs(D-N)<Pa&&!this.showAllValueLabels&&(ga.remove(),ga=null)):(Ja=-(C-M)/2-F,Math.abs(C-M)<Ka&&!this.showAllValueLabels&& | ||
149 | (ga.remove(),ga=null)));break;case "inside":q?(Ja=-(Ka/2)+this.fontSize/2,Ia=0>da?Pa/2+6:-Pa/2-6):Ja=0>da?Ka:-Ka}if(ga){if(isNaN(ia)||isNaN(aa))ga.remove(),ga=null;else if(aa+=Ia,ia+=Ja,ga.translate(aa,ia),q){if(0>ia||ia>n)ga.remove(),ga=null}else{var Pb=0;"3d"==H&&(Pb=I*V);if(0>aa||aa>m+Pb)ga.remove(),ga=null}ga&&this.allBullets.push(ga)}}if("regular"==H||"100%"==H){var Qb=f.totalText;if(Qb){var Qa=this.createLabel(x,0,0,Qb,f.totalTextColor);this.allBullets.push(Qa);var Rb=Qa.getBBox(),Sb=Rb.width, | ||
150 | Tb=Rb.height,Ya,Za,Ub=f.totals[J];Ub&&Ub.remove();var $a=0;"column"!=g&&($a=Ha);q?(Za=C,Ya=0>U?D-Sb/2-2-$a:D+Sb/2+3+$a):(Ya=D,Za=0>U?C+Tb/2+$a:C-Tb/2-3-$a);Qa.translate(Ya,Za);f.totals[J]=Qa;q?(0>Za||Za>n)&&Qa.remove():(0>Ya||Ya>m)&&Qa.remove()}}}}}}if("line"==g||"step"==g||"smoothedLine"==g)"smoothedLine"==g?this.drawSmoothedGraph(w,t,O,P):this.drawLineGraph(w,t,O,P),$||this.launchAnimation();this.bulletsHidden&&this.hideBullets()},animateColumns:function(a,b,c,d,e,f){var g=this;c=g.chart.startDuration; | ||
151 | 0<c&&!g.animationPlayed&&(g.seqAn?(a.set.hide(),g.animationArray.push(a),a=setTimeout(function(){g.animate.call(g)},c/(g.end-g.start+1)*(b-g.start)*1E3),g.timeOuts.push(a)):g.animate(a))},createLabel:function(a,b,c,d,e){var f=this.chart,g=a.labelColor;g||(g=this.color);g||(g=f.color);e&&(g=e);e=this.fontSize;void 0===e&&(this.fontSize=e=f.fontSize);var h=this.labelFunction;d=f.formatString(d,a);d=AmCharts.cleanFromEmpty(d);h&&(d=h(a,d));a=AmCharts.text(this.container,d,g,f.fontFamily,e);a.node.style.pointerEvents= | ||
152 | "none";a.translate(b,c);this.bulletSet.push(a);return a},positiveClip:function(a){a.clipRect(this.pmx,this.pmy,this.pmw,this.pmh)},negativeClip:function(a){a.clipRect(this.nmx,this.nmy,this.nmw,this.nmh)},drawLineGraph:function(a,b,c,d){var e=this;if(1<a.length){var f=e.set,g=e.chart,h=e.container,k=h.set(),l=h.set();f.push(l);f.push(k);var m=e.lineAlpha,n=e.lineThickness,f=e.fillAlphas,p=e.lineColorR,q=e.negativeLineAlpha;isNaN(q)&&(q=m);var r=e.lineColorSwitched;r&&(p=r);var r=e.fillColorsR,s=e.fillColorsSwitched; | ||
153 | s&&(r=s);var v=e.dashLength;(s=e.dashLengthSwitched)&&(v=s);var s=e.negativeLineColor,w=e.negativeFillColors,t=e.negativeFillAlphas,u=e.baseCoord;0!==e.negativeBase&&(u=e.valueAxis.getCoordinate(e.negativeBase));m=AmCharts.line(h,a,b,p,m,n,v,!1,!0);k.push(m);k.click(function(a){e.handleGraphEvent(a,"clickGraph")}).mouseover(function(a){e.handleGraphEvent(a,"rollOverGraph")}).mouseout(function(a){e.handleGraphEvent(a,"rollOutGraph")});void 0===s||e.useNegativeColorIfDown||(n=AmCharts.line(h,a,b,s, | ||
154 | q,n,v,!1,!0),l.push(n));if(0<f||0<t)if(n=a.join(";").split(";"),q=b.join(";").split(";"),m=g.type,"serial"==m?0<c.length?(c.reverse(),d.reverse(),n=a.concat(c),q=b.concat(d)):e.rotate?(q.push(q[q.length-1]),n.push(u),q.push(q[0]),n.push(u),q.push(q[0]),n.push(n[0])):(n.push(n[n.length-1]),q.push(u),n.push(n[0]),q.push(u),n.push(a[0]),q.push(q[0])):"xy"==m&&(b=e.fillToAxis)&&(AmCharts.isString(b)&&(b=g.getValueAxisById(b)),"H"==b.orientation?(u="top"==b.position?0:b.viH,n.push(n[n.length-1]),q.push(u), | ||
155 | n.push(n[0]),q.push(u),n.push(a[0]),q.push(q[0])):(u="left"==b.position?0:b.viW,q.push(q[q.length-1]),n.push(u),q.push(q[0]),n.push(u),q.push(q[0]),n.push(n[0]))),a=e.gradientRotation,0<f&&(g=AmCharts.polygon(h,n,q,r,f,1,"#000",0,a),g.pattern(e.pattern),k.push(g)),w||void 0!==s)isNaN(t)&&(t=f),w||(w=s),h=AmCharts.polygon(h,n,q,w,t,1,"#000",0,a),h.pattern(e.pattern),l.push(h),l.click(function(a){e.handleGraphEvent(a,"clickGraph")}).mouseover(function(a){e.handleGraphEvent(a,"rollOverGraph")}).mouseout(function(a){e.handleGraphEvent(a, | ||
156 | "rollOutGraph")});e.applyMask(l,k)}},applyMask:function(a,b){var c=a.length();"serial"!=this.chart.type||this.scrollbar||(this.positiveClip(b),0<c&&this.negativeClip(a))},drawSmoothedGraph:function(a,b,c,d){if(1<a.length){var e=this.set,f=this.container,g=f.set(),h=f.set();e.push(h);e.push(g);var k=this.lineAlpha,l=this.lineThickness,e=this.dashLength,m=this.fillAlphas,n=this.lineColorR,p=this.fillColorsR,q=this.negativeLineColor,r=this.negativeFillColors,s=this.negativeFillAlphas,v=this.baseCoord, | ||
157 | w=this.lineColorSwitched;w&&(n=w);(w=this.fillColorsSwitched)&&(p=w);w=this.negativeLineAlpha;isNaN(w)&&(w=k);k=new AmCharts.Bezier(f,a,b,n,k,l,p,0,e);g.push(k.path);void 0!==q&&(l=new AmCharts.Bezier(f,a,b,q,w,l,p,0,e),h.push(l.path));0<m&&(k=a.join(";").split(";"),n=b.join(";").split(";"),l="",0<c.length?(c.push("M"),d.push("M"),c.reverse(),d.reverse(),k=a.concat(c),n=b.concat(d)):(this.rotate?(l+=" L"+v+","+b[b.length-1],l+=" L"+v+","+b[0]):(l+=" L"+a[a.length-1]+","+v,l+=" L"+a[0]+","+v),l+=" L"+ | ||
158 | a[0]+","+b[0]),c=new AmCharts.Bezier(f,k,n,NaN,0,0,p,m,e,l),c.path.pattern(this.pattern),g.push(c.path),r||void 0!==q)&&(s||(s=m),r||(r=q),a=new AmCharts.Bezier(f,a,b,NaN,0,0,r,s,e,l),a.path.pattern(this.pattern),h.push(a.path));this.applyMask(h,g)}},launchAnimation:function(){var a=this,b=a.chart.startDuration;if(0<b&&!a.animationPlayed){var c=a.set,d=a.bulletSet;AmCharts.VML||(c.attr({opacity:a.startAlpha}),d.attr({opacity:a.startAlpha}));c.hide();d.hide();a.seqAn?(b=setTimeout(function(){a.animateGraphs.call(a)}, | ||
159 | a.index*b*1E3),a.timeOuts.push(b)):a.animateGraphs()}},animateGraphs:function(){var a=this.chart,b=this.set,c=this.bulletSet,d=this.x,e=this.y;b.show();c.show();var f=a.startDuration,a=a.startEffect;b&&(this.rotate?(b.translate(-1E3,e),c.translate(-1E3,e)):(b.translate(d,-1E3),c.translate(d,-1E3)),b.animate({opacity:1,translate:d+","+e},f,a),c.animate({opacity:1,translate:d+","+e},f,a))},animate:function(a){var b=this.chart,c=this.animationArray;!a&&0<c.length&&(a=c[0],c.shift());c=AmCharts[AmCharts.getEffect(b.startEffect)]; | ||
160 | b=b.startDuration;a&&(this.rotate?a.animateWidth(b,c):a.animateHeight(b,c),a.set.show())},legendKeyColor:function(){var a=this.legendColor,b=this.lineAlpha;void 0===a&&(a=this.lineColorR,0===b&&(b=this.fillColorsR)&&(a="object"==typeof b?b[0]:b));return a},legendKeyAlpha:function(){var a=this.legendAlpha;void 0===a&&(a=this.lineAlpha,this.fillAlphas>a&&(a=this.fillAlphas),0===a&&(a=this.bulletAlpha),0===a&&(a=1));return a},createBullet:function(a,b,c,d){d=this.container;var e=this.bulletOffset,f= | ||
161 | this.bulletSize;isNaN(a.bulletSize)||(f=a.bulletSize);var g=a.values.value,h=this.maxValue,k=this.minValue,l=this.maxBulletSize,m=this.minBulletSize;isNaN(h)||(isNaN(g)||(f=(g-k)/(h-k)*(l-m)+m),k==h&&(f=l));h=f;this.bulletAxis&&(f=a.values.error,isNaN(f)||(g=f),f=this.bulletAxis.stepWidth*g);f<this.minBulletSize&&(f=this.minBulletSize);this.rotate?b=a.isNegative?b-e:b+e:c=a.isNegative?c+e:c-e;var n,m=this.bulletColorR;a.lineColor&&(this.bulletColorSwitched=a.lineColor);this.bulletColorSwitched&&(m= | ||
162 | this.bulletColorSwitched);a.isNegative&&void 0!==this.bulletColorNegative&&(m=this.bulletColorNegative);void 0!==a.color&&(m=a.color);var p;"xy"==this.chart.type&&this.valueField&&(p=this.pattern,a.pattern&&(p=a.pattern));e=this.bullet;a.bullet&&(e=a.bullet);var g=this.bulletBorderThickness,k=this.bulletBorderColorR,l=this.bulletBorderAlpha,q=this.bulletAlpha;k||(k=m);this.useLineColorForBulletBorder&&(k=this.lineColorR);var r=a.alpha;isNaN(r)||(q=r);if("none"!=this.bullet||a.bullet)n=AmCharts.bullet(d, | ||
163 | e,f,m,q,g,k,l,h,0,p);if(this.customBullet||a.customBullet)p=this.customBullet,a.customBullet&&(p=a.customBullet),p&&(n&&n.remove(),"function"==typeof p?(n=new p,n.chart=this.chart,a.bulletConfig&&(n.availableSpace=c,n.graph=this,n.graphDataItem=a,n.bulletY=c,a.bulletConfig.minCoord=this.minCoord-c,n.bulletConfig=a.bulletConfig),n.write(d),n=n.set):(this.chart.path&&(p=this.chart.path+p),n=d.set(),d=d.image(p,0,0,f,f),n.push(d),this.centerCustomBullets&&d.translate(-f/2,-f/2)));n&&((a.url||this.showHandOnHover)&& | ||
164 | n.setAttr("cursor","pointer"),"serial"==this.chart.type&&(0>b-0||b-0>this.width||c<-f/2||c-0>this.height)&&(n.remove(),n=null),n&&(this.bulletSet.push(n),n.translate(b,c),this.addListeners(n,a),this.allBullets.push(n)),a.bx=b,a.by=c);a.bulletGraphics=n;return f},showBullets:function(){var a=this.allBullets,b;this.bulletsHidden=!1;for(b=0;b<a.length;b++)a[b].show()},hideBullets:function(){var a=this.allBullets,b;this.bulletsHidden=!0;for(b=0;b<a.length;b++)a[b].hide()},addListeners:function(a,b){var c= | ||
165 | this;a.mouseover(function(a){c.handleRollOver(b,a)}).mouseout(function(a){c.handleRollOut(b,a)}).touchend(function(a){c.handleRollOver(b,a);c.chart.panEventsEnabled&&c.handleClick(b,a)}).touchstart(function(a){c.handleRollOver(b,a)}).click(function(a){c.handleClick(b,a)}).dblclick(function(a){c.handleDoubleClick(b,a)}).contextmenu(function(a){c.handleRightClick(b,a)})},handleRollOver:function(a,b){if(a){var c=this.chart,d={type:"rollOverGraphItem",item:a,index:a.index,graph:this,target:this,chart:this.chart, | ||
166 | event:b};this.fire("rollOverGraphItem",d);c.fire("rollOverGraphItem",d);clearTimeout(c.hoverInt);d=this.showBalloon;c.chartCursor&&"serial"==c.type&&(d=!1,!c.chartCursor.valueBalloonsEnabled&&this.showBalloon&&(d=!0));if(d){var d=c.formatString(this.balloonText,a,!0),e=this.balloonFunction;e&&(d=e(a,a.graph));d=AmCharts.cleanFromEmpty(d);e=c.getBalloonColor(this,a);c.balloon.showBullet=!1;c.balloon.pointerOrientation="V";var f=a.x,g=a.y;c.rotate&&(f=a.y,g=a.x);c.showBalloon(d,e,!0,f+c.marginLeftReal, | ||
167 | g+c.marginTopReal)}}this.handleGraphEvent(b,"rollOverGraph")},handleRollOut:function(a,b){this.chart.hideBalloon();if(a){var c={type:"rollOutGraphItem",item:a,index:a.index,graph:this,target:this,chart:this.chart,event:b};this.fire("rollOutGraphItem",c);this.chart.fire("rollOutGraphItem",c)}this.handleGraphEvent(b,"rollOutGraph")},handleClick:function(a,b){if(a){var c={type:"clickGraphItem",item:a,index:a.index,graph:this,target:this,chart:this.chart,event:b};this.fire("clickGraphItem",c);this.chart.fire("clickGraphItem", | ||
168 | c);AmCharts.getURL(a.url,this.urlTarget)}this.handleGraphEvent(b,"clickGraph")},handleGraphEvent:function(a,b){var c={type:b,graph:this,target:this,chart:this.chart,event:a};this.fire(b,c);this.chart.fire(b,c)},handleRightClick:function(a,b){if(a){var c={type:"rightClickGraphItem",item:a,index:a.index,graph:this,target:this,chart:this.chart,event:b};this.fire("rightClickGraphItem",c);this.chart.fire("rightClickGraphItem",c)}},handleDoubleClick:function(a,b){if(a){var c={type:"doubleClickGraphItem", | ||
169 | item:a,index:a.index,graph:this,target:this,chart:this.chart,event:b};this.fire("doubleClickGraphItem",c);this.chart.fire("doubleClickGraphItem",c)}},zoom:function(a,b){this.start=a;this.end=b;this.draw()},changeOpacity:function(a){var b=this.set;b&&b.setAttr("opacity",a);if(b=this.ownColumns){var c;for(c=0;c<b.length;c++){var d=b[c].set;d&&d.setAttr("opacity",a)}}(b=this.bulletSet)&&b.setAttr("opacity",a)},destroy:function(){AmCharts.remove(this.set);AmCharts.remove(this.bulletSet);var a=this.timeOuts; | ||
170 | if(a){var b;for(b=0;b<a.length;b++)clearTimeout(a[b])}this.timeOuts=[]}});AmCharts.ChartCursor=AmCharts.Class({construct:function(a){this.cname="ChartCursor";this.createEvents("changed","zoomed","onHideCursor","draw","selected","moved");this.enabled=!0;this.cursorAlpha=1;this.selectionAlpha=.2;this.cursorColor="#CC0000";this.categoryBalloonAlpha=1;this.color="#FFFFFF";this.type="cursor";this.zoomed=!1;this.zoomable=!0;this.pan=!1;this.categoryBalloonDateFormat="MMM DD, YYYY";this.categoryBalloonEnabled=this.valueBalloonsEnabled=!0;this.rolledOver=!1;this.cursorPosition= | ||
171 | "middle";this.bulletsEnabled=this.skipZoomDispatch=!1;this.bulletSize=8;this.selectWithoutZooming=this.oneBalloonOnly=!1;this.graphBulletSize=1.7;this.animationDuration=.3;this.zooming=!1;this.adjustment=0;this.avoidBalloonOverlapping=!0;AmCharts.applyTheme(this,a,this.cname)},draw:function(){var a=this;a.destroy();var b=a.chart,c=b.container;a.rotate=b.rotate;a.container=c;c=c.set();c.translate(a.x,a.y);a.set=c;b.cursorSet.push(c);c=new AmCharts.AmBalloon;c.chart=b;a.categoryBalloon=c;AmCharts.copyProperties(b.balloon, | ||
172 | c);c.cornerRadius=0;c.shadowAlpha=0;c.borderThickness=1;c.borderAlpha=1;c.showBullet=!1;var d=a.categoryBalloonColor;void 0===d&&(d=a.cursorColor);c.fillColor=d;c.fillAlpha=a.categoryBalloonAlpha;c.borderColor=d;c.color=a.color;a.rotate&&(c.pointerOrientation="H");a.extraWidth=0;a.prevX=[];a.prevY=[];a.prevTX=[];a.prevTY=[];if(a.valueBalloonsEnabled)for(c=0;c<b.graphs.length;c++)d=new AmCharts.AmBalloon,d.chart=b,AmCharts.copyProperties(b.balloon,d),b.graphs[c].valueBalloon=d;"cursor"==a.type?a.createCursor(): | ||
173 | a.createCrosshair();a.interval=setInterval(function(){a.detectMovement.call(a)},40)},updateData:function(){var a=this.chart;this.data=a.chartData;this.firstTime=a.firstTime;this.lastTime=a.lastTime},createCursor:function(){var a=this.chart,b=this.cursorAlpha,c=a.categoryAxis,d=c.position,e=c.inside,f=c.axisThickness,g=this.categoryBalloon,h,k,l=a.dx,m=a.dy,n=this.x,p=this.y,q=this.width,r=this.height,a=a.rotate,s=c.tickLength;g.pointerWidth=s;a?(h=[0,q,q+l],k=[0,0,m]):(h=[l,0,0],k=[m,0,r]);this.line= | ||
174 | b=AmCharts.line(this.container,h,k,this.cursorColor,b,1);(h=this.fullRectSet)?(h.push(b),h.translate(this.x,this.y)):this.set.push(b);a?(e&&(g.pointerWidth=0),"right"==d?e?g.setBounds(n,p+m,n+q+l,p+r+m):g.setBounds(n+q+l+f,p+m,n+q+1E3,p+r+m):e?g.setBounds(n,p,q+n,r+p):g.setBounds(-1E3,-1E3,n-s-f,p+r+15)):(g.maxWidth=q,c.parseDates&&(s=0,g.pointerWidth=0),"top"==d?e?g.setBounds(n+l,p+m,q+l+n,r+p):g.setBounds(n+l,-1E3,q+l+n,p+m-s-f):e?g.setBounds(n,p,q+n,r+p-s):g.setBounds(n,p+r+s+f-1,n+q,p+r+s+f)); | ||
175 | this.hideCursor()},createCrosshair:function(){var a=this.cursorAlpha,b=this.container,c=AmCharts.line(b,[0,0],[0,this.height],this.cursorColor,a,1),a=AmCharts.line(b,[0,this.width],[0,0],this.cursorColor,a,1);this.set.push(c);this.set.push(a);this.vLine=c;this.hLine=a;this.hideCursor()},detectMovement:function(){var a=this.chart;if(a.mouseIsOver){var b=a.mouseX-this.x,c=a.mouseY-this.y;-.5<b&&b<this.width+1&&0<c&&c<this.height?(this.drawing?this.rolledOver||a.setMouseCursor("crosshair"):this.pan&& | ||
176 | (this.rolledOver||a.setMouseCursor("move")),this.rolledOver=!0,this.setPosition()):this.rolledOver&&(this.handleMouseOut(),this.rolledOver=!1)}else this.rolledOver&&(this.handleMouseOut(),this.rolledOver=!1)},getMousePosition:function(){var a,b=this.width,c=this.height;a=this.chart;this.rotate?(a=a.mouseY-this.y,0>a&&(a=0),a>c&&(a=c)):(a=a.mouseX-this.x-1,0>a&&(a=0),a>b&&(a=b));return a},updateCrosshair:function(){var a=this.chart,b=a.mouseX-this.x,c=a.mouseY-this.y,d=this.vLine,e=this.hLine,b=AmCharts.fitToBounds(b, | ||
177 | 0,this.width),c=AmCharts.fitToBounds(c,0,this.height);0<this.cursorAlpha&&(d.show(),e.show(),d.translate(b,0),e.translate(0,c));this.zooming&&(a.hideXScrollbar&&(b=NaN),a.hideYScrollbar&&(c=NaN),this.updateSelectionSize(b,c));this.fireMoved();a.mouseIsOver||this.zooming||this.hideCursor()},fireMoved:function(){var a=this.chart,b={type:"moved",target:this};b.chart=a;b.zooming=this.zooming;b.x=a.mouseX-this.x;b.y=a.mouseY-this.y;this.fire("moved",b)},updateSelectionSize:function(a,b){AmCharts.remove(this.selection); | ||
178 | var c=this.selectionPosX,d=this.selectionPosY,e=0,f=0,g=this.width,h=this.height;isNaN(a)||(c>a&&(e=a,g=c-a),c<a&&(e=c,g=a-c),c==a&&(e=a,g=0),g+=this.extraWidth,e-=this.extraWidth/2);isNaN(b)||(d>b&&(f=b,h=d-b),d<b&&(f=d,h=b-d),d==b&&(f=b,h=0),h+=this.extraWidth,f-=this.extraWidth/2);0<g&&0<h&&(c=AmCharts.rect(this.container,g,h,this.cursorColor,this.selectionAlpha),c.translate(e+this.x,f+this.y),this.selection=c)},arrangeBalloons:function(){var a=this.valueBalloons,b=this.x,c=this.y,d=this.height+ | ||
179 | c;a.sort(this.compareY);var e;for(e=0;e<a.length;e++){var f=a[e].balloon;f.setBounds(b,c,b+this.width,d);f.prevX=this.prevX[e];f.prevY=this.prevY[e];f.prevTX=this.prevTX[e];f.prevTY=this.prevTY[e];f.draw();d=f.yPos-3}this.arrangeBalloons2()},compareY:function(a,b){return a.yy<b.yy?1:-1},arrangeBalloons2:function(){var a=this.valueBalloons;a.reverse();var b,c=this.x,d,e,f=a.length;for(e=0;e<f;e++){var g=a[e].balloon;b=g.bottom;var h=g.bottom-g.yPos,k=f-e-1;0<e&&b-h<d+3&&(g.setBounds(c,d+3,c+this.width, | ||
180 | d+h+3),g.prevX=this.prevX[k],g.prevY=this.prevY[k],g.prevTX=this.prevTX[k],g.prevTY=this.prevTY[k],g.draw());g.set&&g.set.show();this.prevX[k]=g.prevX;this.prevY[k]=g.prevY;this.prevTX[k]=g.prevTX;this.prevTY[k]=g.prevTY;d=g.bottom}},showBullets:function(){AmCharts.remove(this.allBullets);var a=this.container,b=a.set();this.set.push(b);this.set.show();this.allBullets=b;var b=this.chart.graphs,c;for(c=0;c<b.length;c++){var d=b[c];if(!d.hidden&&d.balloonText){var e=this.data[this.index].axes[d.valueAxis.id].graphs[d.id], | ||
181 | f=e.y;if(!isNaN(f)){var g,h;g=e.x;this.rotate?(h=f,f=g):h=g;d=AmCharts.circle(a,this.bulletSize/2,this.chart.getBalloonColor(d,e,!0),d.cursorBulletAlpha);d.translate(h,f);this.allBullets.push(d)}}}},destroy:function(){this.clear();AmCharts.remove(this.selection);this.selection=null;var a=this.categoryBalloon;a&&a.destroy();this.destroyValueBalloons();AmCharts.remove(this.set)},clear:function(){clearInterval(this.interval)},destroyValueBalloons:function(){var a=this.valueBalloons;if(a){var b;for(b= | ||
182 | 0;b<a.length;b++)a[b].balloon.hide()}},zoom:function(a,b,c,d){var e=this.chart;this.destroyValueBalloons();this.zooming=!1;var f;this.rotate?this.selectionPosY=f=e.mouseY:this.selectionPosX=f=e.mouseX;this.start=a;this.end=b;this.startTime=c;this.endTime=d;this.zoomed=!0;d=e.categoryAxis;e=this.rotate;b=this.width;c=this.height;a=d.stepWidth;this.fullWidth&&(f=1,d.parseDates&&!d.equalSpacing&&(f=d.minDuration()),e?this.extraWidth=c=a*f:(this.extraWidth=b=a*f,this.categoryBalloon.minWidth=b),this.line&& | ||
183 | this.line.remove(),this.line=AmCharts.rect(this.container,b,c,this.cursorColor,this.cursorAlpha,0),this.fullRectSet&&this.fullRectSet.push(this.line));this.stepWidth=a;this.tempVal=this.valueBalloonsEnabled;this.valueBalloonsEnabled=!1;this.setPosition();this.valueBalloonsEnabled=this.tempVal;this.hideCursor()},hideObj:function(a){a&&a.hide()},hideCursor:function(a){void 0===a&&(a=!0);this.hideObj(this.set);this.hideObj(this.categoryBalloon);this.hideObj(this.line);this.hideObj(this.vLine);this.hideObj(this.hLine); | ||
184 | this.hideObj(this.allBullets);this.destroyValueBalloons();this.selectWithoutZooming||AmCharts.remove(this.selection);this.previousIndex=NaN;a&&this.fire("onHideCursor",{type:"onHideCursor",chart:this.chart,target:this});this.drawing||this.chart.setMouseCursor("auto");this.normalizeBulletSize()},setPosition:function(a,b,c){void 0===b&&(b=!0);if("cursor"==this.type){if(this.tempPosition=NaN,AmCharts.ifArray(this.data))isNaN(a)&&(a=this.getMousePosition()),(a!=this.previousMousePosition||!0===this.zoomed|| | ||
185 | this.oneBalloonOnly)&&!isNaN(a)&&("mouse"==this.cursorPosition&&(this.tempPosition=a),isNaN(c)&&(c=this.chart.categoryAxis.xToIndex(a)),c!=this.previousIndex||this.zoomed||"mouse"==this.cursorPosition||this.oneBalloonOnly)&&(this.updateCursor(c,b),this.zoomed=!1),this.previousMousePosition=a}else this.updateCrosshair()},normalizeBulletSize:function(){var a=this.resizedBullets;if(a)for(var b=0;b<a.length;b++){var c=a[b],d=c.bulletGraphics;d&&(d.translate(c.bx,c.by,1),c=c.graph,isNaN(this.graphBulletAlpha)|| | ||
186 | (d.setAttr("fill-opacity",c.bulletAlpha),d.setAttr("stroke-opacity",c.bulletBorderAlpha)))}},updateCursor:function(a,b){var c=this.chart,d=this.fullWidth,e=c.mouseX-this.x,f=c.mouseY-this.y;this.drawingNow&&(AmCharts.remove(this.drawingLine),this.drawingLine=AmCharts.line(this.container,[this.x+this.drawStartX,this.x+e],[this.y+this.drawStartY,this.y+f],this.cursorColor,1,1));if(this.enabled){void 0===b&&(b=!0);this.index=a+=this.adjustment;var g=c.categoryAxis,h=c.dx,k=c.dy,l=this.x+1,m=this.y+1, | ||
187 | n=this.width,p=this.height,q=this.data[a];this.fireMoved();if(q){var r=q.x[g.id],s=c.rotate,v=g.inside,w=this.stepWidth,t=this.categoryBalloon,u=this.firstTime,y=this.lastTime,E=this.cursorPosition,A=g.position,z=this.zooming,K=this.panning,I=c.graphs,F=g.axisThickness;if(c.mouseIsOver||z||K||this.forceShow)if(this.forceShow=!1,K){var h=this.panClickPos,c=this.panClickEndTime,z=this.panClickStartTime,H=this.panClickEnd,l=this.panClickStart,e=(s?h-f:h-e)/w;if(!g.parseDates||g.equalSpacing)e=Math.round(e); | ||
188 | 0!==e&&(h={type:"zoomed",target:this},h.chart=this.chart,g.parseDates&&!g.equalSpacing?(c+e>y&&(e=y-c),z+e<u&&(e=u-z),h.start=Math.round(z+e),h.end=Math.round(c+e),this.fire(h.type,h)):H+e>=this.data.length||0>l+e||(h.start=l+e,h.end=H+e,this.fire(h.type,h)))}else{"start"==E?r-=g.cellWidth/2:"mouse"==E&&(c.mouseIsOver?r=s?f-2:e-2:isNaN(this.tempPosition)||(r=this.tempPosition-2));if(s){if(0>r)if(z)r=0;else{this.hideCursor();return}if(r>p+1)if(z)r=p+1;else{this.hideCursor();return}}else{if(0>r)if(z)r= | ||
189 | 0;else{this.hideCursor();return}if(r>n)if(z)r=n;else{this.hideCursor();return}}if(0<this.cursorAlpha){var L=this.line;s?(u=0,y=r+k,d&&(y-=g.cellWidth/2)):(u=r,y=0,d&&(u-=g.cellWidth/2));w=this.animationDuration;0<w&&!this.zooming?isNaN(this.previousX)?L.translate(u,y):(L.translate(this.previousX,this.previousY),L.animate({translate:u+","+y},w,"easeOutSine")):L.translate(u,y);this.previousX=u;this.previousY=y;L.show()}this.linePos=s?r+k:r;z&&(d&&L.hide(),s?this.updateSelectionSize(NaN,r):this.updateSelectionSize(r, | ||
190 | NaN));w=!0;z&&(w=!1);this.categoryBalloonEnabled&&w?(s?(v&&("right"==A?t.setBounds(l,m+k,l+n+h,m+r+k):t.setBounds(l,m+k,l+n+h,m+r)),"right"==A?v?t.setPosition(l+n+h,m+r+k):t.setPosition(l+n+h+F,m+r+k):v?t.setPosition(l,m+r):t.setPosition(l-F,m+r)):"top"==A?v?t.setPosition(l+r+h,m+k):t.setPosition(l+r+h,m+k-F+1):v?t.setPosition(l+r,m+p):t.setPosition(l+r,m+p+F-1),(u=this.categoryBalloonFunction)?t.showBalloon(u(q.category)):g.parseDates?(g=AmCharts.formatDate(q.category,this.categoryBalloonDateFormat), | ||
191 | -1!=g.indexOf("fff")&&(g=AmCharts.formatMilliseconds(g,q.category)),t.showBalloon(g)):t.showBalloon(AmCharts.fixNewLines(q.category))):t.hide();I&&this.bulletsEnabled&&this.showBullets();if(this.oneBalloonOnly){k=Infinity;for(g=0;g<I.length;g++)u=I[g],u.showBalloon&&!u.hidden&&u.balloonText&&(y=q.axes[u.valueAxis.id].graphs[u.id],t=y.y,isNaN(t)||(s?Math.abs(e-t)<k&&(k=Math.abs(e-t),H=u):Math.abs(f-t)<k&&(k=Math.abs(f-t),H=u)));this.mostCloseGraph&&(H=this.mostCloseGraph)}if(a!=this.previousIndex|| | ||
192 | H!=this.previousMostCloseGraph)if(this.normalizeBulletSize(),this.destroyValueBalloons(),this.resizedBullets=[],I&&this.valueBalloonsEnabled&&w&&c.balloon.enabled){this.valueBalloons=w=[];for(g=0;g<I.length;g++)if(u=I[g],t=NaN,(!this.oneBalloonOnly||u==H)&&u.showBalloon&&!u.hidden&&u.balloonText&&("step"==u.type&&"left"==u.stepDirection&&(q=this.data[a+1]),q)){if(y=q.axes[u.valueAxis.id].graphs[u.id])t=y.y;if(this.showNextAvailable&&isNaN(t)&&a+1<this.data.length)for(k=a+1;k<this.data.length;k++)if(r= | ||
193 | this.data[k])if(y=r.axes[u.valueAxis.id].graphs[u.id],t=y.y,!isNaN(t))break;if(!isNaN(t)){r=y.x;v=!0;if(s){if(k=t,0>r||r>p)v=!1}else if(k=r,r=t,0>k||k>n+h+1)v=!1;v&&(1!=this.graphBulletSize&&AmCharts.isModern&&(v=y.bulletGraphics)&&(v.getBBox(),v.translate(y.bx,y.by,this.graphBulletSize),this.resizedBullets.push(y),A=this.graphBulletAlpha,isNaN(A)||(v.setAttr("fill-opacity",A),v.setAttr("stroke-opacity",A))),v=u.valueBalloon,A=c.getBalloonColor(u,y),v.setBounds(l,m,l+n,m+p),v.pointerOrientation="H", | ||
194 | F=this.balloonPointerOrientation,"vertical"==F&&(v.pointerOrientation="V"),"horizontal"==F&&(v.pointerOrientation="H"),v.changeColor(A),void 0!==u.balloonAlpha&&(v.fillAlpha=u.balloonAlpha),void 0!==u.balloonTextColor&&(v.color=u.balloonTextColor),v.setPosition(k+l,r+m),k=c.formatString(u.balloonText,y,!0),(r=u.balloonFunction)&&(k=r(y,u).toString()),""!==k&&(s?v.showBalloon(k):(v.text=k,v.show=!0),w.push({yy:t,balloon:v})),!s&&v.set&&(v.set.hide(),u=v.textDiv)&&(u.style.visibility="hidden"))}}this.avoidBalloonOverlapping&& | ||
195 | this.arrangeBalloons()}b?(h={type:"changed"},h.index=a,h.chart=this.chart,h.zooming=z,h.mostCloseGraph=H,h.position=s?f:e,h.target=this,c.fire("changed",h),this.fire("changed",h),this.skipZoomDispatch=!1):(this.skipZoomDispatch=!0,c.updateLegendValues(a));this.previousIndex=a;this.previousMostCloseGraph=H}}}else this.hideCursor()},enableDrawing:function(a){this.enabled=!a;this.hideCursor();this.rolledOver=!1;this.drawing=a},isZooming:function(a){a&&a!=this.zooming&&this.handleMouseDown("fake");a|| | ||
196 | a==this.zooming||this.handleMouseUp()},handleMouseOut:function(){if(this.enabled)if(this.zooming)this.setPosition();else{this.index=void 0;var a={type:"changed",index:void 0,target:this};a.chart=this.chart;this.fire("changed",a);this.hideCursor()}},handleReleaseOutside:function(){this.handleMouseUp()},handleMouseUp:function(){var a=this.chart,b=this.data,c;if(a){var d=a.mouseX-this.x,e=a.mouseY-this.y;if(this.drawingNow){this.drawingNow=!1;AmCharts.remove(this.drawingLine);c=this.drawStartX;var f= | ||
197 | this.drawStartY;if(2<Math.abs(c-d)||2<Math.abs(f-e))c={type:"draw",target:this,chart:a,initialX:c,initialY:f,finalX:d,finalY:e},this.fire(c.type,c)}if(this.enabled&&0<b.length){if(this.pan)this.rolledOver=!1;else if(this.zoomable&&this.zooming){c=this.selectWithoutZooming?{type:"selected"}:{type:"zoomed"};c.target=this;c.chart=a;if("cursor"==this.type)this.rotate?this.selectionPosY=e:this.selectionPosX=e=d,2>Math.abs(e-this.initialMouse)&&this.fromIndex==this.index||(this.index<this.fromIndex?(c.end= | ||
198 | this.fromIndex,c.start=this.index):(c.end=this.index,c.start=this.fromIndex),e=a.categoryAxis,e.parseDates&&!e.equalSpacing&&(c.start=b[c.start].time,c.end=a.getEndTime(b[c.end].time)),this.skipZoomDispatch||this.fire(c.type,c));else{var g=this.initialMouseX,h=this.initialMouseY;3>Math.abs(d-g)&&3>Math.abs(e-h)||(b=Math.min(g,d),f=Math.min(h,e),d=Math.abs(g-d),e=Math.abs(h-e),a.hideXScrollbar&&(b=0,d=this.width),a.hideYScrollbar&&(f=0,e=this.height),c.selectionHeight=e,c.selectionWidth=d,c.selectionY= | ||
199 | f,c.selectionX=b,this.skipZoomDispatch||this.fire(c.type,c))}this.selectWithoutZooming||AmCharts.remove(this.selection)}this.panning=this.zooming=this.skipZoomDispatch=!1}}},showCursorAt:function(a){var b=this.chart.categoryAxis;a=b.parseDates?b.dateToCoordinate(a):b.categoryToCoordinate(a);this.previousMousePosition=NaN;this.forceShow=!0;this.setPosition(a,!1)},clearSelection:function(){AmCharts.remove(this.selection)},handleMouseDown:function(a){if(this.zoomable||this.pan||this.drawing){var b=this.rotate, | ||
200 | c=this.chart,d=c.mouseX-this.x,e=c.mouseY-this.y;if(0<d&&d<this.width&&0<e&&e<this.height||"fake"==a)this.setPosition(),this.selectWithoutZooming&&AmCharts.remove(this.selection),this.drawing?(this.drawStartY=e,this.drawStartX=d,this.drawingNow=!0):this.pan?(this.zoomable=!1,c.setMouseCursor("move"),this.panning=!0,this.panClickPos=b?e:d,this.panClickStart=this.start,this.panClickEnd=this.end,this.panClickStartTime=this.startTime,this.panClickEndTime=this.endTime):this.zoomable&&("cursor"==this.type? | ||
201 | (this.fromIndex=this.index,b?(this.initialMouse=e,this.selectionPosY=this.linePos):(this.initialMouse=d,this.selectionPosX=this.linePos)):(this.initialMouseX=d,this.initialMouseY=e,this.selectionPosX=d,this.selectionPosY=e),this.zooming=!0)}}});AmCharts.SimpleChartScrollbar=AmCharts.Class({construct:function(a){this.createEvents("zoomed");this.backgroundColor="#D4D4D4";this.backgroundAlpha=1;this.selectedBackgroundColor="#EFEFEF";this.scrollDuration=this.selectedBackgroundAlpha=1;this.resizeEnabled=!0;this.hideResizeGrips=!1;this.scrollbarHeight=20;this.updateOnReleaseOnly=!1;9>document.documentMode&&(this.updateOnReleaseOnly=!0);this.dragIconWidth=18;this.dragIconHeight=25;AmCharts.applyTheme(this,a,"SimpleChartScrollbar")},draw:function(){var a= | ||
202 | this;a.destroy();a.interval=setInterval(function(){a.updateScrollbar.call(a)},40);var b=a.chart.container,c=a.rotate,d=a.chart,e=b.set();a.set=e;d.scrollbarsSet.push(e);var f,g;c?(f=a.scrollbarHeight,g=d.plotAreaHeight):(g=a.scrollbarHeight,f=d.plotAreaWidth);a.width=f;if((a.height=g)&&f){var h=AmCharts.rect(b,f,g,a.backgroundColor,a.backgroundAlpha,1,a.backgroundColor,a.backgroundAlpha);a.bg=h;e.push(h);h=AmCharts.rect(b,f,g,"#000",.005);e.push(h);a.invisibleBg=h;h.click(function(){a.handleBgClick()}).mouseover(function(){a.handleMouseOver()}).mouseout(function(){a.handleMouseOut()}).touchend(function(){a.handleBgClick()}); | ||
203 | h=AmCharts.rect(b,f,g,a.selectedBackgroundColor,a.selectedBackgroundAlpha);a.selectedBG=h;e.push(h);f=AmCharts.rect(b,f,g,"#000",.005);a.dragger=f;e.push(f);f.mousedown(function(b){a.handleDragStart(b)}).mouseup(function(){a.handleDragStop()}).mouseover(function(){a.handleDraggerOver()}).mouseout(function(){a.handleMouseOut()}).touchstart(function(b){a.handleDragStart(b)}).touchend(function(){a.handleDragStop()});f=d.pathToImages;c?(h=f+"dragIconH.gif",f=a.dragIconWidth,c=a.dragIconHeight):(h=f+"dragIcon.gif", | ||
204 | c=a.dragIconWidth,f=a.dragIconHeight);g=b.image(h,0,0,c,f);var h=b.image(h,0,0,c,f),k=10,l=20;d.panEventsEnabled&&(k=25,l=a.scrollbarHeight);var m=AmCharts.rect(b,k,l,"#000",.005),n=AmCharts.rect(b,k,l,"#000",.005);n.translate(-(k-c)/2,-(l-f)/2);m.translate(-(k-c)/2,-(l-f)/2);c=b.set([g,n]);b=b.set([h,m]);a.iconLeft=c;a.iconRight=b;c.mousedown(function(){a.leftDragStart()}).mouseup(function(){a.leftDragStop()}).mouseover(function(){a.iconRollOver()}).mouseout(function(){a.iconRollOut()}).touchstart(function(b){a.leftDragStart()}).touchend(function(){a.leftDragStop()}); | ||
205 | b.mousedown(function(){a.rightDragStart()}).mouseup(function(){a.rightDragStop()}).mouseover(function(){a.iconRollOver()}).mouseout(function(){a.iconRollOut()}).touchstart(function(b){a.rightDragStart()}).touchend(function(){a.rightDragStop()});AmCharts.ifArray(d.chartData)?e.show():e.hide();a.hideDragIcons();a.clipDragger(!1)}e.translate(a.x,a.y)},updateScrollbarSize:function(a,b){var c=this.dragger,d,e,f,g;this.rotate?(d=0,e=a,f=this.width+1,g=b-a,c.setAttr("height",b-a),c.setAttr("y",e)):(d=a, | ||
206 | e=0,f=b-a,g=this.height+1,c.setAttr("width",b-a),c.setAttr("x",d));this.clipAndUpdate(d,e,f,g)},updateScrollbar:function(){var a,b=!1,c,d,e=this.x,f=this.y,g=this.dragger,h=this.getDBox();c=h.x+e;d=h.y+f;var k=h.width,h=h.height,l=this.rotate,m=this.chart,n=this.width,p=this.height,q=m.mouseX,r=m.mouseY;a=this.initialMouse;m.mouseIsOver&&(this.dragging&&(m=this.initialCoord,l?(a=m+(r-a),0>a&&(a=0),m=p-h,a>m&&(a=m),g.setAttr("y",a)):(a=m+(q-a),0>a&&(a=0),m=n-k,a>m&&(a=m),g.setAttr("x",a))),this.resizingRight&& | ||
207 | (l?(a=r-d,a+d>p+f&&(a=p-d+f),0>a?(this.resizingRight=!1,b=this.resizingLeft=!0):(0===a&&(a=.1),g.setAttr("height",a))):(a=q-c,a+c>n+e&&(a=n-c+e),0>a?(this.resizingRight=!1,b=this.resizingLeft=!0):(0===a&&(a=.1),g.setAttr("width",a)))),this.resizingLeft&&(l?(c=d,d=r,d<f&&(d=f),d>p+f&&(d=p+f),a=!0===b?c-d:h+c-d,0>a?(this.resizingRight=!0,this.resizingLeft=!1,g.setAttr("y",c+h-f)):(0===a&&(a=.1),g.setAttr("y",d-f),g.setAttr("height",a))):(d=q,d<e&&(d=e),d>n+e&&(d=n+e),a=!0===b?c-d:k+c-d,0>a?(this.resizingRight= | ||
208 | !0,this.resizingLeft=!1,g.setAttr("x",c+k-e)):(0===a&&(a=.1),g.setAttr("x",d-e),g.setAttr("width",a)))),this.clipDragger(!0))},clipDragger:function(a){var b=this.getDBox();if(b){var c=b.x,d=b.y,e=b.width,b=b.height,f=!1;if(this.rotate){if(c=0,e=this.width+1,this.clipY!=d||this.clipH!=b)f=!0}else if(d=0,b=this.height+1,this.clipX!=c||this.clipW!=e)f=!0;f&&(this.clipAndUpdate(c,d,e,b),a&&(this.updateOnReleaseOnly||this.dispatchScrollbarEvent()))}},maskGraphs:function(){},clipAndUpdate:function(a,b, | ||
209 | c,d){this.clipX=a;this.clipY=b;this.clipW=c;this.clipH=d;this.selectedBG.clipRect(a,b,c,d);this.updateDragIconPositions();this.maskGraphs(a,b,c,d)},dispatchScrollbarEvent:function(){if(this.skipEvent)this.skipEvent=!1;else{var a=this.chart;a.hideBalloon();var b=this.getDBox(),c=b.x,d=b.y,e=b.width,b=b.height;this.rotate?(c=d,e=this.height/b):e=this.width/e;a={type:"zoomed",position:c,chart:a,target:this,multiplier:e};this.fire(a.type,a)}},updateDragIconPositions:function(){var a=this.getDBox(),b= | ||
210 | a.x,c=a.y,d=this.iconLeft,e=this.iconRight,f,g,h=this.scrollbarHeight;this.rotate?(f=this.dragIconWidth,g=this.dragIconHeight,d.translate(this.x+(h-g)/2,this.y+c-f/2),e.translate(this.x+(h-g)/2,this.y+c+a.height-f/2)):(f=this.dragIconHeight,g=this.dragIconWidth,d.translate(this.x+b-g/2,this.y+(h-f)/2),e.translate(this.x+b-g/2+a.width,this.y+(h-f)/2))},showDragIcons:function(){this.resizeEnabled&&(this.iconLeft.show(),this.iconRight.show())},hideDragIcons:function(){if(!this.resizingLeft&&!this.resizingRight&& | ||
211 | !this.dragging){if(this.hideResizeGrips||!this.resizeEnabled)this.iconLeft.hide(),this.iconRight.hide();this.removeCursors()}},removeCursors:function(){this.chart.setMouseCursor("auto")},relativeZoom:function(a,b){this.dragger.stop();this.multiplier=a;this.position=b;this.updateScrollbarSize(b,this.rotate?b+this.height/a:b+this.width/a)},destroy:function(){this.clear();AmCharts.remove(this.set);AmCharts.remove(this.iconRight);AmCharts.remove(this.iconLeft)},clear:function(){clearInterval(this.interval)}, | ||
212 | handleDragStart:function(){var a=this.chart;this.dragger.stop();this.removeCursors();this.dragging=!0;var b=this.getDBox();this.rotate?(this.initialCoord=b.y,this.initialMouse=a.mouseY):(this.initialCoord=b.x,this.initialMouse=a.mouseX)},handleDragStop:function(){this.updateOnReleaseOnly&&(this.updateScrollbar(),this.skipEvent=!1,this.dispatchScrollbarEvent());this.dragging=!1;this.mouseIsOver&&this.removeCursors();this.updateScrollbar()},handleDraggerOver:function(){this.handleMouseOver()},leftDragStart:function(){this.dragger.stop(); | ||
213 | this.resizingLeft=!0},leftDragStop:function(){this.resizingLeft=!1;this.mouseIsOver||this.removeCursors();this.updateOnRelease()},rightDragStart:function(){this.dragger.stop();this.resizingRight=!0},rightDragStop:function(){this.resizingRight=!1;this.mouseIsOver||this.removeCursors();this.updateOnRelease()},iconRollOut:function(){this.removeCursors()},iconRollOver:function(){this.rotate?this.chart.setMouseCursor("n-resize"):this.chart.setMouseCursor("e-resize");this.handleMouseOver()},getDBox:function(){if(this.dragger)return this.dragger.getBBox()}, | ||
214 | handleBgClick:function(){if(!this.resizingRight&&!this.resizingLeft){this.zooming=!0;var a,b,c=this.scrollDuration,d=this.dragger;a=this.getDBox();var e=a.height,f=a.width;b=this.chart;var g=this.y,h=this.x,k=this.rotate;k?(a="y",b=b.mouseY-e/2-g,b=AmCharts.fitToBounds(b,0,this.height-e)):(a="x",b=b.mouseX-f/2-h,b=AmCharts.fitToBounds(b,0,this.width-f));this.updateOnReleaseOnly?(this.skipEvent=!1,d.setAttr(a,b),this.dispatchScrollbarEvent(),this.clipDragger()):(b=Math.round(b),k?d.animate({y:b},c, | ||
215 | ">"):d.animate({x:b},c,">"))}},updateOnRelease:function(){this.updateOnReleaseOnly&&(this.updateScrollbar(),this.skipEvent=!1,this.dispatchScrollbarEvent())},handleReleaseOutside:function(){if(this.set){if(this.resizingLeft||this.resizingRight||this.dragging)this.updateOnRelease(),this.removeCursors();this.mouseIsOver=this.dragging=this.resizingRight=this.resizingLeft=!1;this.hideDragIcons();this.updateScrollbar()}},handleMouseOver:function(){this.mouseIsOver=!0;this.showDragIcons()},handleMouseOut:function(){this.mouseIsOver= | ||
216 | !1;this.hideDragIcons()}});AmCharts.ChartScrollbar=AmCharts.Class({inherits:AmCharts.SimpleChartScrollbar,construct:function(a){this.cname="ChartScrollbar";AmCharts.ChartScrollbar.base.construct.call(this,a);this.graphLineColor="#BBBBBB";this.graphLineAlpha=0;this.graphFillColor="#BBBBBB";this.graphFillAlpha=1;this.selectedGraphLineColor="#888888";this.selectedGraphLineAlpha=0;this.selectedGraphFillColor="#888888";this.selectedGraphFillAlpha=1;this.gridCount=0;this.gridColor="#FFFFFF";this.gridAlpha=.7;this.skipEvent=this.autoGridCount= | ||
217 | !1;this.color="#FFFFFF";this.scrollbarCreated=!1;this.offset=0;AmCharts.applyTheme(this,a,this.cname)},init:function(){var a=this.categoryAxis,b=this.chart;a||(this.categoryAxis=a=new AmCharts.CategoryAxis);a.chart=b;a.id="scrollbar";a.dateFormats=b.categoryAxis.dateFormats;a.markPeriodChange=b.categoryAxis.markPeriodChange;a.boldPeriodBeginning=b.categoryAxis.boldPeriodBeginning;a.axisItemRenderer=AmCharts.RecItem;a.axisRenderer=AmCharts.RecAxis;a.guideFillRenderer=AmCharts.RecFill;a.inside=!0;a.fontSize= | ||
218 | this.fontSize;a.tickLength=0;a.axisAlpha=0;AmCharts.isString(this.graph)&&(this.graph=AmCharts.getObjById(b.graphs,this.graph));if(a=this.graph){var c=this.valueAxis;c||(this.valueAxis=c=new AmCharts.ValueAxis,c.visible=!1,c.scrollbar=!0,c.axisItemRenderer=AmCharts.RecItem,c.axisRenderer=AmCharts.RecAxis,c.guideFillRenderer=AmCharts.RecFill,c.labelsEnabled=!1,c.chart=b);b=this.unselectedGraph;b||(b=new AmCharts.AmGraph,b.scrollbar=!0,this.unselectedGraph=b,b.negativeBase=a.negativeBase,b.noStepRisers= | ||
219 | a.noStepRisers);b=this.selectedGraph;b||(b=new AmCharts.AmGraph,b.scrollbar=!0,this.selectedGraph=b,b.negativeBase=a.negativeBase,b.noStepRisers=a.noStepRisers)}this.scrollbarCreated=!0},draw:function(){var a=this;AmCharts.ChartScrollbar.base.draw.call(a);a.scrollbarCreated||a.init();var b=a.chart,c=b.chartData,d=a.categoryAxis,e=a.rotate,f=a.x,g=a.y,h=a.width,k=a.height,l=b.categoryAxis,m=a.set;d.setOrientation(!e);d.parseDates=l.parseDates;d.rotate=e;d.equalSpacing=l.equalSpacing;d.minPeriod=l.minPeriod; | ||
220 | d.startOnAxis=l.startOnAxis;d.viW=h;d.viH=k;d.width=h;d.height=k;d.gridCount=a.gridCount;d.gridColor=a.gridColor;d.gridAlpha=a.gridAlpha;d.color=a.color;d.tickLength=0;d.axisAlpha=0;d.autoGridCount=a.autoGridCount;d.parseDates&&!d.equalSpacing&&d.timeZoom(b.firstTime,b.lastTime);d.zoom(0,c.length-1);if(l=a.graph){var n=a.valueAxis,p=l.valueAxis;n.id=p.id;n.rotate=e;n.setOrientation(e);n.width=h;n.height=k;n.viW=h;n.viH=k;n.dataProvider=c;n.reversed=p.reversed;n.logarithmic=p.logarithmic;n.gridAlpha= | ||
221 | 0;n.axisAlpha=0;m.push(n.set);e?(n.y=g,n.x=0):(n.x=f,n.y=0);var f=Infinity,g=-Infinity,q;for(q=0;q<c.length;q++){var r=c[q].axes[p.id].graphs[l.id].values,s;for(s in r)if(r.hasOwnProperty(s)&&"percents"!=s&&"total"!=s){var v=r[s];v<f&&(f=v);v>g&&(g=v)}}Infinity!=f&&(n.minimum=f);-Infinity!=g&&(n.maximum=g+.1*(g-f));f==g&&(n.minimum-=1,n.maximum+=1);void 0!==a.minimum&&(n.minimum=a.minimum);void 0!==a.maximum&&(n.maximum=a.maximum);n.zoom(0,c.length-1);s=a.unselectedGraph;s.id=l.id;s.rotate=e;s.chart= | ||
222 | b;s.data=c;s.valueAxis=n;s.chart=l.chart;s.categoryAxis=a.categoryAxis;s.periodSpan=l.periodSpan;s.valueField=l.valueField;s.openField=l.openField;s.closeField=l.closeField;s.highField=l.highField;s.lowField=l.lowField;s.lineAlpha=a.graphLineAlpha;s.lineColorR=a.graphLineColor;s.fillAlphas=a.graphFillAlpha;s.fillColorsR=a.graphFillColor;s.connect=l.connect;s.hidden=l.hidden;s.width=h;s.height=k;s.pointPosition=l.pointPosition;s.stepDirection=l.stepDirection;s.periodSpan=l.periodSpan;p=a.selectedGraph; | ||
223 | p.id=l.id;p.rotate=e;p.chart=b;p.data=c;p.valueAxis=n;p.chart=l.chart;p.categoryAxis=d;p.periodSpan=l.periodSpan;p.valueField=l.valueField;p.openField=l.openField;p.closeField=l.closeField;p.highField=l.highField;p.lowField=l.lowField;p.lineAlpha=a.selectedGraphLineAlpha;p.lineColorR=a.selectedGraphLineColor;p.fillAlphas=a.selectedGraphFillAlpha;p.fillColorsR=a.selectedGraphFillColor;p.connect=l.connect;p.hidden=l.hidden;p.width=h;p.height=k;p.pointPosition=l.pointPosition;p.stepDirection=l.stepDirection; | ||
224 | p.periodSpan=l.periodSpan;b=a.graphType;b||(b=l.type);s.type=b;p.type=b;c=c.length-1;s.zoom(0,c);p.zoom(0,c);p.set.click(function(){a.handleBackgroundClick()}).mouseover(function(){a.handleMouseOver()}).mouseout(function(){a.handleMouseOut()});s.set.click(function(){a.handleBackgroundClick()}).mouseover(function(){a.handleMouseOver()}).mouseout(function(){a.handleMouseOut()});m.push(s.set);m.push(p.set)}m.push(d.set);m.push(d.labelsSet);a.bg.toBack();a.invisibleBg.toFront();a.dragger.toFront();a.iconLeft.toFront(); | ||
225 | a.iconRight.toFront()},timeZoom:function(a,b,c){this.startTime=a;this.endTime=b;this.timeDifference=b-a;this.skipEvent=!AmCharts.toBoolean(c);this.zoomScrollbar();this.skipEvent||this.dispatchScrollbarEvent()},zoom:function(a,b){this.start=a;this.end=b;this.skipEvent=!0;this.zoomScrollbar()},dispatchScrollbarEvent:function(){if(this.skipEvent)this.skipEvent=!1;else{var a=this.chart.chartData,b,c,d=this.dragger.getBBox();b=d.x;var e=d.y,f=d.width;c=d.height;d=this.chart;this.rotate?b=e:c=f;f={type:"zoomed", | ||
226 | target:this};f.chart=d;var g=this.categoryAxis,h=this.stepWidth,e=d.minSelectedTime;if(g.parseDates&&!g.equalSpacing){if(a=d.lastTime,d=d.firstTime,g.minDuration(),g=Math.round(b/h)+d,b=this.dragging?g+this.timeDifference:Math.round((b+c)/h)+d,g>b&&(g=b),0<e&&b-g<e&&(b=Math.round(g+(b-g)/2),c=Math.round(e/2),g=b-c,b+=c),b>a&&(b=a),b-e<g&&(g=b-e),g<d&&(g=d),g+e>b&&(b=g+e),g!=this.startTime||b!=this.endTime)this.startTime=g,this.endTime=b,f.start=g,f.end=b,f.startDate=new Date(g),f.endDate=new Date(b), | ||
227 | this.fire(f.type,f)}else if(g.startOnAxis||(b+=h/2),c-=this.stepWidth/2,e=g.xToIndex(b),b=g.xToIndex(b+c),e!=this.start||this.end!=b)g.startOnAxis&&(this.resizingRight&&e==b&&b++,this.resizingLeft&&e==b&&(0<e?e--:b=1)),this.start=e,this.end=this.dragging?this.start+this.difference:b,f.start=this.start,f.end=this.end,g.parseDates&&(a[this.start]&&(f.startDate=new Date(a[this.start].time)),a[this.end]&&(f.endDate=new Date(a[this.end].time))),this.fire(f.type,f)}this.zoomScrollbar()},zoomScrollbar:function(){var a, | ||
228 | b;a=this.chart;var c=a.chartData,d=this.categoryAxis;d.parseDates&&!d.equalSpacing?(c=d.stepWidth,d=a.firstTime,a=c*(this.startTime-d),b=c*(this.endTime-d)):(a=c[this.start].x[d.id],b=c[this.end].x[d.id],c=d.stepWidth,d.startOnAxis||(d=c/2,a-=d,b+=d));this.stepWidth=c;this.updateScrollbarSize(a,b)},maskGraphs:function(a,b,c,d){var e=this.selectedGraph;e&&e.set.clipRect(a,b,c,d)},handleDragStart:function(){AmCharts.ChartScrollbar.base.handleDragStart.call(this);this.difference=this.end-this.start; | ||
229 | this.timeDifference=this.endTime-this.startTime;0>this.timeDifference&&(this.timeDifference=0)},handleBackgroundClick:function(){AmCharts.ChartScrollbar.base.handleBackgroundClick.call(this);this.dragging||(this.difference=this.end-this.start,this.timeDifference=this.endTime-this.startTime,0>this.timeDifference&&(this.timeDifference=0))}});AmCharts.AmBalloon=AmCharts.Class({construct:function(a){this.cname="AmBalloon";this.enabled=!0;this.fillColor="#FFFFFF";this.fillAlpha=.8;this.borderThickness=2;this.borderColor="#FFFFFF";this.borderAlpha=1;this.cornerRadius=0;this.maximumWidth=220;this.horizontalPadding=8;this.verticalPadding=4;this.pointerWidth=6;this.pointerOrientation="V";this.color="#000000";this.adjustBorderColor=!0;this.show=this.follow=this.showBullet=!1;this.bulletSize=3;this.shadowAlpha=.4;this.shadowColor="#000000";this.fadeOutDuration= | ||
230 | this.animationDuration=.3;this.fixedPosition=!1;this.offsetY=6;this.offsetX=1;this.textAlign="center";AmCharts.isModern||(this.offsetY*=1.5);AmCharts.applyTheme(this,a,this.cname)},draw:function(){var a=this.pointToX,b=this.pointToY;this.deltaSignX=this.deltaSignY=1;var c=this.chart;AmCharts.VML&&(this.fadeOutDuration=0);this.xAnim&&c.stopAnim(this.xAnim);this.yAnim&&c.stopAnim(this.yAnim);if(!isNaN(a)){var d=this.follow,e=c.container,f=this.set;AmCharts.remove(f);this.removeDiv();f=e.set();f.node.style.pointerEvents= | ||
231 | "none";this.set=f;c.balloonsSet.push(f);if(this.show){var g=this.l,h=this.t,k=this.r,l=this.b,m=this.balloonColor,n=this.fillColor,p=this.borderColor,q=n;void 0!=m&&(this.adjustBorderColor?q=p=m:n=m);var r=this.horizontalPadding,s=this.verticalPadding,v=this.pointerWidth,w=this.pointerOrientation,t=this.cornerRadius,u=c.fontFamily,y=this.fontSize;void 0==y&&(y=c.fontSize);var m=document.createElement("div"),E=m.style;E.pointerEvents="none";E.position="absolute";var A=this.minWidth,z="";isNaN(A)|| | ||
232 | (z="min-width:"+(A-2*r)+"px; ");m.innerHTML='<div style="text-align:'+this.textAlign+"; "+z+"max-width:"+this.maxWidth+"px; font-size:"+y+"px; color:"+this.color+"; font-family:"+u+'">'+this.text+"</div>";c.chartDiv.appendChild(m);this.textDiv=m;y=m.offsetWidth;u=m.offsetHeight;m.clientHeight&&(y=m.clientWidth,u=m.clientHeight);u+=2*s;z=y+2*r;!isNaN(A)&&z<A&&(z=A);window.opera&&(u+=2);var K=!1,y=this.offsetY;c.handDrawn&&(y+=c.handDrawScatter+2);"H"!=w?(A=a-z/2,b<h+u+10&&"down"!=w?(K=!0,d&&(b+=y), | ||
233 | y=b+v,this.deltaSignY=-1):(d&&(b-=y),y=b-u-v,this.deltaSignY=1)):(2*v>u&&(v=u/2),y=b-u/2,a<g+(k-g)/2?(A=a+v,this.deltaSignX=-1):(A=a-z-v,this.deltaSignX=1));y+u>=l&&(y=l-u);y<h&&(y=h);A<g&&(A=g);A+z>k&&(A=k-z);var h=y+s,l=A+r,s=this.shadowAlpha,I=this.shadowColor,r=this.borderThickness,F=this.bulletSize,H;0<t||0===v?(0<s&&(a=AmCharts.rect(e,z,u,n,0,r+1,I,s,this.cornerRadius),AmCharts.isModern?a.translate(1,1):a.translate(4,4),f.push(a)),n=AmCharts.rect(e,z,u,n,this.fillAlpha,r,p,this.borderAlpha, | ||
234 | this.cornerRadius),this.showBullet&&(H=AmCharts.circle(e,F,q,this.fillAlpha),f.push(H))):(q=[],t=[],"H"!=w?(g=a-A,g>z-v&&(g=z-v),g<v&&(g=v),q=[0,g-v,a-A,g+v,z,z,0,0],t=K?[0,0,b-y,0,0,u,u,0]:[u,u,b-y,u,u,0,0,u]):(q=b-y,q>u-v&&(q=u-v),q<v&&(q=v),t=[0,q-v,b-y,q+v,u,u,0,0],q=a<g+(k-g)/2?[0,0,A<a?0:a-A,0,0,z,z,0]:[z,z,A+z>a?z:a-A,z,z,0,0,z]),0<s&&(a=AmCharts.polygon(e,q,t,n,0,r,I,s),a.translate(1,1),f.push(a)),n=AmCharts.polygon(e,q,t,n,this.fillAlpha,r,p,this.borderAlpha));this.bg=n;f.push(n);n.toFront(); | ||
235 | e=1*this.deltaSignX;E.left=l+"px";E.top=h+"px";f.translate(A-e,y);n=n.getBBox();this.bottom=y+u+1;this.yPos=n.y+y;H&&H.translate(this.pointToX-A+e,b-y);b=this.animationDuration;0<this.animationDuration&&!d&&!isNaN(this.prevX)&&(f.translate(this.prevX,this.prevY),f.animate({translate:A-e+","+y},b,"easeOutSine"),m&&(E.left=this.prevTX+"px",E.top=this.prevTY+"px",this.xAnim=c.animate({node:m},"left",this.prevTX,l,b,"easeOutSine","px"),this.yAnim=c.animate({node:m},"top",this.prevTY,h,b,"easeOutSine", | ||
236 | "px")));this.prevX=A-e;this.prevY=y;this.prevTX=l;this.prevTY=h}}},followMouse:function(){if(this.follow&&this.show){var a=this.chart.mouseX-this.offsetX*this.deltaSignX,b=this.chart.mouseY;this.pointToX=a;this.pointToY=b;if(a!=this.previousX||b!=this.previousY)if(this.previousX=a,this.previousY=b,0===this.cornerRadius)this.draw();else{var c=this.set;if(c){var d=c.getBBox(),a=a-d.width/2,e=b-d.height-10;a<this.l&&(a=this.l);a>this.r-d.width&&(a=this.r-d.width);e<this.t&&(e=b+10);c.translate(a,e); | ||
237 | b=this.textDiv.style;b.left=a+this.horizontalPadding+"px";b.top=e+this.verticalPadding+"px"}}}},changeColor:function(a){this.balloonColor=a},setBounds:function(a,b,c,d){this.l=a;this.t=b;this.r=c;this.b=d;this.destroyTO&&clearTimeout(this.destroyTO)},showBalloon:function(a){this.text=a;this.show=!0;this.destroyTO&&clearTimeout(this.destroyTO);a=this.chart;this.fadeAnim1&&a.stopAnim(this.fadeAnim1);this.fadeAnim2&&a.stopAnim(this.fadeAnim2);this.draw()},hide:function(){var a=this,b=a.fadeOutDuration, | ||
238 | c=a.chart;if(0<b){a.destroyTO=setTimeout(function(){a.destroy.call(a)},1E3*b);a.follow=!1;a.show=!1;var d=a.set;d&&(d.setAttr("opacity",a.fillAlpha),a.fadeAnim1=d.animate({opacity:0},b,"easeInSine"));a.textDiv&&(a.fadeAnim2=c.animate({node:a.textDiv},"opacity",1,0,b,"easeInSine",""))}else a.show=!1,a.follow=!1,a.destroy()},setPosition:function(a,b,c){this.pointToX=a;this.pointToY=b;c&&(a==this.previousX&&b==this.previousY||this.draw());this.previousX=a;this.previousY=b},followCursor:function(a){var b= | ||
239 | this;(b.follow=a)?(b.pShowBullet=b.showBullet,b.showBullet=!1):void 0!==b.pShowBullet&&(b.showBullet=b.pShowBullet);clearInterval(b.interval);var c=b.chart.mouseX,d=b.chart.mouseY;!isNaN(c)&&a&&(b.pointToX=c-b.offsetX*b.deltaSignX,b.pointToY=d,b.followMouse(),b.interval=setInterval(function(){b.followMouse.call(b)},40))},removeDiv:function(){if(this.textDiv){var a=this.textDiv.parentNode;a&&a.removeChild(this.textDiv)}},destroy:function(){clearInterval(this.interval);AmCharts.remove(this.set);this.removeDiv(); | ||
240 | this.set=null}});AmCharts.AmCoordinateChart=AmCharts.Class({inherits:AmCharts.AmChart,construct:function(a){AmCharts.AmCoordinateChart.base.construct.call(this,a);this.theme=a;this.createEvents("rollOverGraphItem","rollOutGraphItem","clickGraphItem","doubleClickGraphItem","rightClickGraphItem","clickGraph","rollOverGraph","rollOutGraph");this.startAlpha=1;this.startDuration=0;this.startEffect="elastic";this.sequencedAnimation=!0;this.colors="#FF6600 #FCD202 #B0DE09 #0D8ECF #2A0CD0 #CD0D74 #CC0000 #00CC00 #0000CC #DDDDDD #999999 #333333 #990000".split(" "); | ||
241 | this.balloonDateFormat="MMM DD, YYYY";this.valueAxes=[];this.graphs=[];this.guides=[];this.gridAboveGraphs=!1;AmCharts.applyTheme(this,a,"AmCoordinateChart")},initChart:function(){AmCharts.AmCoordinateChart.base.initChart.call(this);var a=this.categoryAxis;a&&(this.categoryAxis=AmCharts.processObject(a,AmCharts.CategoryAxis,this.theme));this.processValueAxes();this.createValueAxes();this.processGraphs();this.processGuides();AmCharts.VML&&(this.startAlpha=1);this.setLegendData(this.graphs);this.gridAboveGraphs&& | ||
242 | this.gridSet.toFront()},createValueAxes:function(){if(0===this.valueAxes.length){var a=new AmCharts.ValueAxis;this.addValueAxis(a)}},parseData:function(){this.processValueAxes();this.processGraphs()},parseSerialData:function(){var a=this.graphs,b,c={},d=this.seriesIdField;d||(d=this.categoryField);this.chartData=[];var e=this.dataProvider;if(e){var f=!1,g,h=this.categoryAxis,k,l;h&&(f=h.parseDates,k=h.forceShowField,l=h.labelColorField,g=h.categoryFunction);var m,n,p={},q;f&&(b=AmCharts.extractPeriod(h.minPeriod), | ||
243 | m=b.period,n=b.count,q=AmCharts.getPeriodDuration(m,n));var r={};this.lookupTable=r;var s,v=this.dataDateFormat,w={};for(s=0;s<e.length;s++){var t={},u=e[s];b=u[this.categoryField];t.dataContext=u;t.category=g?g(b,u,h):String(b);k&&(t.forceShow=u[k]);l&&(t.labelColor=u[l]);r[u[d]]=t;if(f&&(b=h.categoryFunction?h.categoryFunction(b,u,h):b instanceof Date?AmCharts.newDate(b,h.minPeriod):v?AmCharts.stringToDate(b,v):new Date(b),b=AmCharts.resetDateToMin(b,m,n,h.firstDayOfWeek),t.category=b,t.time=b.getTime(), | ||
244 | isNaN(t.time)))continue;var y=this.valueAxes;t.axes={};t.x={};var E;for(E=0;E<y.length;E++){var A=y[E].id;t.axes[A]={};t.axes[A].graphs={};var z;for(z=0;z<a.length;z++){b=a[z];var K=b.id,I=b.periodValue;if(b.valueAxis.id==A){t.axes[A].graphs[K]={};var F={};F.index=s;var H=u;b.dataProvider&&(H=c);F.values=this.processValues(H,b,I);!b.connect&&w&&w[K]&&t.time-p[K]>1.1*q&&(w[K].gap=!0);this.processFields(b,F,H);F.category=t.category;F.serialDataItem=t;F.graph=b;t.axes[A].graphs[K]=F}p[K]=t.time;w[K]= | ||
245 | F}}this.chartData[s]=t}}for(c=0;c<a.length;c++)b=a[c],b.dataProvider&&this.parseGraphData(b)},processValues:function(a,b,c){var d={},e,f=!1;"candlestick"!=b.type&&"ohlc"!=b.type||""===c||(f=!0);e=Number(a[b.valueField+c]);isNaN(e)||(d.value=e);e=Number(a[b.errorField+c]);isNaN(e)||(d.error=e);f&&(c="Open");e=Number(a[b.openField+c]);isNaN(e)||(d.open=e);f&&(c="Close");e=Number(a[b.closeField+c]);isNaN(e)||(d.close=e);f&&(c="Low");e=Number(a[b.lowField+c]);isNaN(e)||(d.low=e);f&&(c="High");e=Number(a[b.highField+ | ||
246 | c]);isNaN(e)||(d.high=e);return d},parseGraphData:function(a){var b=a.dataProvider,c=a.seriesIdField;c||(c=this.seriesIdField);c||(c=this.categoryField);var d;for(d=0;d<b.length;d++){var e=b[d],f=this.lookupTable[String(e[c])],g=a.valueAxis.id;f&&(g=f.axes[g].graphs[a.id],g.serialDataItem=f,g.values=this.processValues(e,a,a.periodValue),this.processFields(a,g,e))}},addValueAxis:function(a){a.chart=this;this.valueAxes.push(a);this.validateData()},removeValueAxesAndGraphs:function(){var a=this.valueAxes, | ||
247 | b;for(b=a.length-1;-1<b;b--)this.removeValueAxis(a[b])},removeValueAxis:function(a){var b=this.graphs,c;for(c=b.length-1;0<=c;c--){var d=b[c];d&&d.valueAxis==a&&this.removeGraph(d)}b=this.valueAxes;for(c=b.length-1;0<=c;c--)b[c]==a&&b.splice(c,1);this.validateData()},addGraph:function(a){this.graphs.push(a);this.chooseGraphColor(a,this.graphs.length-1);this.validateData()},removeGraph:function(a){var b=this.graphs,c;for(c=b.length-1;0<=c;c--)b[c]==a&&(b.splice(c,1),a.destroy());this.validateData()}, | ||
248 | processValueAxes:function(){var a=this.valueAxes,b;for(b=0;b<a.length;b++){var c=a[b],c=AmCharts.processObject(c,AmCharts.ValueAxis,this.theme);a[b]=c;c.chart=this;c.id||(c.id="valueAxisAuto"+b+"_"+(new Date).getTime());void 0===c.usePrefixes&&(c.usePrefixes=this.usePrefixes)}},processGuides:function(){var a=this.guides,b=this.categoryAxis;if(a)for(var c=0;c<a.length;c++){var d=a[c];(void 0!==d.category||void 0!==d.date)&&b&&b.addGuide(d);var e=d.valueAxis;e?(AmCharts.isString(e)&&(e=this.getValueAxisById(e)), | ||
249 | e?e.addGuide(d):this.valueAxes[0].addGuide(d)):isNaN(d.value)||this.valueAxes[0].addGuide(d)}},processGraphs:function(){var a=this.graphs,b;for(b=0;b<a.length;b++){var c=a[b],c=AmCharts.processObject(c,AmCharts.AmGraph,this.theme);a[b]=c;this.chooseGraphColor(c,b);c.chart=this;AmCharts.isString(c.valueAxis)&&(c.valueAxis=this.getValueAxisById(c.valueAxis));c.valueAxis||(c.valueAxis=this.valueAxes[0]);c.id||(c.id="graphAuto"+b+"_"+(new Date).getTime())}},formatString:function(a,b,c){var d=b.graph, | ||
250 | e=d.valueAxis;e.duration&&b.values.value&&(e=AmCharts.formatDuration(b.values.value,e.duration,"",e.durationUnits,e.maxInterval,e.numberFormatter),a=a.split("[[value]]").join(e));a=AmCharts.massReplace(a,{"[[title]]":d.title,"[[description]]":b.description});a=c?AmCharts.fixNewLines(a):AmCharts.fixBrakes(a);return a=AmCharts.cleanFromEmpty(a)},getBalloonColor:function(a,b,c){var d=a.lineColor,e=a.balloonColor;c&&(e=d);c=a.fillColorsR;"object"==typeof c?d=c[0]:void 0!==c&&(d=c);b.isNegative&&(c=a.negativeLineColor, | ||
251 | a=a.negativeFillColors,"object"==typeof a?c=a[0]:void 0!==a&&(c=a),void 0!==c&&(d=c));void 0!==b.color&&(d=b.color);void 0===e&&(e=d);return e},getGraphById:function(a){return AmCharts.getObjById(this.graphs,a)},getValueAxisById:function(a){return AmCharts.getObjById(this.valueAxes,a)},processFields:function(a,b,c){if(a.itemColors){var d=a.itemColors,e=b.index;b.color=e<d.length?d[e]:AmCharts.randomColor()}d="lineColor color alpha fillColors description bullet customBullet bulletSize bulletConfig url labelColor dashLength pattern".split(" "); | ||
252 | for(e=0;e<d.length;e++){var f=d[e],g=a[f+"Field"];g&&(g=c[g],AmCharts.isDefined(g)&&(b[f]=g))}b.dataContext=c},chooseGraphColor:function(a,b){if(a.lineColor)a.lineColorR=a.lineColor;else{var c;c=this.colors.length>b?this.colors[b]:AmCharts.randomColor();a.lineColorR=c}a.fillColorsR=a.fillColors?a.fillColors:a.lineColorR;a.bulletBorderColorR=a.bulletBorderColor?a.bulletBorderColor:a.useLineColorForBulletBorder?a.lineColorR:a.bulletColor;a.bulletColorR=a.bulletColor?a.bulletColor:a.lineColorR;if(c= | ||
253 | this.patterns)a.pattern=c[b]},handleLegendEvent:function(a){var b=a.type;a=a.dataItem;if(!this.legend.data&&a){var c=a.hidden,d=a.showBalloon;switch(b){case "clickMarker":this.textClickEnabled&&(d?this.hideGraphsBalloon(a):this.showGraphsBalloon(a));break;case "clickLabel":d?this.hideGraphsBalloon(a):this.showGraphsBalloon(a);break;case "rollOverItem":c||this.highlightGraph(a);break;case "rollOutItem":c||this.unhighlightGraph();break;case "hideItem":this.hideGraph(a);break;case "showItem":this.showGraph(a)}}}, | ||
254 | highlightGraph:function(a){var b=this.graphs,c,d=.2;this.legend&&(d=this.legend.rollOverGraphAlpha);if(1!=d)for(c=0;c<b.length;c++){var e=b[c];e!=a&&e.changeOpacity(d)}},unhighlightGraph:function(){var a;this.legend&&(a=this.legend.rollOverGraphAlpha);if(1!=a){a=this.graphs;var b;for(b=0;b<a.length;b++)a[b].changeOpacity(1)}},showGraph:function(a){a.switchable&&(a.hidden=!1,this.dataChanged=!0,"xy"!=this.type&&(this.marginsUpdated=!1),this.chartCreated&&this.initChart())},hideGraph:function(a){a.switchable&& | ||
255 | (this.dataChanged=!0,"xy"!=this.type&&(this.marginsUpdated=!1),a.hidden=!0,this.chartCreated&&this.initChart())},hideGraphsBalloon:function(a){a.showBalloon=!1;this.updateLegend()},showGraphsBalloon:function(a){a.showBalloon=!0;this.updateLegend()},updateLegend:function(){this.legend&&this.legend.invalidateSize()},resetAnimation:function(){var a=this.graphs;if(a){var b;for(b=0;b<a.length;b++)a[b].animationPlayed=!1}},animateAgain:function(){this.resetAnimation();this.validateNow()}});AmCharts.AmSlicedChart=AmCharts.Class({inherits:AmCharts.AmChart,construct:function(a){this.createEvents("rollOverSlice","rollOutSlice","clickSlice","pullOutSlice","pullInSlice","rightClickSlice");AmCharts.AmSlicedChart.base.construct.call(this,a);this.colors="#FF0F00 #FF6600 #FF9E01 #FCD202 #F8FF01 #B0DE09 #04D215 #0D8ECF #0D52D1 #2A0CD0 #8A0CCF #CD0D74 #754DEB #DDDDDD #999999 #333333 #000000 #57032A #CA9726 #990000 #4B0C25".split(" ");this.alpha=1;this.groupPercent=0;this.groupedTitle="Other";this.groupedPulled= | ||
256 | !1;this.groupedAlpha=1;this.marginLeft=0;this.marginBottom=this.marginTop=10;this.marginRight=0;this.hoverAlpha=1;this.outlineColor="#FFFFFF";this.outlineAlpha=0;this.outlineThickness=1;this.startAlpha=0;this.startDuration=1;this.startEffect="bounce";this.sequencedAnimation=!0;this.pullOutDuration=1;this.pullOutEffect="bounce";this.pullOnHover=this.pullOutOnlyOne=!1;this.labelsEnabled=!0;this.labelTickColor="#000000";this.labelTickAlpha=.2;this.hideLabelsPercent=0;this.urlTarget="_self";this.autoMarginOffset= | ||
257 | 10;this.gradientRatio=[];this.maxLabelWidth=200;AmCharts.applyTheme(this,a,"AmSlicedChart")},initChart:function(){AmCharts.AmSlicedChart.base.initChart.call(this);this.dataChanged&&(this.parseData(),this.dispatchDataUpdated=!0,this.dataChanged=!1,this.setLegendData(this.chartData));this.drawChart()},handleLegendEvent:function(a){var b=a.type;a=a.dataItem;if(!this.legend.data&&a){var c=a.hidden;switch(b){case "clickMarker":c||this.clickSlice(a);break;case "clickLabel":c||this.clickSlice(a);break;case "rollOverItem":c|| | ||
258 | this.rollOverSlice(a,!1);break;case "rollOutItem":c||this.rollOutSlice(a);break;case "hideItem":this.hideSlice(a);break;case "showItem":this.showSlice(a)}}},invalidateVisibility:function(){this.recalculatePercents();this.initChart();var a=this.legend;a&&a.invalidateSize()},addEventListeners:function(a,b){var c=this;a.mouseover(function(a){c.rollOverSlice(b,!0,a)}).mouseout(function(a){c.rollOutSlice(b,a)}).touchend(function(a){c.rollOverSlice(b,a);c.panEventsEnabled&&c.clickSlice(b,a)}).touchstart(function(a){c.rollOverSlice(b, | ||
259 | a)}).click(function(a){c.clickSlice(b,a)}).contextmenu(function(a){c.handleRightClick(b,a)})},formatString:function(a,b,c){a=AmCharts.formatValue(a,b,["value"],this.nf,"",this.usePrefixes,this.prefixesOfSmallNumbers,this.prefixesOfBigNumbers);a=AmCharts.formatValue(a,b,["percents"],this.pf);a=AmCharts.massReplace(a,{"[[title]]":b.title,"[[description]]":b.description});-1!=a.indexOf("[[")&&(a=AmCharts.formatDataContextValue(a,b.dataContext));a=c?AmCharts.fixNewLines(a):AmCharts.fixBrakes(a);return a= | ||
260 | AmCharts.cleanFromEmpty(a)},startSlices:function(){var a;for(a=0;a<this.chartData.length;a++)0<this.startDuration&&this.sequencedAnimation?this.setStartTO(a):this.startSlice(this.chartData[a])},setStartTO:function(a){var b=this;a=setTimeout(function(){b.startSequenced.call(b)},b.startDuration/b.chartData.length*500*a);b.timeOuts.push(a)},pullSlices:function(a){var b=this.chartData,c;for(c=0;c<b.length;c++){var d=b[c];d.pulled&&this.pullSlice(d,1,a)}},startSequenced:function(){var a=this.chartData, | ||
261 | b;for(b=0;b<a.length;b++)if(!a[b].started){this.startSlice(this.chartData[b]);break}},startSlice:function(a){a.started=!0;var b=a.wedge,c=this.startDuration;b&&0<c&&(0<a.alpha&&b.show(),b.translate(a.startX,a.startY),b.animate({opacity:1,translate:"0,0"},c,this.startEffect))},showLabels:function(){var a=this.chartData,b;for(b=0;b<a.length;b++){var c=a[b];if(0<c.alpha){var d=c.label;d&&d.show();(c=c.tick)&&c.show()}}},showSlice:function(a){isNaN(a)?a.hidden=!1:this.chartData[a].hidden=!1;this.invalidateVisibility()}, | ||
262 | hideSlice:function(a){isNaN(a)?a.hidden=!0:this.chartData[a].hidden=!0;this.hideBalloon();this.invalidateVisibility()},rollOverSlice:function(a,b,c){isNaN(a)||(a=this.chartData[a]);clearTimeout(this.hoverInt);if(!a.hidden){this.pullOnHover&&this.pullSlice(a,1);1>this.hoverAlpha&&a.wedge&&a.wedge.attr({opacity:this.hoverAlpha});var d=a.balloonX,e=a.balloonY;a.pulled&&(d+=a.pullX,e+=a.pullY);var f=this.formatString(this.balloonText,a,!0),g=this.balloonFunction;g&&(f=g(a,f));g=AmCharts.adjustLuminosity(a.color, | ||
263 | -.15);this.showBalloon(f,g,b,d,e);a={type:"rollOverSlice",dataItem:a,chart:this,event:c};this.fire(a.type,a)}},rollOutSlice:function(a,b){isNaN(a)||(a=this.chartData[a]);a.wedge&&a.wedge.attr({opacity:1});this.hideBalloon();var c={type:"rollOutSlice",dataItem:a,chart:this,event:b};this.fire(c.type,c)},clickSlice:function(a,b){isNaN(a)||(a=this.chartData[a]);a.pulled?this.pullSlice(a,0):this.pullSlice(a,1);AmCharts.getURL(a.url,this.urlTarget);var c={type:"clickSlice",dataItem:a,chart:this,event:b}; | ||
264 | this.fire(c.type,c)},handleRightClick:function(a,b){isNaN(a)||(a=this.chartData[a]);var c={type:"rightClickSlice",dataItem:a,chart:this,event:b};this.fire(c.type,c)},drawTicks:function(){var a=this.chartData,b;for(b=0;b<a.length;b++){var c=a[b];if(c.label){var d=c.ty,d=AmCharts.line(this.container,[c.tx0,c.tx,c.tx2],[c.ty0,d,d],this.labelTickColor,this.labelTickAlpha);c.tick=d;c.wedge.push(d)}}},initialStart:function(){var a=this,b=a.startDuration,c=setTimeout(function(){a.showLabels.call(a)},1E3* | ||
265 | b);a.timeOuts.push(c);a.chartCreated?a.pullSlices(!0):(a.startSlices(),0<b?(b=setTimeout(function(){a.pullSlices.call(a)},1200*b),a.timeOuts.push(b)):a.pullSlices(!0))},pullSlice:function(a,b,c){var d=this.pullOutDuration;!0===c&&(d=0);(c=a.wedge)&&(0<d?c.animate({translate:b*a.pullX+","+b*a.pullY},d,this.pullOutEffect):c.translate(b*a.pullX,b*a.pullY));1==b?(a.pulled=!0,this.pullOutOnlyOne&&this.pullInAll(a.index),a={type:"pullOutSlice",dataItem:a,chart:this}):(a.pulled=!1,a={type:"pullInSlice", | ||
266 | dataItem:a,chart:this});this.fire(a.type,a)},pullInAll:function(a){var b=this.chartData,c;for(c=0;c<this.chartData.length;c++)c!=a&&b[c].pulled&&this.pullSlice(b[c],0)},pullOutAll:function(a){a=this.chartData;var b;for(b=0;b<a.length;b++)a[b].pulled||this.pullSlice(a[b],1)},parseData:function(){var a=[];this.chartData=a;var b=this.dataProvider;isNaN(this.pieAlpha)||(this.alpha=this.pieAlpha);if(void 0!==b){var c=b.length,d=0,e,f,g;for(e=0;e<c;e++){f={};var h=b[e];f.dataContext=h;f.value=Number(h[this.valueField]); | ||
267 | (g=h[this.titleField])||(g="");f.title=g;f.pulled=AmCharts.toBoolean(h[this.pulledField],!1);(g=h[this.descriptionField])||(g="");f.description=g;f.labelRadius=Number(h[this.labelRadiusField]);f.switchable=!0;f.url=h[this.urlField];g=h[this.patternField];!g&&this.patterns&&(g=this.patterns[e]);f.pattern=g;f.visibleInLegend=AmCharts.toBoolean(h[this.visibleInLegendField],!0);g=h[this.alphaField];f.alpha=void 0!==g?Number(g):this.alpha;g=h[this.colorField];void 0!==g&&(f.color=AmCharts.toColor(g)); | ||
268 | f.labelColor=AmCharts.toColor(h[this.labelColorField]);d+=f.value;f.hidden=!1;a[e]=f}for(e=b=0;e<c;e++)f=a[e],f.percents=f.value/d*100,f.percents<this.groupPercent&&b++;1<b&&(this.groupValue=0,this.removeSmallSlices(),a.push({title:this.groupedTitle,value:this.groupValue,percents:this.groupValue/d*100,pulled:this.groupedPulled,color:this.groupedColor,url:this.groupedUrl,description:this.groupedDescription,alpha:this.groupedAlpha,pattern:this.groupedPattern,dataContext:{}}));c=this.baseColor;c||(c= | ||
269 | this.pieBaseColor);d=this.brightnessStep;d||(d=this.pieBrightnessStep);for(e=0;e<a.length;e++)c?g=AmCharts.adjustLuminosity(c,e*d/100):(g=this.colors[e],void 0===g&&(g=AmCharts.randomColor())),void 0===a[e].color&&(a[e].color=g);this.recalculatePercents()}},recalculatePercents:function(){var a=this.chartData,b=0,c,d;for(c=0;c<a.length;c++)d=a[c],!d.hidden&&0<d.value&&(b+=d.value);for(c=0;c<a.length;c++)d=this.chartData[c],d.percents=!d.hidden&&0<d.value?100*d.value/b:0},removeSmallSlices:function(){var a= | ||
270 | this.chartData,b;for(b=a.length-1;0<=b;b--)a[b].percents<this.groupPercent&&(this.groupValue+=a[b].value,a.splice(b,1))},animateAgain:function(){var a=this;a.startSlices();for(var b=0;b<a.chartData.length;b++){var c=a.chartData[b];c.started=!1;var d=c.wedge;d&&d.translate(c.startX,c.startY)}b=a.startDuration;0<b?(b=setTimeout(function(){a.pullSlices.call(a)},1200*b),a.timeOuts.push(b)):a.pullSlices()},measureMaxLabel:function(){var a=this.chartData,b=0,c;for(c=0;c<a.length;c++){var d=a[c],e=this.formatString(this.labelText, | ||
271 | d),f=this.labelFunction;f&&(e=f(d,e));d=AmCharts.text(this.container,e,this.color,this.fontFamily,this.fontSize);e=d.getBBox().width;e>b&&(b=e);d.remove()}return b}});AmCharts.AmRectangularChart=AmCharts.Class({inherits:AmCharts.AmCoordinateChart,construct:function(a){AmCharts.AmRectangularChart.base.construct.call(this,a);this.theme=a;this.createEvents("zoomed");this.marginRight=this.marginBottom=this.marginTop=this.marginLeft=20;this.verticalPosition=this.horizontalPosition=this.depth3D=this.angle=0;this.heightMultiplier=this.widthMultiplier=1;this.plotAreaFillColors="#FFFFFF";this.plotAreaFillAlphas=0;this.plotAreaBorderColor="#000000";this.plotAreaBorderAlpha= | ||
272 | 0;this.zoomOutButtonImageSize=17;this.zoomOutButtonImage="lens.png";this.zoomOutText="Show all";this.zoomOutButtonColor="#e5e5e5";this.zoomOutButtonAlpha=0;this.zoomOutButtonRollOverAlpha=1;this.zoomOutButtonPadding=8;this.trendLines=[];this.autoMargins=!0;this.marginsUpdated=!1;this.autoMarginOffset=10;AmCharts.applyTheme(this,a,"AmRectangularChart")},initChart:function(){AmCharts.AmRectangularChart.base.initChart.call(this);this.updateDxy();var a=!0;!this.marginsUpdated&&this.autoMargins&&(this.resetMargins(), | ||
273 | a=!1);this.processScrollbars();this.updateMargins();this.updatePlotArea();this.updateScrollbars();this.updateTrendLines();this.updateChartCursor();this.updateValueAxes();a&&(this.scrollbarOnly||this.updateGraphs())},drawChart:function(){AmCharts.AmRectangularChart.base.drawChart.call(this);this.drawPlotArea();if(AmCharts.ifArray(this.chartData)){var a=this.chartCursor;a&&a.draw();a=this.zoomOutText;""!==a&&a&&this.drawZoomOutButton()}},resetMargins:function(){var a={},b;if("serial"==this.type){var c= | ||
274 | this.valueAxes;for(b=0;b<c.length;b++){var d=c[b];d.ignoreAxisWidth||(d.setOrientation(this.rotate),d.fixAxisPosition(),a[d.position]=!0)}(b=this.categoryAxis)&&!b.ignoreAxisWidth&&(b.setOrientation(!this.rotate),b.fixAxisPosition(),b.fixAxisPosition(),a[b.position]=!0)}else{d=this.xAxes;c=this.yAxes;for(b=0;b<d.length;b++){var e=d[b];e.ignoreAxisWidth||(e.setOrientation(!0),e.fixAxisPosition(),a[e.position]=!0)}for(b=0;b<c.length;b++)d=c[b],d.ignoreAxisWidth||(d.setOrientation(!1),d.fixAxisPosition(), | ||
275 | a[d.position]=!0)}a.left&&(this.marginLeft=0);a.right&&(this.marginRight=0);a.top&&(this.marginTop=0);a.bottom&&(this.marginBottom=0);this.fixMargins=a},measureMargins:function(){var a=this.valueAxes,b,c=this.autoMarginOffset,d=this.fixMargins,e=this.realWidth,f=this.realHeight,g=c,h=c,k=e;b=f;var l;for(l=0;l<a.length;l++)b=this.getAxisBounds(a[l],g,k,h,b),g=Math.round(b.l),k=Math.round(b.r),h=Math.round(b.t),b=Math.round(b.b);if(a=this.categoryAxis)b=this.getAxisBounds(a,g,k,h,b),g=Math.round(b.l), | ||
276 | k=Math.round(b.r),h=Math.round(b.t),b=Math.round(b.b);d.left&&g<c&&(this.marginLeft=Math.round(-g+c));d.right&&k>=e-c&&(this.marginRight=Math.round(k-e+c));d.top&&h<c+this.titleHeight&&(this.marginTop=Math.round(this.marginTop-h+c+this.titleHeight));d.bottom&&b>f-c&&(this.marginBottom=Math.round(this.marginBottom+b-f+c));this.initChart()},getAxisBounds:function(a,b,c,d,e){if(!a.ignoreAxisWidth){var f=a.labelsSet,g=a.tickLength;a.inside&&(g=0);if(f)switch(f=a.getBBox(),a.position){case "top":a=f.y; | ||
277 | d>a&&(d=a);break;case "bottom":a=f.y+f.height;e<a&&(e=a);break;case "right":a=f.x+f.width+g+3;c<a&&(c=a);break;case "left":a=f.x-g,b>a&&(b=a)}}return{l:b,t:d,r:c,b:e}},drawZoomOutButton:function(){var a=this,b=a.container.set();a.zoomButtonSet.push(b);var c=a.color,d=a.fontSize,e=a.zoomOutButtonImageSize,f=a.zoomOutButtonImage,g=AmCharts.lang.zoomOutText||a.zoomOutText,h=a.zoomOutButtonColor,k=a.zoomOutButtonAlpha,l=a.zoomOutButtonFontSize,m=a.zoomOutButtonPadding;isNaN(l)||(d=l);(l=a.zoomOutButtonFontColor)&& | ||
278 | (c=l);var l=a.zoomOutButton,n;l&&(l.fontSize&&(d=l.fontSize),l.color&&(c=l.color),l.backgroundColor&&(h=l.backgroundColor),isNaN(l.backgroundAlpha)||(a.zoomOutButtonRollOverAlpha=l.backgroundAlpha));var p=l=0;void 0!==a.pathToImages&&f&&(n=a.container.image(a.pathToImages+f,0,0,e,e),b.push(n),n=n.getBBox(),l=n.width+5);void 0!==g&&(c=AmCharts.text(a.container,g,c,a.fontFamily,d,"start"),d=c.getBBox(),p=n?n.height/2-3:d.height/2,c.translate(l,p),b.push(c));n=b.getBBox();c=1;AmCharts.isModern||(c=0); | ||
279 | h=AmCharts.rect(a.container,n.width+2*m+5,n.height+2*m-2,h,1,1,h,c);h.setAttr("opacity",k);h.translate(-m,-m);b.push(h);h.toBack();a.zbBG=h;n=h.getBBox();b.translate(a.marginLeftReal+a.plotAreaWidth-n.width+m,a.marginTopReal+m);b.hide();b.mouseover(function(){a.rollOverZB()}).mouseout(function(){a.rollOutZB()}).click(function(){a.clickZB()}).touchstart(function(){a.rollOverZB()}).touchend(function(){a.rollOutZB();a.clickZB()});for(k=0;k<b.length;k++)b[k].attr({cursor:"pointer"});a.zbSet=b},rollOverZB:function(){this.zbBG.setAttr("opacity", | ||
280 | this.zoomOutButtonRollOverAlpha)},rollOutZB:function(){this.zbBG.setAttr("opacity",this.zoomOutButtonAlpha)},clickZB:function(){this.zoomOut()},zoomOut:function(){this.updateScrollbar=!0;this.zoom()},drawPlotArea:function(){var a=this.dx,b=this.dy,c=this.marginLeftReal,d=this.marginTopReal,e=this.plotAreaWidth-1,f=this.plotAreaHeight-1,g=this.plotAreaFillColors,h=this.plotAreaFillAlphas,k=this.plotAreaBorderColor,l=this.plotAreaBorderAlpha;this.trendLinesSet.clipRect(c,d,e,f);"object"==typeof h&& | ||
281 | (h=h[0]);g=AmCharts.polygon(this.container,[0,e,e,0,0],[0,0,f,f,0],g,h,1,k,l,this.plotAreaGradientAngle);g.translate(c+a,d+b);this.set.push(g);0!==a&&0!==b&&(g=this.plotAreaFillColors,"object"==typeof g&&(g=g[0]),g=AmCharts.adjustLuminosity(g,-.15),e=AmCharts.polygon(this.container,[0,a,e+a,e,0],[0,b,b,0,0],g,h,1,k,l),e.translate(c,d+f),this.set.push(e),a=AmCharts.polygon(this.container,[0,0,a,a,0],[0,f,f+b,b,0],g,h,1,k,l),a.translate(c,d),this.set.push(a));(c=this.bbset)&&this.scrollbarOnly&&c.remove()}, | ||
282 | updatePlotArea:function(){var a=this.updateWidth(),b=this.updateHeight(),c=this.container;this.realWidth=a;this.realWidth=b;c&&this.container.setSize(a,b);a=a-this.marginLeftReal-this.marginRightReal-this.dx;b=b-this.marginTopReal-this.marginBottomReal;1>a&&(a=1);1>b&&(b=1);this.plotAreaWidth=Math.round(a);this.plotAreaHeight=Math.round(b)},updateDxy:function(){this.dx=Math.round(this.depth3D*Math.cos(this.angle*Math.PI/180));this.dy=Math.round(-this.depth3D*Math.sin(this.angle*Math.PI/180));this.d3x= | ||
283 | Math.round(this.columnSpacing3D*Math.cos(this.angle*Math.PI/180));this.d3y=Math.round(-this.columnSpacing3D*Math.sin(this.angle*Math.PI/180))},updateMargins:function(){var a=this.getTitleHeight();this.titleHeight=a;this.marginTopReal=this.marginTop-this.dy+a;this.marginBottomReal=this.marginBottom;this.marginLeftReal=this.marginLeft;this.marginRightReal=this.marginRight},updateValueAxes:function(){var a=this.valueAxes,b=this.marginLeftReal,c=this.marginTopReal,d=this.plotAreaHeight,e=this.plotAreaWidth, | ||
284 | f;for(f=0;f<a.length;f++){var g=a[f];g.axisRenderer=AmCharts.RecAxis;g.guideFillRenderer=AmCharts.RecFill;g.axisItemRenderer=AmCharts.RecItem;g.dx=this.dx;g.dy=this.dy;g.viW=e-1;g.viH=d-1;g.marginsChanged=!0;g.viX=b;g.viY=c;this.updateObjectSize(g)}},updateObjectSize:function(a){a.width=(this.plotAreaWidth-1)*this.widthMultiplier;a.height=(this.plotAreaHeight-1)*this.heightMultiplier;a.x=this.marginLeftReal+this.horizontalPosition;a.y=this.marginTopReal+this.verticalPosition},updateGraphs:function(){var a= | ||
285 | this.graphs,b;for(b=0;b<a.length;b++){var c=a[b];c.x=this.marginLeftReal+this.horizontalPosition;c.y=this.marginTopReal+this.verticalPosition;c.width=this.plotAreaWidth*this.widthMultiplier;c.height=this.plotAreaHeight*this.heightMultiplier;c.index=b;c.dx=this.dx;c.dy=this.dy;c.rotate=this.rotate}},updateChartCursor:function(){var a=this.chartCursor;a&&(a=AmCharts.processObject(a,AmCharts.ChartCursor,this.theme),this.addChartCursor(a),a.x=this.marginLeftReal,a.y=this.marginTopReal,a.width=this.plotAreaWidth- | ||
286 | 1,a.height=this.plotAreaHeight-1,a.chart=this)},processScrollbars:function(){var a=this.chartScrollbar;a&&(a=AmCharts.processObject(a,AmCharts.ChartScrollbar,this.theme),this.addChartScrollbar(a))},updateScrollbars:function(){},addChartCursor:function(a){AmCharts.callMethod("destroy",[this.chartCursor]);a&&(this.listenTo(a,"changed",this.handleCursorChange),this.listenTo(a,"zoomed",this.handleCursorZoom));this.chartCursor=a},removeChartCursor:function(){AmCharts.callMethod("destroy",[this.chartCursor]); | ||
287 | this.chartCursor=null},zoomTrendLines:function(){var a=this.trendLines,b;for(b=0;b<a.length;b++){var c=a[b];c.valueAxis.recalculateToPercents?c.set&&c.set.hide():(c.x=this.marginLeftReal+this.horizontalPosition,c.y=this.marginTopReal+this.verticalPosition,c.draw())}},addTrendLine:function(a){this.trendLines.push(a)},removeTrendLine:function(a){var b=this.trendLines,c;for(c=b.length-1;0<=c;c--)b[c]==a&&b.splice(c,1)},adjustMargins:function(a,b){var c=a.scrollbarHeight+a.offset;"top"==a.position?b? | ||
288 | this.marginLeftReal+=c:this.marginTopReal+=c:b?this.marginRightReal+=c:this.marginBottomReal+=c},getScrollbarPosition:function(a,b,c){a.position=b?"bottom"==c||"left"==c?"bottom":"top":"top"==c||"right"==c?"bottom":"top"},updateChartScrollbar:function(a,b){if(a){a.rotate=b;var c=this.marginTopReal,d=this.marginLeftReal,e=a.scrollbarHeight,f=this.dx,g=this.dy,h=a.offset;"top"==a.position?b?(a.y=c,a.x=d-e-h):(a.y=c-e+g-1-h,a.x=d+f):b?(a.y=c+g,a.x=d+this.plotAreaWidth+f+h):(a.y=c+this.plotAreaHeight+ | ||
289 | h,a.x=this.marginLeftReal)}},showZB:function(a){var b=this.zbSet;b&&(a?b.show():b.hide(),this.rollOutZB())},handleReleaseOutside:function(a){AmCharts.AmRectangularChart.base.handleReleaseOutside.call(this,a);(a=this.chartCursor)&&a.handleReleaseOutside()},handleMouseDown:function(a){AmCharts.AmRectangularChart.base.handleMouseDown.call(this,a);var b=this.chartCursor;b&&b.handleMouseDown(a)},handleCursorChange:function(a){}});AmCharts.TrendLine=AmCharts.Class({construct:function(a){this.cname="TrendLine";this.createEvents("click");this.isProtected=!1;this.dashLength=0;this.lineColor="#00CC00";this.lineThickness=this.lineAlpha=1;AmCharts.applyTheme(this,a,this.cname)},draw:function(){var a=this;a.destroy();var b=a.chart,c=b.container,d,e,f,g,h=a.categoryAxis,k=a.initialDate,l=a.initialCategory,m=a.finalDate,n=a.finalCategory,p=a.valueAxis,q=a.valueAxisX,r=a.initialXValue,s=a.finalXValue,v=a.initialValue,w=a.finalValue, | ||
290 | t=p.recalculateToPercents,u=b.dataDateFormat;h&&(k&&(k instanceof Date||(k=u?AmCharts.stringToDate(k,u):new Date(k)),a.initialDate=k,d=h.dateToCoordinate(k)),l&&(d=h.categoryToCoordinate(l)),m&&(m instanceof Date||(m=u?AmCharts.stringToDate(m,u):new Date(m)),a.finalDate=m,e=h.dateToCoordinate(m)),n&&(e=h.categoryToCoordinate(n)));q&&!t&&(isNaN(r)||(d=q.getCoordinate(r)),isNaN(s)||(e=q.getCoordinate(s)));p&&!t&&(isNaN(v)||(f=p.getCoordinate(v)),isNaN(w)||(g=p.getCoordinate(w)));isNaN(d)||isNaN(e)|| | ||
291 | isNaN(f)||isNaN(f)||(b.rotate?(h=[f,g],e=[d,e]):(h=[d,e],e=[f,g]),f=a.lineColor,d=AmCharts.line(c,h,e,f,a.lineAlpha,a.lineThickness,a.dashLength),g=h,k=e,n=h[1]-h[0],p=e[1]-e[0],0===n&&(n=.01),0===p&&(p=.01),l=n/Math.abs(n),m=p/Math.abs(p),p=n*p/Math.abs(n*p)*Math.sqrt(Math.pow(n,2)+Math.pow(p,2)),n=Math.asin(n/p),p=90*Math.PI/180-n,n=Math.abs(5*Math.cos(p)),p=Math.abs(5*Math.sin(p)),g.push(h[1]-l*p,h[0]-l*p),k.push(e[1]+m*n,e[0]+m*n),h=AmCharts.polygon(c,g,k,f,.005,0),c=c.set([h,d]),c.translate(b.marginLeftReal, | ||
292 | b.marginTopReal),b.trendLinesSet.push(c),a.line=d,a.set=c,h.mouseup(function(){a.handleLineClick()}).mouseover(function(){a.handleLineOver()}).mouseout(function(){a.handleLineOut()}),h.touchend&&h.touchend(function(){a.handleLineClick()}))},handleLineClick:function(){var a={type:"click",trendLine:this,chart:this.chart};this.fire(a.type,a)},handleLineOver:function(){var a=this.rollOverColor;void 0!==a&&this.line.attr({stroke:a})},handleLineOut:function(){this.line.attr({stroke:this.lineColor})},destroy:function(){AmCharts.remove(this.set)}});AmCharts.circle=function(a,b,c,d,e,f,g,h){if(void 0==e||0===e)e=.01;void 0===f&&(f="#000000");void 0===g&&(g=0);d={fill:c,stroke:f,"fill-opacity":d,"stroke-width":e,"stroke-opacity":g};a=a.circle(0,0,b).attr(d);h&&a.gradient("radialGradient",[c,AmCharts.adjustLuminosity(c,-.6)]);return a}; | ||
293 | AmCharts.text=function(a,b,c,d,e,f,g,h){f||(f="middle");"right"==f&&(f="end");isNaN(h)&&(h=1);void 0!==b&&(b=String(b),AmCharts.isIE&&!AmCharts.isModern&&(b=b.replace("&","&"),b=b.replace("&","&")));c={fill:c,"font-family":d,"font-size":e,opacity:h};!0===g&&(c["font-weight"]="bold");c["text-anchor"]=f;return a.text(b,c)}; | ||
294 | AmCharts.polygon=function(a,b,c,d,e,f,g,h,k,l,m){isNaN(f)&&(f=.01);isNaN(h)&&(h=e);var n=d,p=!1;"object"==typeof n&&1<n.length&&(p=!0,n=n[0]);void 0===g&&(g=n);e={fill:n,stroke:g,"fill-opacity":e,"stroke-width":f,"stroke-opacity":h};void 0!==m&&0<m&&(e["stroke-dasharray"]=m);m=AmCharts.dx;f=AmCharts.dy;a.handDrawn&&(c=AmCharts.makeHD(b,c,a.handDrawScatter),b=c[0],c=c[1]);g=Math.round;l&&(g=AmCharts.doNothing);l="M"+(g(b[0])+m)+","+(g(c[0])+f);for(h=1;h<b.length;h++)l+=" L"+(g(b[h])+m)+","+(g(c[h])+ | ||
295 | f);a=a.path(l+" Z").attr(e);p&&a.gradient("linearGradient",d,k);return a}; | ||
296 | AmCharts.rect=function(a,b,c,d,e,f,g,h,k,l,m){isNaN(f)&&(f=0);void 0===k&&(k=0);void 0===l&&(l=270);isNaN(e)&&(e=0);var n=d,p=!1;"object"==typeof n&&(n=n[0],p=!0);void 0===g&&(g=n);void 0===h&&(h=e);b=Math.round(b);c=Math.round(c);var q=0,r=0;0>b&&(b=Math.abs(b),q=-b);0>c&&(c=Math.abs(c),r=-c);q+=AmCharts.dx;r+=AmCharts.dy;e={fill:n,stroke:g,"fill-opacity":e,"stroke-opacity":h};void 0!==m&&0<m&&(e["stroke-dasharray"]=m);a=a.rect(q,r,b,c,k,f).attr(e);p&&a.gradient("linearGradient",d,l);return a}; | ||
297 | AmCharts.bullet=function(a,b,c,d,e,f,g,h,k,l,m){var n;"circle"==b&&(b="round");switch(b){case "round":n=AmCharts.circle(a,c/2,d,e,f,g,h);break;case "square":n=AmCharts.polygon(a,[-c/2,c/2,c/2,-c/2],[c/2,c/2,-c/2,-c/2],d,e,f,g,h,l-180);break;case "rectangle":n=AmCharts.polygon(a,[-c,c,c,-c],[c/2,c/2,-c/2,-c/2],d,e,f,g,h,l-180);break;case "diamond":n=AmCharts.polygon(a,[-c/2,0,c/2,0],[0,-c/2,0,c/2],d,e,f,g,h);break;case "triangleUp":n=AmCharts.triangle(a,c,0,d,e,f,g,h);break;case "triangleDown":n=AmCharts.triangle(a, | ||
298 | c,180,d,e,f,g,h);break;case "triangleLeft":n=AmCharts.triangle(a,c,270,d,e,f,g,h);break;case "triangleRight":n=AmCharts.triangle(a,c,90,d,e,f,g,h);break;case "bubble":n=AmCharts.circle(a,c/2,d,e,f,g,h,!0);break;case "line":n=AmCharts.line(a,[-c/2,c/2],[0,0],d,e,f,g,h);break;case "yError":n=a.set();n.push(AmCharts.line(a,[0,0],[-c/2,c/2],d,e,f));n.push(AmCharts.line(a,[-k,k],[-c/2,-c/2],d,e,f));n.push(AmCharts.line(a,[-k,k],[c/2,c/2],d,e,f));break;case "xError":n=a.set(),n.push(AmCharts.line(a,[-c/ | ||
299 | 2,c/2],[0,0],d,e,f)),n.push(AmCharts.line(a,[-c/2,-c/2],[-k,k],d,e,f)),n.push(AmCharts.line(a,[c/2,c/2],[-k,k],d,e,f))}n&&n.pattern(m);return n}; | ||
300 | AmCharts.triangle=function(a,b,c,d,e,f,g,h){if(void 0===f||0===f)f=1;void 0===g&&(g="#000");void 0===h&&(h=0);d={fill:d,stroke:g,"fill-opacity":e,"stroke-width":f,"stroke-opacity":h};b/=2;var k;0===c&&(k=" M"+-b+","+b+" L0,"+-b+" L"+b+","+b+" Z");180==c&&(k=" M"+-b+","+-b+" L0,"+b+" L"+b+","+-b+" Z");90==c&&(k=" M"+-b+","+-b+" L"+b+",0 L"+-b+","+b+" Z");270==c&&(k=" M"+-b+",0 L"+b+","+b+" L"+b+","+-b+" Z");return a.path(k).attr(d)}; | ||
301 | AmCharts.line=function(a,b,c,d,e,f,g,h,k,l,m){if(a.handDrawn&&!m)return AmCharts.handDrawnLine(a,b,c,d,e,f,g,h,k,l,m);f={fill:"none","stroke-width":f};void 0!==g&&0<g&&(f["stroke-dasharray"]=g);isNaN(e)||(f["stroke-opacity"]=e);d&&(f.stroke=d);d=Math.round;l&&(d=AmCharts.doNothing);l=AmCharts.dx;e=AmCharts.dy;g="M"+(d(b[0])+l)+","+(d(c[0])+e);for(h=1;h<b.length;h++)g+=" L"+(d(b[h])+l)+","+(d(c[h])+e);if(AmCharts.VML)return a.path(g,void 0,!0).attr(f);k&&(g+=" M0,0 L0,0");return a.path(g).attr(f)}; | ||
302 | AmCharts.makeHD=function(a,b,c){for(var d=[],e=[],f=1;f<a.length;f++)for(var g=Number(a[f-1]),h=Number(b[f-1]),k=Number(a[f]),l=Number(b[f]),m=Math.sqrt(Math.pow(k-g,2)+Math.pow(l-h,2)),m=Math.round(m/50)+1,k=(k-g)/m,l=(l-h)/m,n=0;n<=m;n++){var p=g+n*k+Math.random()*c,q=h+n*l+Math.random()*c;d.push(p);e.push(q)}return[d,e]}; | ||
303 | AmCharts.handDrawnLine=function(a,b,c,d,e,f,g,h,k,l,m){var n=a.set();for(m=1;m<b.length;m++)for(var p=[b[m-1],b[m]],q=[c[m-1],c[m]],q=AmCharts.makeHD(p,q,a.handDrawScatter),p=q[0],q=q[1],r=1;r<p.length;r++)n.push(AmCharts.line(a,[p[r-1],p[r]],[q[r-1],q[r]],d,e,f+Math.random()*a.handDrawThickness-a.handDrawThickness/2,g,h,k,l,!0));return n};AmCharts.doNothing=function(a){return a}; | ||
304 | AmCharts.wedge=function(a,b,c,d,e,f,g,h,k,l,m,n){var p=Math.round;f=p(f);g=p(g);h=p(h);var q=p(g/f*h),r=AmCharts.VML,s=359.5+f/100;359.94<s&&(s=359.94);e>=s&&(e=s);var v=1/180*Math.PI,s=b+Math.sin(d*v)*h,w=c-Math.cos(d*v)*q,t=b+Math.sin(d*v)*f,u=c-Math.cos(d*v)*g,y=b+Math.sin((d+e)*v)*f,E=c-Math.cos((d+e)*v)*g,A=b+Math.sin((d+e)*v)*h,v=c-Math.cos((d+e)*v)*q,z={fill:AmCharts.adjustLuminosity(l.fill,-.2),"stroke-opacity":0,"fill-opacity":l["fill-opacity"]},K=0;180<Math.abs(e)&&(K=1);d=a.set();var I; | ||
305 | r&&(s=p(10*s),t=p(10*t),y=p(10*y),A=p(10*A),w=p(10*w),u=p(10*u),E=p(10*E),v=p(10*v),b=p(10*b),k=p(10*k),c=p(10*c),f*=10,g*=10,h*=10,q*=10,1>Math.abs(e)&&1>=Math.abs(y-t)&&1>=Math.abs(E-u)&&(I=!0));e="";var F;n&&(z["fill-opacity"]=0,z["stroke-opacity"]=l["stroke-opacity"]/2,z.stroke=l.stroke);0<k&&(r?(F=" M"+s+","+(w+k)+" L"+t+","+(u+k),I||(F+=" A"+(b-f)+","+(k+c-g)+","+(b+f)+","+(k+c+g)+","+t+","+(u+k)+","+y+","+(E+k)),F+=" L"+A+","+(v+k),0<h&&(I||(F+=" B"+(b-h)+","+(k+c-q)+","+(b+h)+","+(k+c+q)+ | ||
306 | ","+A+","+(k+v)+","+s+","+(k+w)))):(F=" M"+s+","+(w+k)+" L"+t+","+(u+k)+(" A"+f+","+g+",0,"+K+",1,"+y+","+(E+k)+" L"+A+","+(v+k)),0<h&&(F+=" A"+h+","+q+",0,"+K+",0,"+s+","+(w+k))),F+=" Z",F=a.path(F,void 0,void 0,"1000,1000").attr(z),d.push(F),F=a.path(" M"+s+","+w+" L"+s+","+(w+k)+" L"+t+","+(u+k)+" L"+t+","+u+" L"+s+","+w+" Z",void 0,void 0,"1000,1000").attr(z),k=a.path(" M"+y+","+E+" L"+y+","+(E+k)+" L"+A+","+(v+k)+" L"+A+","+v+" L"+y+","+E+" Z",void 0,void 0,"1000,1000").attr(z),d.push(F),d.push(k)); | ||
307 | r?(I||(e=" A"+p(b-f)+","+p(c-g)+","+p(b+f)+","+p(c+g)+","+p(t)+","+p(u)+","+p(y)+","+p(E)),f=" M"+p(s)+","+p(w)+" L"+p(t)+","+p(u)+e+" L"+p(A)+","+p(v)):f=" M"+s+","+w+" L"+t+","+u+(" A"+f+","+g+",0,"+K+",1,"+y+","+E)+" L"+A+","+v;0<h&&(r?I||(f+=" B"+(b-h)+","+(c-q)+","+(b+h)+","+(c+q)+","+A+","+v+","+s+","+w):f+=" A"+h+","+q+",0,"+K+",0,"+s+","+w);a.handDrawn&&(b=AmCharts.line(a,[s,t],[w,u],l.stroke,l.thickness*Math.random()*a.handDrawThickness,l["stroke-opacity"]),d.push(b));a=a.path(f+" Z",void 0, | ||
308 | void 0,"1000,1000").attr(l);if(m){b=[];for(c=0;c<m.length;c++)b.push(AmCharts.adjustLuminosity(l.fill,m[c]));0<b.length&&a.gradient("linearGradient",b)}a.pattern(n);d.push(a);return d}; | ||
309 | AmCharts.adjustLuminosity=function(a,b){a=String(a).replace(/[^0-9a-f]/gi,"");6>a.length&&(a=String(a[0])+String(a[0])+String(a[1])+String(a[1])+String(a[2])+String(a[2]));b=b||0;var c="#",d,e;for(e=0;3>e;e++)d=parseInt(a.substr(2*e,2),16),d=Math.round(Math.min(Math.max(0,d+d*b),255)).toString(16),c+=("00"+d).substr(d.length);return c};AmCharts.Bezier=AmCharts.Class({construct:function(a,b,c,d,e,f,g,h,k,l){"object"==typeof g&&(g=g[0]);"object"==typeof h&&(h=h[0]);f={fill:g,"fill-opacity":h,"stroke-width":f};void 0!==k&&0<k&&(f["stroke-dasharray"]=k);isNaN(e)||(f["stroke-opacity"]=e);d&&(f.stroke=d);d="M"+Math.round(b[0])+","+Math.round(c[0]);e=[];for(k=0;k<b.length;k++)e.push({x:Number(b[k]),y:Number(c[k])});1<e.length&&(b=this.interpolate(e),d+=this.drawBeziers(b));l?d+=l:AmCharts.VML||(d+="M0,0 L0,0");this.path=a.path(d).attr(f)}, | ||
310 | interpolate:function(a){var b=[];b.push({x:a[0].x,y:a[0].y});var c=a[1].x-a[0].x,d=a[1].y-a[0].y,e=AmCharts.bezierX,f=AmCharts.bezierY;b.push({x:a[0].x+c/e,y:a[0].y+d/f});var g;for(g=1;g<a.length-1;g++){var h=a[g-1],k=a[g],d=a[g+1];isNaN(d.x)&&(d=k);isNaN(k.x)&&(k=h);isNaN(h.x)&&(h=k);c=d.x-k.x;d=d.y-h.y;h=k.x-h.x;h>c&&(h=c);b.push({x:k.x-h/e,y:k.y-d/f});b.push({x:k.x,y:k.y});b.push({x:k.x+h/e,y:k.y+d/f})}d=a[a.length-1].y-a[a.length-2].y;c=a[a.length-1].x-a[a.length-2].x;b.push({x:a[a.length-1].x- | ||
311 | c/e,y:a[a.length-1].y-d/f});b.push({x:a[a.length-1].x,y:a[a.length-1].y});return b},drawBeziers:function(a){var b="",c;for(c=0;c<(a.length-1)/3;c++)b+=this.drawBezierMidpoint(a[3*c],a[3*c+1],a[3*c+2],a[3*c+3]);return b},drawBezierMidpoint:function(a,b,c,d){var e=Math.round,f=this.getPointOnSegment(a,b,.75),g=this.getPointOnSegment(d,c,.75),h=(d.x-a.x)/16,k=(d.y-a.y)/16,l=this.getPointOnSegment(a,b,.375);a=this.getPointOnSegment(f,g,.375);a.x-=h;a.y-=k;b=this.getPointOnSegment(g,f,.375);b.x+=h;b.y+= | ||
312 | k;c=this.getPointOnSegment(d,c,.375);h=this.getMiddle(l,a);f=this.getMiddle(f,g);g=this.getMiddle(b,c);l=" Q"+e(l.x)+","+e(l.y)+","+e(h.x)+","+e(h.y);l+=" Q"+e(a.x)+","+e(a.y)+","+e(f.x)+","+e(f.y);l+=" Q"+e(b.x)+","+e(b.y)+","+e(g.x)+","+e(g.y);return l+=" Q"+e(c.x)+","+e(c.y)+","+e(d.x)+","+e(d.y)},getMiddle:function(a,b){return{x:(a.x+b.x)/2,y:(a.y+b.y)/2}},getPointOnSegment:function(a,b,c){return{x:a.x+(b.x-a.x)*c,y:a.y+(b.y-a.y)*c}}});AmCharts.AmDraw=AmCharts.Class({construct:function(a,b,c,d){AmCharts.SVG_NS="http://www.w3.org/2000/svg";AmCharts.SVG_XLINK="http://www.w3.org/1999/xlink";AmCharts.hasSVG=!!document.createElementNS&&!!document.createElementNS(AmCharts.SVG_NS,"svg").createSVGRect;1>b&&(b=10);1>c&&(c=10);this.div=a;this.width=b;this.height=c;this.rBin=document.createElement("div");if(AmCharts.hasSVG){AmCharts.SVG=!0;var e=this.createSvgElement("svg");e.style.position="absolute";e.style.width=b+"px";e.style.height=c+ | ||
313 | "px";b=this.createSvgElement("desc");b.appendChild(document.createTextNode("JavaScript chart by amCharts "+d.version));e.appendChild(b);AmCharts.rtl&&(e.setAttribute("direction","rtl"),e.style.left="auto",e.style.right="0px");e.setAttribute("version","1.1");a.appendChild(e);this.container=e;this.R=new AmCharts.SVGRenderer(this)}else AmCharts.isIE&&AmCharts.VMLRenderer&&(AmCharts.VML=!0,AmCharts.vmlStyleSheet||(document.namespaces.add("amvml","urn:schemas-microsoft-com:vml"),31>document.styleSheets.length? | ||
314 | (e=document.createStyleSheet(),e.addRule(".amvml","behavior:url(#default#VML); display:inline-block; antialias:true"),AmCharts.vmlStyleSheet=e):document.styleSheets[0].addRule(".amvml","behavior:url(#default#VML); display:inline-block; antialias:true")),this.container=a,this.R=new AmCharts.VMLRenderer(this,d),this.R.disableSelection(a))},createSvgElement:function(a){return document.createElementNS(AmCharts.SVG_NS,a)},circle:function(a,b,c,d){var e=new AmCharts.AmDObject("circle",this);e.attr({r:c, | ||
315 | cx:a,cy:b});this.addToContainer(e.node,d);return e},setSize:function(a,b){0<a&&0<b&&(this.container.style.width=a+"px",this.container.style.height=b+"px")},rect:function(a,b,c,d,e,f,g){var h=new AmCharts.AmDObject("rect",this);AmCharts.VML&&(e=100*e/Math.min(c,d),c+=2*f,d+=2*f,h.bw=f,h.node.style.marginLeft=-f,h.node.style.marginTop=-f);1>c&&(c=1);1>d&&(d=1);h.attr({x:a,y:b,width:c,height:d,rx:e,ry:e,"stroke-width":f});this.addToContainer(h.node,g);return h},image:function(a,b,c,d,e,f){var g=new AmCharts.AmDObject("image", | ||
316 | this);g.attr({x:b,y:c,width:d,height:e});this.R.path(g,a);this.addToContainer(g.node,f);return g},addToContainer:function(a,b){b||(b=this.container);b.appendChild(a)},text:function(a,b,c){return this.R.text(a,b,c)},path:function(a,b,c,d){var e=new AmCharts.AmDObject("path",this);d||(d="100,100");e.attr({cs:d});c?e.attr({dd:a}):e.attr({d:a});this.addToContainer(e.node,b);return e},set:function(a){return this.R.set(a)},remove:function(a){if(a){var b=this.rBin;b.appendChild(a);b.innerHTML=""}},renderFix:function(){var a= | ||
317 | this.container,b=a.style,c;try{c=a.getScreenCTM()||a.createSVGMatrix()}catch(d){c=a.createSVGMatrix()}a=1-c.e%1;c=1-c.f%1;.5<a&&(a-=1);.5<c&&(c-=1);a&&(b.left=a+"px");c&&(b.top=c+"px")},update:function(){this.R.update()}});AmCharts.AmDObject=AmCharts.Class({construct:function(a,b){this.D=b;this.R=b.R;this.node=this.R.create(this,a);this.y=this.x=0;this.scale=1},attr:function(a){this.R.attr(this,a);return this},getAttr:function(a){return this.node.getAttribute(a)},setAttr:function(a,b){this.R.setAttr(this,a,b);return this},clipRect:function(a,b,c,d){this.R.clipRect(this,a,b,c,d)},translate:function(a,b,c,d){d||(a=Math.round(a),b=Math.round(b));this.R.move(this,a,b,c);this.x=a;this.y=b;this.scale=c;this.angle&&this.rotate(this.angle)}, | ||
318 | rotate:function(a,b){this.R.rotate(this,a,b);this.angle=a},animate:function(a,b,c){for(var d in a)if(a.hasOwnProperty(d)){var e=d,f=a[d];c=AmCharts.getEffect(c);this.R.animate(this,e,f,b,c)}},push:function(a){if(a){var b=this.node;b.appendChild(a.node);var c=a.clipPath;c&&b.appendChild(c);(a=a.grad)&&b.appendChild(a)}},text:function(a){this.R.setText(this,a)},remove:function(){this.R.remove(this)},clear:function(){var a=this.node;if(a.hasChildNodes())for(;1<=a.childNodes.length;)a.removeChild(a.firstChild)}, | ||
319 | hide:function(){this.setAttr("visibility","hidden")},show:function(){this.setAttr("visibility","visible")},getBBox:function(){return this.R.getBBox(this)},toFront:function(){var a=this.node;if(a){this.prevNextNode=a.nextSibling;var b=a.parentNode;b&&b.appendChild(a)}},toPrevious:function(){var a=this.node;a&&this.prevNextNode&&(a=a.parentNode)&&a.insertBefore(this.prevNextNode,null)},toBack:function(){var a=this.node;if(a){this.prevNextNode=a.nextSibling;var b=a.parentNode;if(b){var c=b.firstChild; | ||
320 | c&&b.insertBefore(a,c)}}},mouseover:function(a){this.R.addListener(this,"mouseover",a);return this},mouseout:function(a){this.R.addListener(this,"mouseout",a);return this},click:function(a){this.R.addListener(this,"click",a);return this},dblclick:function(a){this.R.addListener(this,"dblclick",a);return this},mousedown:function(a){this.R.addListener(this,"mousedown",a);return this},mouseup:function(a){this.R.addListener(this,"mouseup",a);return this},touchstart:function(a){this.R.addListener(this, | ||
321 | "touchstart",a);return this},touchend:function(a){this.R.addListener(this,"touchend",a);return this},contextmenu:function(a){this.node.addEventListener?this.node.addEventListener("contextmenu",a,!0):this.R.addListener(this,"contextmenu",a);return this},stop:function(a){(a=this.animationX)&&AmCharts.removeFromArray(this.R.animations,a);(a=this.animationY)&&AmCharts.removeFromArray(this.R.animations,a)},length:function(){return this.node.childNodes.length},gradient:function(a,b,c){this.R.gradient(this, | ||
322 | a,b,c)},pattern:function(a,b){a&&this.R.pattern(this,a,b)}});AmCharts.VMLRenderer=AmCharts.Class({construct:function(a,b){this.chart=b;this.D=a;this.cNames={circle:"oval",rect:"roundrect",path:"shape"};this.styleMap={x:"left",y:"top",width:"width",height:"height","font-family":"fontFamily","font-size":"fontSize",visibility:"visibility"}},create:function(a,b){var c;if("group"==b)c=document.createElement("div"),a.type="div";else if("text"==b)c=document.createElement("div"),a.type="text";else if("image"==b)c=document.createElement("img"),a.type="image";else{a.type= | ||
323 | "shape";a.shapeType=this.cNames[b];c=document.createElement("amvml:"+this.cNames[b]);var d=document.createElement("amvml:stroke");c.appendChild(d);a.stroke=d;var e=document.createElement("amvml:fill");c.appendChild(e);a.fill=e;e.className="amvml";d.className="amvml";c.className="amvml"}c.style.position="absolute";c.style.top=0;c.style.left=0;return c},path:function(a,b){a.node.setAttribute("src",b)},setAttr:function(a,b,c){if(void 0!==c){var d;8===document.documentMode&&(d=!0);var e=a.node,f=a.type, | ||
324 | g=e.style;"r"==b&&(g.width=2*c,g.height=2*c);"roundrect"!=a.shapeType||"width"!=b&&"height"!=b||(c-=1);"cursor"==b&&(g.cursor=c);"cx"==b&&(g.left=c-AmCharts.removePx(g.width)/2);"cy"==b&&(g.top=c-AmCharts.removePx(g.height)/2);var h=this.styleMap[b];void 0!==h&&(g[h]=c);"text"==f&&("text-anchor"==b&&(a.anchor=c,h=e.clientWidth,"end"==c&&(g.marginLeft=-h+"px"),"middle"==c&&(g.marginLeft=-(h/2)+"px",g.textAlign="center"),"start"==c&&(g.marginLeft="0px")),"fill"==b&&(g.color=c),"font-weight"==b&&(g.fontWeight= | ||
325 | c));if(g=a.children)for(h=0;h<g.length;h++)g[h].setAttr(b,c);if("shape"==f){"cs"==b&&(e.style.width="100px",e.style.height="100px",e.setAttribute("coordsize",c));"d"==b&&e.setAttribute("path",this.svgPathToVml(c));"dd"==b&&e.setAttribute("path",c);f=a.stroke;a=a.fill;"stroke"==b&&(d?f.color=c:f.setAttribute("color",c));"stroke-width"==b&&(d?f.weight=c:f.setAttribute("weight",c));"stroke-opacity"==b&&(d?f.opacity=c:f.setAttribute("opacity",c));"stroke-dasharray"==b&&(g="solid",0<c&&3>c&&(g="dot"), | ||
326 | 3<=c&&6>=c&&(g="dash"),6<c&&(g="longdash"),d?f.dashstyle=g:f.setAttribute("dashstyle",g));if("fill-opacity"==b||"opacity"==b)0===c?d?a.on=!1:a.setAttribute("on",!1):d?a.opacity=c:a.setAttribute("opacity",c);"fill"==b&&(d?a.color=c:a.setAttribute("color",c));"rx"==b&&(d?e.arcSize=c+"%":e.setAttribute("arcsize",c+"%"))}}},attr:function(a,b){for(var c in b)b.hasOwnProperty(c)&&this.setAttr(a,c,b[c])},text:function(a,b,c){var d=new AmCharts.AmDObject("text",this.D),e=d.node;e.style.whiteSpace="pre";e.innerHTML= | ||
327 | a;this.D.addToContainer(e,c);this.attr(d,b);return d},getBBox:function(a){return this.getBox(a.node)},getBox:function(a){var b=a.offsetLeft,c=a.offsetTop,d=a.offsetWidth,e=a.offsetHeight,f;if(a.hasChildNodes()){var g,h,k;for(k=0;k<a.childNodes.length;k++){f=this.getBox(a.childNodes[k]);var l=f.x;isNaN(l)||(isNaN(g)?g=l:l<g&&(g=l));var m=f.y;isNaN(m)||(isNaN(h)?h=m:m<h&&(h=m));l=f.width+l;isNaN(l)||(d=Math.max(d,l));f=f.height+m;isNaN(f)||(e=Math.max(e,f))}0>g&&(b+=g);0>h&&(c+=h)}return{x:b,y:c,width:d, | ||
328 | height:e}},setText:function(a,b){var c=a.node;c&&(c.innerHTML=b);this.setAttr(a,"text-anchor",a.anchor)},addListener:function(a,b,c){a.node["on"+b]=c},move:function(a,b,c){var d=a.node,e=d.style;"text"==a.type&&(c-=AmCharts.removePx(e.fontSize)/2-1);"oval"==a.shapeType&&(b-=AmCharts.removePx(e.width)/2,c-=AmCharts.removePx(e.height)/2);a=a.bw;isNaN(a)||(b-=a,c-=a);isNaN(b)||isNaN(c)||(d.style.left=b+"px",d.style.top=c+"px")},svgPathToVml:function(a){var b=a.split(" ");a="";var c,d=Math.round,e;for(e= | ||
329 | 0;e<b.length;e++){var f=b[e],g=f.substring(0,1),f=f.substring(1),h=f.split(","),k=d(h[0])+","+d(h[1]);"M"==g&&(a+=" m "+k);"L"==g&&(a+=" l "+k);"Z"==g&&(a+=" x e");if("Q"==g){var l=c.length,m=c[l-1],n=h[0],p=h[1],k=h[2],q=h[3];c=d(c[l-2]/3+2/3*n);m=d(m/3+2/3*p);n=d(2/3*n+k/3);p=d(2/3*p+q/3);a+=" c "+c+","+m+","+n+","+p+","+k+","+q}"A"==g&&(a+=" wa "+f);"B"==g&&(a+=" at "+f);c=h}return a},animate:function(a,b,c,d,e){var f=a.node,g=this.chart;if("translate"==b){b=c.split(",");c=b[1];var h=f.offsetTop; | ||
330 | g.animate(a,"left",f.offsetLeft,b[0],d,e,"px");g.animate(a,"top",h,c,d,e,"px")}},clipRect:function(a,b,c,d,e){a=a.node;0===b&&0===c?(a.style.width=d+"px",a.style.height=e+"px",a.style.overflow="hidden"):a.style.clip="rect("+c+"px "+(b+d)+"px "+(c+e)+"px "+b+"px)"},rotate:function(a,b,c){if(0!==Number(b)){var d=a.node;a=d.style;c||(c=this.getBGColor(d.parentNode));a.backgroundColor=c;a.paddingLeft=1;c=b*Math.PI/180;var e=Math.cos(c),f=Math.sin(c),g=AmCharts.removePx(a.left),h=AmCharts.removePx(a.top), | ||
331 | k=d.offsetWidth,d=d.offsetHeight;b/=Math.abs(b);a.left=g+k/2-k/2*Math.cos(c)-b*d/2*Math.sin(c)+3;a.top=h-b*k/2*Math.sin(c)+b*d/2*Math.sin(c);a.cssText=a.cssText+"; filter:progid:DXImageTransform.Microsoft.Matrix(M11='"+e+"', M12='"+-f+"', M21='"+f+"', M22='"+e+"', sizingmethod='auto expand');"}},getBGColor:function(a){var b="#FFFFFF";if(a.style){var c=a.style.backgroundColor;""!==c?b=c:a.parentNode&&(b=this.getBGColor(a.parentNode))}return b},set:function(a){var b=new AmCharts.AmDObject("group",this.D); | ||
332 | this.D.container.appendChild(b.node);if(a){var c;for(c=0;c<a.length;c++)b.push(a[c])}return b},gradient:function(a,b,c,d){var e="";"radialGradient"==b&&(b="gradientradial",c.reverse());"linearGradient"==b&&(b="gradient");var f;for(f=0;f<c.length;f++){var g=Math.round(100*f/(c.length-1)),e=e+(g+"% "+c[f]);f<c.length-1&&(e+=",")}a=a.fill;90==d?d=0:270==d?d=180:180==d?d=90:0===d&&(d=270);8===document.documentMode?(a.type=b,a.angle=d):(a.setAttribute("type",b),a.setAttribute("angle",d));e&&(a.colors.value= | ||
333 | e)},remove:function(a){a.clipPath&&this.D.remove(a.clipPath);this.D.remove(a.node)},disableSelection:function(a){void 0!==typeof a.onselectstart&&(a.onselectstart=function(){return!1});a.style.cursor="default"},pattern:function(a,b){var c=a.node,d=a.fill,e="none";b.color&&(e=b.color);c.fillColor=e;8===document.documentMode?(d.type="tile",d.src=b.url):(d.setAttribute("type","tile"),d.setAttribute("src",b.url))},update:function(){}});AmCharts.SVGRenderer=AmCharts.Class({construct:function(a){this.D=a;this.animations=[]},create:function(a,b){return document.createElementNS(AmCharts.SVG_NS,b)},attr:function(a,b){for(var c in b)b.hasOwnProperty(c)&&this.setAttr(a,c,b[c])},setAttr:function(a,b,c){void 0!==c&&a.node.setAttribute(b,c)},animate:function(a,b,c,d,e){var f=a.node;a["an_"+b]&&AmCharts.removeFromArray(this.animations,a["an_"+b]);"translate"==b?(f=(f=f.getAttribute("transform"))?String(f).substring(10,f.length-1):"0,0",f= | ||
334 | f.split(", ").join(" "),f=f.split(" ").join(","),0===f&&(f="0,0")):f=Number(f.getAttribute(b));c={obj:a,frame:0,attribute:b,from:f,to:c,time:d,effect:e};this.animations.push(c);a["an_"+b]=c},update:function(){var a,b=this.animations;for(a=b.length-1;0<=a;a--){var c=b[a],d=1E3*c.time/AmCharts.updateRate,e=c.frame+1,f=c.obj,g=c.attribute,h,k,l;e<=d?(c.frame++,"translate"==g?(h=c.from.split(","),g=Number(h[0]),h=Number(h[1]),isNaN(h)&&(h=0),k=c.to.split(","),l=Number(k[0]),k=Number(k[1]),l=0===l-g?l: | ||
335 | Math.round(AmCharts[c.effect](0,e,g,l-g,d)),c=0===k-h?k:Math.round(AmCharts[c.effect](0,e,h,k-h,d)),g="transform",c="translate("+l+","+c+")"):(k=Number(c.from),h=Number(c.to),l=h-k,c=AmCharts[c.effect](0,e,k,l,d),isNaN(c)&&(c=h),0===l&&this.animations.splice(a,1)),this.setAttr(f,g,c)):("translate"==g?(k=c.to.split(","),l=Number(k[0]),k=Number(k[1]),f.translate(l,k)):(h=Number(c.to),this.setAttr(f,g,h)),this.animations.splice(a,1))}},getBBox:function(a){if(a=a.node)try{return a.getBBox()}catch(b){}return{width:0, | ||
336 | height:0,x:0,y:0}},path:function(a,b){a.node.setAttributeNS(AmCharts.SVG_XLINK,"xlink:href",b)},clipRect:function(a,b,c,d,e){var f=a.node,g=a.clipPath;g&&this.D.remove(g);var h=f.parentNode;h&&(f=document.createElementNS(AmCharts.SVG_NS,"clipPath"),g=AmCharts.getUniqueId(),f.setAttribute("id",g),this.D.rect(b,c,d,e,0,0,f),h.appendChild(f),b="#",AmCharts.baseHref&&!AmCharts.isIE&&(b=window.location.href+b),this.setAttr(a,"clip-path","url("+b+g+")"),this.clipPathC++,a.clipPath=f)},text:function(a,b, | ||
337 | c){var d=new AmCharts.AmDObject("text",this.D);a=String(a).split("\n");var e=b["font-size"],f;for(f=0;f<a.length;f++){var g=this.create(null,"tspan");g.appendChild(document.createTextNode(a[f]));g.setAttribute("y",(e+2)*f+Math.round(e/2));g.setAttribute("x",0);d.node.appendChild(g)}d.node.setAttribute("y",Math.round(e/2));this.attr(d,b);this.D.addToContainer(d.node,c);return d},setText:function(a,b){var c=a.node;c&&(c.removeChild(c.firstChild),c.appendChild(document.createTextNode(b)))},move:function(a, | ||
338 | b,c,d){b="translate("+b+","+c+")";d&&(b=b+" scale("+d+")");this.setAttr(a,"transform",b)},rotate:function(a,b){var c=a.node.getAttribute("transform"),d="rotate("+b+")";c&&(d=c+" "+d);this.setAttr(a,"transform",d)},set:function(a){var b=new AmCharts.AmDObject("g",this.D);this.D.container.appendChild(b.node);if(a){var c;for(c=0;c<a.length;c++)b.push(a[c])}return b},addListener:function(a,b,c){a.node["on"+b]=c},gradient:function(a,b,c,d){var e=a.node,f=a.grad;f&&this.D.remove(f);b=document.createElementNS(AmCharts.SVG_NS, | ||
339 | b);f=AmCharts.getUniqueId();b.setAttribute("id",f);if(!isNaN(d)){var g=0,h=0,k=0,l=0;90==d?k=100:270==d?l=100:180==d?g=100:0===d&&(h=100);b.setAttribute("x1",g+"%");b.setAttribute("x2",h+"%");b.setAttribute("y1",k+"%");b.setAttribute("y2",l+"%")}for(d=0;d<c.length;d++)g=document.createElementNS(AmCharts.SVG_NS,"stop"),h=100*d/(c.length-1),0===d&&(h=0),g.setAttribute("offset",h+"%"),g.setAttribute("stop-color",c[d]),b.appendChild(g);e.parentNode.appendChild(b);c="#";AmCharts.baseHref&&!AmCharts.isIE&& | ||
340 | (c=window.location.href+c);e.setAttribute("fill","url("+c+f+")");a.grad=b},pattern:function(a,b,c){var d=a.node;isNaN(c)&&(c=1);var e=a.patternNode;e&&this.D.remove(e);var e=document.createElementNS(AmCharts.SVG_NS,"pattern"),f=AmCharts.getUniqueId(),g=b;b.url&&(g=b.url);var h=Number(b.width);isNaN(h)&&(h=4);var k=Number(b.height);isNaN(k)&&(k=4);h/=c;k/=c;c=b.x;isNaN(c)&&(c=0);var l=-Math.random()*Number(b.randomX);isNaN(l)||(c=l);l=b.y;isNaN(l)&&(l=0);var m=-Math.random()*Number(b.randomY);isNaN(m)|| | ||
341 | (l=m);e.setAttribute("id",f);e.setAttribute("width",h);e.setAttribute("height",k);e.setAttribute("patternUnits","userSpaceOnUse");e.setAttribute("xlink:href",g);b.color&&(m=document.createElementNS(AmCharts.SVG_NS,"rect"),m.setAttributeNS(null,"height",h),m.setAttributeNS(null,"width",k),m.setAttributeNS(null,"fill",b.color),e.appendChild(m));this.D.image(g,0,0,h,k,e).translate(c,l);g="#";AmCharts.baseHref&&!AmCharts.isIE&&(g=window.location.href+g);d.setAttribute("fill","url("+g+f+")");a.patternNode= | ||
342 | e;d.parentNode.appendChild(e)},remove:function(a){a.clipPath&&this.D.remove(a.clipPath);a.grad&&this.D.remove(a.grad);a.patternNode&&this.D.remove(a.patternNode);this.D.remove(a.node)}});AmCharts.AmDSet=AmCharts.Class({construct:function(a){this.create("g")},attr:function(a){this.R.attr(this.node,a)},move:function(a,b){this.R.move(this.node,a,b)}});AmCharts.AmLegend=AmCharts.Class({construct:function(a){this.cname="AmLegend";this.createEvents("rollOverMarker","rollOverItem","rollOutMarker","rollOutItem","showItem","hideItem","clickMarker","rollOverItem","rollOutItem","clickLabel");this.position="bottom";this.borderColor=this.color="#000000";this.borderAlpha=0;this.markerLabelGap=5;this.verticalGap=10;this.align="left";this.horizontalGap=0;this.spacing=10;this.markerDisabledColor="#AAB3B3";this.markerType="square";this.markerSize=16;this.markerBorderThickness= | ||
343 | this.markerBorderAlpha=1;this.marginBottom=this.marginTop=0;this.marginLeft=this.marginRight=20;this.autoMargins=!0;this.valueWidth=50;this.switchable=!0;this.switchType="x";this.switchColor="#FFFFFF";this.rollOverColor="#CC0000";this.reversedOrder=!1;this.labelText="[[title]]";this.valueText="[[value]]";this.useMarkerColorForLabels=!1;this.rollOverGraphAlpha=1;this.textClickEnabled=!1;this.equalWidths=!0;this.dateFormat="DD-MM-YYYY";this.backgroundColor="#FFFFFF";this.backgroundAlpha=0;this.useGraphSettings= | ||
344 | !1;this.showEntries=!0;AmCharts.applyTheme(this,a,this.cname)},setData:function(a){this.legendData=a;this.invalidateSize()},invalidateSize:function(){this.destroy();this.entries=[];this.valueLabels=[];(AmCharts.ifArray(this.legendData)||AmCharts.ifArray(this.data))&&this.drawLegend()},drawLegend:function(){var a=this.chart,b=this.position,c=this.width,d=a.divRealWidth,e=a.divRealHeight,f=this.div,g=this.legendData;this.data&&(g=this.data);isNaN(this.fontSize)&&(this.fontSize=a.fontSize);if("right"== | ||
345 | b||"left"==b)this.maxColumns=1,this.autoMargins&&(this.marginLeft=this.marginRight=10);else if(this.autoMargins){this.marginRight=a.marginRight;this.marginLeft=a.marginLeft;var h=a.autoMarginOffset;"bottom"==b?(this.marginBottom=h,this.marginTop=0):(this.marginTop=h,this.marginBottom=0)}var k;void 0!==c?k=AmCharts.toCoordinate(c,d):"right"!=b&&"left"!=b&&(k=a.realWidth);"outside"==b?(k=f.offsetWidth,e=f.offsetHeight,f.clientHeight&&(k=f.clientWidth,e=f.clientHeight)):(isNaN(k)||(f.style.width=k+"px"), | ||
346 | f.className="amChartsLegend");this.divWidth=k;(b=this.container)?(b.container.innerHTML="",f.appendChild(b.container),b.setSize(k,e)):b=new AmCharts.AmDraw(f,k,e,a);this.container=b;this.lx=0;this.ly=8;e=this.markerSize;e>this.fontSize&&(this.ly=e/2-1);0<e&&(this.lx+=e+this.markerLabelGap);this.titleWidth=0;if(e=this.title)a=AmCharts.text(this.container,e,this.color,a.fontFamily,this.fontSize,"start",!0),a.translate(this.marginLeft,this.marginTop+this.verticalGap+this.ly+1),a=a.getBBox(),this.titleWidth= | ||
347 | a.width+15,this.titleHeight=a.height+6;this.index=this.maxLabelWidth=0;if(this.showEntries){for(a=0;a<g.length;a++)this.createEntry(g[a]);for(a=this.index=0;a<g.length;a++)this.createValue(g[a])}this.arrangeEntries();this.updateValues()},arrangeEntries:function(){var a=this.position,b=this.marginLeft+this.titleWidth,c=this.marginRight,d=this.marginTop,e=this.marginBottom,f=this.horizontalGap,g=this.div,h=this.divWidth,k=this.maxColumns,l=this.verticalGap,m=this.spacing,n=h-c-b,p=0,q=0,r=this.container; | ||
348 | this.set&&this.set.remove();var s=r.set();this.set=s;r=r.set();s.push(r);var v=this.entries,w,t;for(t=0;t<v.length;t++){w=v[t].getBBox();var u=w.width;u>p&&(p=u);w=w.height;w>q&&(q=w)}var u=q=0,y=f,E=0,A=0;for(t=0;t<v.length;t++){var z=v[t];this.reversedOrder&&(z=v[v.length-t-1]);w=z.getBBox();var K;this.equalWidths?K=f+u*(p+m+this.markerLabelGap):(K=y,y=y+w.width+f+m);w.height>A&&(A=w.height);K+w.width>n&&0<t&&0!==u&&(q++,u=0,K=f,y=K+w.width+f+m,E=E+A+l,A=0);z.translate(K,E);u++;!isNaN(k)&&u>=k&& | ||
349 | (u=0,q++,E=E+A+l,A=0);r.push(z)}w=r.getBBox();k=w.height+2*l-1;"left"==a||"right"==a?(h=w.width+2*f,g.style.width=h+b+c+"px"):h=h-b-c-1;c=AmCharts.polygon(this.container,[0,h,h,0],[0,0,k,k],this.backgroundColor,this.backgroundAlpha,1,this.borderColor,this.borderAlpha);s.push(c);s.translate(b,d);c.toBack();b=f;if("top"==a||"bottom"==a||"absolute"==a||"outside"==a)"center"==this.align?b=f+(h-w.width)/2:"right"==this.align&&(b=f+h-w.width);r.translate(b,l+1);this.titleHeight>k&&(k=this.titleHeight); | ||
350 | a=k+d+e+1;0>a&&(a=0);g.style.height=Math.round(a)+"px"},createEntry:function(a){if(!1!==a.visibleInLegend){var b=this.chart,c=a.markerType;c||(c=this.markerType);var d=a.color,e=a.alpha;a.legendKeyColor&&(d=a.legendKeyColor());a.legendKeyAlpha&&(e=a.legendKeyAlpha());var f;!0===a.hidden&&(f=d=this.markerDisabledColor);var g=a.pattern,h=a.customMarker;h||(h=this.customMarker);var k=this.container,l=this.markerSize,m=0,n=0,p=l/2;if(this.useGraphSettings)if(m=a.type,this.switchType=void 0,"line"==m|| | ||
351 | "step"==m||"smoothedLine"==m||"ohlc"==m)g=k.set(),a.hidden||(d=a.lineColorR,f=a.bulletBorderColorR),n=AmCharts.line(k,[0,2*l],[l/2,l/2],d,a.lineAlpha,a.lineThickness,a.dashLength),g.push(n),a.bullet&&(a.hidden||(d=a.bulletColorR),n=AmCharts.bullet(k,a.bullet,a.bulletSize,d,a.bulletAlpha,a.bulletBorderThickness,f,a.bulletBorderAlpha))&&(n.translate(l+1,l/2),g.push(n)),p=0,m=l,n=l/3;else{var q;a.getGradRotation&&(q=a.getGradRotation());m=a.fillColorsR;!0===a.hidden&&(m=d);if(g=this.createMarker("rectangle", | ||
352 | m,a.fillAlphas,a.lineThickness,d,a.lineAlpha,q,g))p=l,g.translate(p,l/2);m=l}else h?(b.path&&(h=b.path+h),g=k.image(h,0,0,l,l)):(g=this.createMarker(c,d,e,void 0,void 0,void 0,void 0,g))&&g.translate(l/2,l/2);this.addListeners(g,a);k=k.set([g]);this.switchable&&a.switchable&&k.setAttr("cursor","pointer");(f=this.switchType)&&"none"!=f&&("x"==f?(q=this.createX(),q.translate(l/2,l/2)):q=this.createV(),q.dItem=a,!0!==a.hidden?"x"==f?q.hide():q.show():"x"!=f&&q.hide(),this.switchable||q.hide(),this.addListeners(q, | ||
353 | a),a.legendSwitch=q,k.push(q));f=this.color;a.showBalloon&&this.textClickEnabled&&void 0!==this.selectedColor&&(f=this.selectedColor);this.useMarkerColorForLabels&&(f=d);!0===a.hidden&&(f=this.markerDisabledColor);d=AmCharts.massReplace(this.labelText,{"[[title]]":a.title});q=this.fontSize;g&&l<=q&&g.translate(p,l/2+this.ly-q/2+(q+2-l)/2-n);var r;d&&(d=AmCharts.fixBrakes(d),a.legendTextReal=d,r=this.labelWidth,r=isNaN(r)?AmCharts.text(this.container,d,f,b.fontFamily,q,"start"):AmCharts.wrappedText(this.container, | ||
354 | d,f,b.fontFamily,q,"start",!1,r,0),r.translate(this.lx+m,this.ly),k.push(r),b=r.getBBox().width,this.maxLabelWidth<b&&(this.maxLabelWidth=b));this.entries[this.index]=k;a.legendEntry=this.entries[this.index];a.legendLabel=r;this.index++}},addListeners:function(a,b){var c=this;a&&a.mouseover(function(){c.rollOverMarker(b)}).mouseout(function(){c.rollOutMarker(b)}).click(function(){c.clickMarker(b)})},rollOverMarker:function(a){this.switchable&&this.dispatch("rollOverMarker",a);this.dispatch("rollOverItem", | ||
355 | a)},rollOutMarker:function(a){this.switchable&&this.dispatch("rollOutMarker",a);this.dispatch("rollOutItem",a)},clickMarker:function(a){this.switchable&&(!0===a.hidden?this.dispatch("showItem",a):this.dispatch("hideItem",a));this.dispatch("clickMarker",a)},rollOverLabel:function(a){a.hidden||(this.textClickEnabled&&a.legendLabel&&a.legendLabel.attr({fill:this.rollOverColor}),this.dispatch("rollOverItem",a))},rollOutLabel:function(a){if(!a.hidden){if(this.textClickEnabled&&a.legendLabel){var b=this.color; | ||
356 | void 0!==this.selectedColor&&a.showBalloon&&(b=this.selectedColor);this.useMarkerColorForLabels&&(b=a.lineColor,void 0===b&&(b=a.color));a.legendLabel.attr({fill:b})}this.dispatch("rollOutItem",a)}},clickLabel:function(a){this.textClickEnabled?a.hidden||this.dispatch("clickLabel",a):this.switchable&&(!0===a.hidden?this.dispatch("showItem",a):this.dispatch("hideItem",a))},dispatch:function(a,b){this.fire(a,{type:a,dataItem:b,target:this,chart:this.chart})},createValue:function(a){var b=this,c=b.fontSize; | ||
357 | if(!1!==a.visibleInLegend){var d=b.maxLabelWidth;b.equalWidths||(b.valueAlign="left");"left"==b.valueAlign&&(d=a.legendEntry.getBBox().width);var e=d;if(b.valueText&&0<b.valueWidth){var f=b.color;b.useMarkerColorForValues&&(f=a.color,a.legendKeyColor&&(f=a.legendKeyColor()));!0===a.hidden&&(f=b.markerDisabledColor);var g=b.valueText,d=d+b.lx+b.markerLabelGap+b.valueWidth,h="end";"left"==b.valueAlign&&(d-=b.valueWidth,h="start");f=AmCharts.text(b.container,g,f,b.chart.fontFamily,c,h);f.translate(d, | ||
358 | b.ly);b.entries[b.index].push(f);e+=b.valueWidth+2*b.markerLabelGap;f.dItem=a;b.valueLabels.push(f)}b.index++;f=b.markerSize;f<c+7&&(f=c+7,AmCharts.VML&&(f+=3));c=b.container.rect(b.markerSize,0,e,f,0,0).attr({stroke:"none",fill:"#ffffff","fill-opacity":.005});c.dItem=a;b.entries[b.index-1].push(c);c.mouseover(function(){b.rollOverLabel(a)}).mouseout(function(){b.rollOutLabel(a)}).click(function(){b.clickLabel(a)})}},createV:function(){var a=this.markerSize;return AmCharts.polygon(this.container, | ||
359 | [a/5,a/2,a-a/5,a/2],[a/3,a-a/5,a/5,a/1.7],this.switchColor)},createX:function(){var a=(this.markerSize-4)/2,b={stroke:this.switchColor,"stroke-width":3},c=this.container,d=AmCharts.line(c,[-a,a],[-a,a]).attr(b),a=AmCharts.line(c,[-a,a],[a,-a]).attr(b);return this.container.set([d,a])},createMarker:function(a,b,c,d,e,f,g,h){var k=this.markerSize,l=this.container;e||(e=this.markerBorderColor);e||(e=b);isNaN(d)&&(d=this.markerBorderThickness);isNaN(f)&&(f=this.markerBorderAlpha);return AmCharts.bullet(l, | ||
360 | a,k,b,c,d,e,f,k,g,h)},validateNow:function(){this.invalidateSize()},updateValues:function(){var a=this.valueLabels,b=this.chart,c,d=this.data;for(c=0;c<a.length;c++){var e=a[c],f=e.dItem,g=" ";if(d)f.value?e.text(f.value):e.text("");else{if(void 0!==f.type){var h=f.currentDataItem,k=this.periodValueText;f.legendPeriodValueText&&(k=f.legendPeriodValueText);h?(g=this.valueText,f.legendValueText&&(g=f.legendValueText),g=b.formatString(g,h)):k&&(g=b.formatPeriodString(k,f))}else g=b.formatString(this.valueText, | ||
361 | f);if(k=this.valueFunction)h&&(f=h),g=k(f,g);e.text(g)}}},renderFix:function(){if(!AmCharts.VML){var a=this.container;a&&a.renderFix()}},destroy:function(){this.div.innerHTML="";AmCharts.remove(this.set)}});AmCharts.formatMilliseconds=function(a,b){if(-1!=a.indexOf("fff")){var c=b.getMilliseconds(),d=String(c);10>c&&(d="00"+c);10<=c&&100>c&&(d="0"+c);a=a.replace(/fff/g,d)}return a};AmCharts.extractPeriod=function(a){var b=AmCharts.stripNumbers(a),c=1;b!=a&&(c=Number(a.slice(0,a.indexOf(b))));return{period:b,count:c}}; | ||
362 | AmCharts.newDate=function(a,b){return date="fff"==b?AmCharts.useUTC?new Date(a.getUTCFullYear(),a.getUTCMonth(),a.getUTCDate(),a.getUTCHours(),a.getUTCMinutes(),a.getUTCSeconds(),a.getUTCMilliseconds()):new Date(a.getFullYear(),a.getMonth(),a.getDate(),a.getHours(),a.getMinutes(),a.getSeconds(),a.getMilliseconds()):new Date(a)}; | ||
363 | AmCharts.resetDateToMin=function(a,b,c,d){void 0===d&&(d=1);var e,f,g,h,k,l,m;AmCharts.useUTC?(e=a.getUTCFullYear(),f=a.getUTCMonth(),g=a.getUTCDate(),h=a.getUTCHours(),k=a.getUTCMinutes(),l=a.getUTCSeconds(),m=a.getUTCMilliseconds(),a=a.getUTCDay()):(e=a.getFullYear(),f=a.getMonth(),g=a.getDate(),h=a.getHours(),k=a.getMinutes(),l=a.getSeconds(),m=a.getMilliseconds(),a=a.getDay());switch(b){case "YYYY":e=Math.floor(e/c)*c;f=0;g=1;m=l=k=h=0;break;case "MM":f=Math.floor(f/c)*c;g=1;m=l=k=h=0;break;case "WW":0=== | ||
364 | a&&0<d&&(a=7);g=g-a+d;m=l=k=h=0;break;case "DD":m=l=k=h=0;break;case "hh":h=Math.floor(h/c)*c;m=l=k=0;break;case "mm":k=Math.floor(k/c)*c;m=l=0;break;case "ss":l=Math.floor(l/c)*c;m=0;break;case "fff":m=Math.floor(m/c)*c}AmCharts.useUTC?(a=new Date,a.setUTCFullYear(e,f,g),a.setUTCHours(h,k,l,m)):a=new Date(e,f,g,h,k,l,m);return a}; | ||
365 | AmCharts.getPeriodDuration=function(a,b){void 0===b&&(b=1);var c;switch(a){case "YYYY":c=316224E5;break;case "MM":c=26784E5;break;case "WW":c=6048E5;break;case "DD":c=864E5;break;case "hh":c=36E5;break;case "mm":c=6E4;break;case "ss":c=1E3;break;case "fff":c=1}return c*b};AmCharts.intervals={s:{nextInterval:"ss",contains:1E3},ss:{nextInterval:"mm",contains:60,count:0},mm:{nextInterval:"hh",contains:60,count:1},hh:{nextInterval:"DD",contains:24,count:2},DD:{nextInterval:"",contains:Infinity,count:3}}; | ||
366 | AmCharts.getMaxInterval=function(a,b){var c=AmCharts.intervals;return a>=c[b].contains?(a=Math.round(a/c[b].contains),b=c[b].nextInterval,AmCharts.getMaxInterval(a,b)):"ss"==b?c[b].nextInterval:b};AmCharts.dayNames="Sunday Monday Tuesday Wednesday Thursday Friday Saturday".split(" ");AmCharts.shortDayNames="Sun Mon Tue Wed Thu Fri Sat".split(" ");AmCharts.monthNames="January February March April May June July August September October November December".split(" ");AmCharts.shortMonthNames="Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec".split(" "); | ||
367 | AmCharts.getWeekNumber=function(a){a=new Date(a);a.setHours(0,0,0);a.setDate(a.getDate()+4-(a.getDay()||7));var b=new Date(a.getFullYear(),0,1);return Math.ceil(((a-b)/864E5+1)/7)}; | ||
368 | AmCharts.stringToDate=function(a,b){var c={},d=[{pattern:"YYYY",period:"year"},{pattern:"YY",period:"year"},{pattern:"MM",period:"month"},{pattern:"M",period:"month"},{pattern:"DD",period:"date"},{pattern:"D",period:"date"},{pattern:"JJ",period:"hours"},{pattern:"J",period:"hours"},{pattern:"HH",period:"hours"},{pattern:"H",period:"hours"},{pattern:"KK",period:"hours"},{pattern:"K",period:"hours"},{pattern:"LL",period:"hours"},{pattern:"L",period:"hours"},{pattern:"NN",period:"minutes"},{pattern:"N", | ||
369 | period:"minutes"},{pattern:"SS",period:"seconds"},{pattern:"S",period:"seconds"},{pattern:"QQQ",period:"milliseconds"},{pattern:"QQ",period:"milliseconds"},{pattern:"Q",period:"milliseconds"}],e=!0,f=b.indexOf("AA");-1!=f&&(a.substr(f,2),"pm"==a.toLowerCase&&(e=!1));var f=b,g,h,k;for(k=0;k<d.length;k++)h=d[k].period,c[h]=0,"date"==h&&(c[h]=1);for(k=0;k<d.length;k++)if(g=d[k].pattern,h=d[k].period,-1!=b.indexOf(g)){var l=AmCharts.getFromDateString(g,a,f);b=b.replace(g,"");if("KK"==g||"K"==g||"LL"== | ||
370 | g||"L"==g)e||(l+=12);c[h]=l}return new Date(c.year,c.month,c.date,c.hours,c.minutes,c.seconds,c.milliseconds)};AmCharts.getFromDateString=function(a,b,c){if(void 0!==b)return c=c.indexOf(a),b=b.substr(c,a.length),"0"==b.charAt(0)&&(b=b.substr(1,b.length-1)),b=Number(b),isNaN(b)&&(b=0),-1!=a.indexOf("M")&&b--,b}; | ||
371 | AmCharts.formatDate=function(a,b){var c,d,e,f,g,h,k,l,m=AmCharts.getWeekNumber(a);AmCharts.useUTC?(c=a.getUTCFullYear(),d=a.getUTCMonth(),e=a.getUTCDate(),f=a.getUTCDay(),g=a.getUTCHours(),h=a.getUTCMinutes(),k=a.getUTCSeconds(),l=a.getUTCMilliseconds()):(c=a.getFullYear(),d=a.getMonth(),e=a.getDate(),f=a.getDay(),g=a.getHours(),h=a.getMinutes(),k=a.getSeconds(),l=a.getMilliseconds());var n=String(c).substr(2,2),p=d+1;9>d&&(p="0"+p);var q="0"+f;b=b.replace(/W/g,m);m=g;24==m&&(m=0);var r=m;10>r&&(r= | ||
372 | "0"+r);b=b.replace(/JJ/g,r);b=b.replace(/J/g,m);r=g;0===r&&(r=24,-1!=b.indexOf("H")&&e--);m=e;10>e&&(m="0"+e);var s=r;10>s&&(s="0"+s);b=b.replace(/HH/g,s);b=b.replace(/H/g,r);r=g;11<r&&(r-=12);s=r;10>s&&(s="0"+s);b=b.replace(/KK/g,s);b=b.replace(/K/g,r);r=g;0===r&&(r=12);12<r&&(r-=12);s=r;10>s&&(s="0"+s);b=b.replace(/LL/g,s);b=b.replace(/L/g,r);r=h;10>r&&(r="0"+r);b=b.replace(/NN/g,r);b=b.replace(/N/g,h);h=k;10>h&&(h="0"+h);b=b.replace(/SS/g,h);b=b.replace(/S/g,k);k=l;10>k&&(k="00"+k);100>k&&(k="0"+ | ||
373 | k);h=l;10>h&&(h="00"+h);b=b.replace(/QQQ/g,k);b=b.replace(/QQ/g,h);b=b.replace(/Q/g,l);b=12>g?b.replace(/A/g,"am"):b.replace(/A/g,"pm");b=b.replace(/YYYY/g,"@IIII@");b=b.replace(/YY/g,"@II@");b=b.replace(/MMMM/g,"@XXXX@");b=b.replace(/MMM/g,"@XXX@");b=b.replace(/MM/g,"@XX@");b=b.replace(/M/g,"@X@");b=b.replace(/DD/g,"@RR@");b=b.replace(/D/g,"@R@");b=b.replace(/EEEE/g,"@PPPP@");b=b.replace(/EEE/g,"@PPP@");b=b.replace(/EE/g,"@PP@");b=b.replace(/E/g,"@P@");b=b.replace(/@IIII@/g,c);b=b.replace(/@II@/g, | ||
374 | n);b=b.replace(/@XXXX@/g,AmCharts.monthNames[d]);b=b.replace(/@XXX@/g,AmCharts.shortMonthNames[d]);b=b.replace(/@XX@/g,p);b=b.replace(/@X@/g,d+1);b=b.replace(/@RR@/g,m);b=b.replace(/@R@/g,e);b=b.replace(/@PPPP@/g,AmCharts.dayNames[f]);b=b.replace(/@PPP@/g,AmCharts.shortDayNames[f]);b=b.replace(/@PP@/g,q);return b=b.replace(/@P@/g,f)}; | ||
375 | AmCharts.changeDate=function(a,b,c,d,e){var f=-1;void 0===d&&(d=!0);void 0===e&&(e=!1);!0===d&&(f=1);switch(b){case "YYYY":a.setFullYear(a.getFullYear()+c*f);d||e||a.setDate(a.getDate()+1);break;case "MM":b=a.getMonth();a.setMonth(a.getMonth()+c*f);a.getMonth()>b+c*f&&a.setDate(a.getDate()-1);d||e||a.setDate(a.getDate()+1);break;case "DD":a.setDate(a.getDate()+c*f);break;case "WW":a.setDate(a.getDate()+c*f*7);break;case "hh":a.setHours(a.getHours()+c*f);break;case "mm":a.setMinutes(a.getMinutes()+ | ||
376 | c*f);break;case "ss":a.setSeconds(a.getSeconds()+c*f);break;case "fff":a.setMilliseconds(a.getMilliseconds()+c*f)}return a}; |
amcharts/exporting/amexport.js
File was created | 1 | AmCharts.AmExport = AmCharts.Class({ | |
2 | construct: function(chart, cfg, init ) { | ||
3 | var _this = this; | ||
4 | _this.DEBUG = false; | ||
5 | _this.chart = chart; | ||
6 | _this.canvas = null; | ||
7 | _this.svgs = []; | ||
8 | _this.userCFG = cfg; | ||
9 | |||
10 | _this.buttonIcon = 'export.png'; | ||
11 | _this.exportPNG = true; | ||
12 | _this.exportPDF = false; | ||
13 | _this.exportJPG = false; | ||
14 | _this.exportSVG = false; | ||
15 | //_this.left; | ||
16 | _this.right = 0; | ||
17 | //_this.bottom; | ||
18 | _this.top = 0; | ||
19 | //_this.color; | ||
20 | _this.buttonRollOverColor = "#EFEFEF"; | ||
21 | //_this.buttonColor = "#FFFFFF"; | ||
22 | //_this.buttonRollOverAlpha = 0.5; | ||
23 | _this.textRollOverColor = "#CC0000"; | ||
24 | _this.buttonTitle = "Save chart as an image"; | ||
25 | _this.buttonAlpha = 0.75; | ||
26 | _this.imageFileName = "amChart"; | ||
27 | _this.imageBackgroundColor = "#FFFFFF"; | ||
28 | |||
29 | if (init) { | ||
30 | _this.init(); | ||
31 | } | ||
32 | }, | ||
33 | |||
34 | toCoordinate:function(value){ | ||
35 | if(value === undefined){ | ||
36 | return "auto"; | ||
37 | } | ||
38 | if(String(value).indexOf("%") != -1){ | ||
39 | return value; | ||
40 | } | ||
41 | else{ | ||
42 | return value + "px"; | ||
43 | } | ||
44 | }, | ||
45 | |||
46 | init: function(){ | ||
47 | var _this = this; | ||
48 | |||
49 | var formats = []; | ||
50 | if (_this.exportPNG) { | ||
51 | formats.push("png"); | ||
52 | } | ||
53 | if (_this.exportPDF) { | ||
54 | formats.push("pdf"); | ||
55 | } | ||
56 | if (_this.exportJPG) { | ||
57 | formats.push("jpg"); | ||
58 | } | ||
59 | if (_this.exportSVG) { | ||
60 | formats.push("svg"); | ||
61 | } | ||
62 | |||
63 | var menuItems = []; | ||
64 | if(formats.length == 1){ | ||
65 | var format = formats[0]; | ||
66 | menuItems.push({format:format, iconTitle:_this.buttonTitle, icon:_this.chart.pathToImages + _this.buttonIcon}) | ||
67 | } | ||
68 | else if(formats.length > 1){ | ||
69 | var subItems = []; | ||
70 | for(var i = 0; i < formats.length; i++){ | ||
71 | subItems.push({format:formats[i], title:formats[i].toUpperCase()}); | ||
72 | } | ||
73 | menuItems.push({onclick: function() {}, icon:_this.chart.pathToImages + _this.buttonIcon, items:subItems}) | ||
74 | } | ||
75 | |||
76 | |||
77 | var color = _this.color; | ||
78 | if(color === undefined){ | ||
79 | color = _this.chart.color; | ||
80 | } | ||
81 | |||
82 | var buttonColor = _this.buttonColor; | ||
83 | if(buttonColor === undefined){ | ||
84 | buttonColor = "transparent"; | ||
85 | } | ||
86 | |||
87 | |||
88 | _this.cfg = { | ||
89 | menuTop : _this.toCoordinate(_this.top), | ||
90 | menuLeft : _this.toCoordinate(_this.left), | ||
91 | menuRight : _this.toCoordinate(_this.right), | ||
92 | menuBottom : _this.toCoordinate(_this.bottom), | ||
93 | menuItems : menuItems, | ||
94 | menuItemStyle: { | ||
95 | backgroundColor : buttonColor, | ||
96 | opacity :_this.buttonAlpha, | ||
97 | rollOverBackgroundColor : _this.buttonRollOverColor, | ||
98 | color : color, | ||
99 | rollOverColor : _this.textRollOverColor, | ||
100 | paddingTop : '6px', | ||
101 | paddingRight : '6px', | ||
102 | paddingBottom : '6px', | ||
103 | paddingLeft : '6px', | ||
104 | marginTop : '0px', | ||
105 | marginRight : '0px', | ||
106 | marginBottom : '0px', | ||
107 | marginLeft : '0px', | ||
108 | textAlign : 'left', | ||
109 | textDecoration : 'none', | ||
110 | fontFamily : _this.chart.fontFamily, | ||
111 | fontSize : _this.chart.fontSize + 'px' | ||
112 | }, | ||
113 | menuItemOutput: { | ||
114 | backgroundColor : _this.imageBackgroundColor, | ||
115 | fileName : _this.imageFileName, | ||
116 | format : 'png', | ||
117 | output : 'dataurlnewwindow', | ||
118 | render : 'browser', | ||
119 | dpi : 90, | ||
120 | onclick : function(instance, config, event) { | ||
121 | event.preventDefault(); | ||
122 | if(_this.chart.prepareForExport){ | ||
123 | _this.chart.prepareForExport(); | ||
124 | } | ||
125 | instance.output(config); | ||
126 | } | ||
127 | }, | ||
128 | removeImagery: true | ||
129 | }; | ||
130 | |||
131 | _this.processing = { | ||
132 | buffer: [], | ||
133 | drawn: 0, | ||
134 | timer: 0 | ||
135 | }; | ||
136 | |||
137 | // Config dependency adaption | ||
138 | if (typeof(window.canvg) != 'undefined' && typeof(window.RGBColor) != 'undefined') { | ||
139 | _this.cfg.menuItemOutput.render = 'canvg'; | ||
140 | } | ||
141 | if (typeof(window.saveAs) != 'undefined') { | ||
142 | _this.cfg.menuItemOutput.output = 'save'; | ||
143 | } | ||
144 | if (AmCharts.isIE && AmCharts.IEversion < 10) { | ||
145 | _this.cfg.menuItemOutput.output = 'dataurlnewwindow'; | ||
146 | } | ||
147 | |||
148 | // Merge given configs | ||
149 | var cfg = _this.userCFG; | ||
150 | if (cfg) { | ||
151 | cfg.menuItemOutput = AmCharts.extend(_this.cfg.menuItemOutput, cfg.menuItemOutput || {}); | ||
152 | cfg.menuItemStyle = AmCharts.extend(_this.cfg.menuItemStyle, cfg.menuItemStyle || {}); | ||
153 | _this.cfg = AmCharts.extend(_this.cfg, cfg); | ||
154 | } | ||
155 | |||
156 | // Add reference to chart | ||
157 | _this.chart.AmExport = _this; | ||
158 | |||
159 | // Listen to the drawer | ||
160 | _this.chart.addListener('rendered', function() { | ||
161 | _this.setup(); | ||
162 | }); | ||
163 | |||
164 | // DEBUG; Public reference | ||
165 | if (_this.DEBUG) { | ||
166 | window.AmExport = _this; | ||
167 | } | ||
168 | }, | ||
169 | |||
170 | |||
171 | /* | ||
172 | Simple log function for internal purpose | ||
173 | @param **args | ||
174 | */ | ||
175 | log: function() { | ||
176 | console.log('AmExport: ', arguments); | ||
177 | }, | ||
178 | |||
179 | /* PUBLIC | ||
180 | Prepares everything to get exported | ||
181 | @param none | ||
182 | */ | ||
183 | setup: function() { | ||
184 | var _this = this; | ||
185 | |||
186 | if (_this.DEBUG == 10) { | ||
187 | _this.log('SETUP START'); | ||
188 | } // DEBUG | ||
189 | |||
190 | |||
191 | if (!AmCharts.isIE || (AmCharts.isIE && AmCharts.IEversion > 9)) { | ||
192 | // Build Buttons | ||
193 | _this.generateButtons(); | ||
194 | if (_this.DEBUG == 10) { | ||
195 | _this.log('SETUP END'); | ||
196 | } // DEBUG | ||
197 | } else { | ||
198 | if (_this.DEBUG == 10) { | ||
199 | _this.log('< IE10 NOT SUPPORTED'); | ||
200 | } // DEBUG | ||
201 | } | ||
202 | }, | ||
203 | |||
204 | /* PUBLIC | ||
205 | Decodes base64 string to binary array | ||
206 | @param base64_string | ||
207 | @copyright Eli Grey, http://eligrey.com and Devin Samarin, https://github.com/eboyjr | ||
208 | */ | ||
209 | generateBinaryArray: function(base64_string) { | ||
210 | var | ||
211 | len = base64_string.length, | ||
212 | buffer = new Uint8Array(len / 4 * 3 | 0), | ||
213 | i = 0, | ||
214 | outptr = 0, | ||
215 | last = [0, 0], | ||
216 | state = 0, | ||
217 | save = 0, | ||
218 | rank, code, undef, base64_ranks = new Uint8Array([ | ||
219 | 62, -1, -1, -1, 63, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, -1, -1, -1, 0, -1, -1, -1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1, -1, -1, -1, -1, -1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51 | ||
220 | ]); | ||
221 | while (len--) { | ||
222 | code = base64_string.charCodeAt(i++); | ||
223 | rank = base64_ranks[code - 43]; | ||
224 | if (rank !== 255 && rank !== undef) { | ||
225 | last[1] = last[0]; | ||
226 | last[0] = code; | ||
227 | save = (save << 6) | rank; | ||
228 | state++; | ||
229 | if (state === 4) { | ||
230 | buffer[outptr++] = save >>> 16; | ||
231 | if (last[1] !== 61 /* padding character */ ) { | ||
232 | buffer[outptr++] = save >>> 8; | ||
233 | } | ||
234 | if (last[0] !== 61 /* padding character */ ) { | ||
235 | buffer[outptr++] = save; | ||
236 | } | ||
237 | state = 0; | ||
238 | } | ||
239 | } | ||
240 | } | ||
241 | // 2/3 chance there's going to be some null bytes at the end, but that | ||
242 | // doesn't really matter with most image formats. | ||
243 | // If it somehow matters for you, truncate the buffer up outptr. | ||
244 | return buffer; | ||
245 | }, | ||
246 | |||
247 | /* | ||
248 | Creates blob object | ||
249 | @param base64_datastring string | ||
250 | @param type string | ||
251 | */ | ||
252 | generateBlob: function(datastring, type) { | ||
253 | var _this = this, | ||
254 | header_end = type!='image/svg+xml'?datastring.indexOf(',') + 1:0, | ||
255 | header = datastring.substring(0, header_end), | ||
256 | data = datastring, | ||
257 | blob = new Blob(); | ||
258 | |||
259 | if (header.indexOf('base64') != -1) { | ||
260 | data = _this.generateBinaryArray(datastring.substring(header_end)); | ||
261 | } | ||
262 | |||
263 | // Fake blob for IE | ||
264 | if (AmCharts.isIE && AmCharts.IEversion < 10) { | ||
265 | blob.data = data; | ||
266 | blob.size = data.length; | ||
267 | blob.type = type; | ||
268 | blob.encoding = 'base64'; | ||
269 | } else { | ||
270 | blob = new Blob([data], { | ||
271 | type: type | ||
272 | }); | ||
273 | } | ||
274 | return blob; | ||
275 | }, | ||
276 | |||
277 | /* | ||
278 | Creates PDF object | ||
279 | @param config object | ||
280 | */ | ||
281 | generatePDF: function(cfg) { | ||
282 | var _this = this, | ||
283 | pdf = { | ||
284 | output: function() { | ||
285 | return ''; | ||
286 | } | ||
287 | }, | ||
288 | data = _this.canvas.toDataURL('image/jpeg'), // JSPDF ONLY SUPPORTS JPG | ||
289 | width = (_this.canvas.width * 25.4) / cfg.dpi, | ||
290 | height = (_this.canvas.height * 25.4) / cfg.dpi; | ||
291 | |||
292 | // Check | ||
293 | if (window.jsPDF) { | ||
294 | pdf = new jsPDF(); | ||
295 | if (pdf.addImage) { | ||
296 | pdf.addImage(data, 'JPEG', 0, 0, width, height); | ||
297 | } else { | ||
298 | alert("Missing jsPDF plugin; Please add the 'addImage' plugin."); | ||
299 | } | ||
300 | } else { | ||
301 | alert("Missing jsPDF lib; Don't forget to add the addImage plugin."); | ||
302 | } | ||
303 | |||
304 | return pdf; | ||
305 | }, | ||
306 | |||
307 | /* | ||
308 | Creates the CANVAS to receive the image data | ||
309 | @param format void() | ||
310 | @param callback; given callback function which returns the blob or datastring of the configured ouput type | ||
311 | */ | ||
312 | output: function(cfg, externalCallback) { | ||
313 | var _this = this; | ||
314 | cfg = AmCharts.extend(AmCharts.extend({}, _this.cfg.menuItemOutput), cfg || {}); | ||
315 | |||
316 | /* PRIVATE | ||
317 | Callback function which gets called after the drawing process is done | ||
318 | @param none | ||
319 | */ | ||
320 | function internalCallback() { | ||
321 | var data = null; | ||
322 | var blob; | ||
323 | if (_this.DEBUG == 10) { | ||
324 | _this.log('OUTPUT', cfg.format); | ||
325 | } // DEBUG | ||
326 | |||
327 | // SVG | ||
328 | if (cfg.format == 'image/svg+xml' || cfg.format == 'svg') { | ||
329 | data = _this.generateSVG(); | ||
330 | blob = _this.generateBlob(data, 'image/svg+xml'); | ||
331 | |||
332 | if (cfg.output == 'save') { | ||
333 | saveAs(blob, cfg.fileName + '.svg'); | ||
334 | } else if (cfg.output == 'datastring' || cfg.output == 'datauristring' || cfg.output == 'dataurlstring') { | ||
335 | blob = 'data:image/svg+xml;base64,' + btoa(data); | ||
336 | } else if (cfg.output == 'dataurlnewwindow') { | ||
337 | window.open('data:image/svg+xml;base64,' + btoa(data)); | ||
338 | } else if (cfg.output == 'datauri' || cfg.output == 'dataurl') { | ||
339 | location.href = 'data:image/svg+xml;base64,' + btoa(data); | ||
340 | } else if (cfg.output == 'datastream') { | ||
341 | location.href = 'data:image/octet-stream;base64,' + data; | ||
342 | } | ||
343 | |||
344 | if (externalCallback) | ||
345 | externalCallback.apply(_this, [blob]); | ||
346 | |||
347 | |||
348 | } else if (cfg.format == 'application/pdf' || cfg.format == 'pdf') { | ||
349 | data = _this.generatePDF(cfg).output('dataurlstring'); | ||
350 | blob = _this.generateBlob(data, 'application/pdf'); | ||
351 | |||
352 | if (cfg.output == 'save') { | ||
353 | saveAs(blob, cfg.fileName + '.pdf'); | ||
354 | } else if (cfg.output == 'datastring' || cfg.output == 'datauristring' || cfg.output == 'dataurlstring') { | ||
355 | blob = data; | ||
356 | } else if (cfg.output == 'dataurlnewwindow') { | ||
357 | window.open(data); | ||
358 | } else if (cfg.output == 'datauri' || cfg.output == 'dataurl') { | ||
359 | location.href = data; | ||
360 | } else if (cfg.output == 'datastream') { | ||
361 | location.href = data.replace('application/pdf', 'application/octet-stream'); | ||
362 | } | ||
363 | |||
364 | if (externalCallback) | ||
365 | externalCallback.apply(_this, [blob]); | ||
366 | |||
367 | // PNG | ||
368 | } else if (cfg.format == 'image/png' || cfg.format == 'png') { | ||
369 | data = _this.canvas.toDataURL('image/png'); | ||
370 | blob = _this.generateBlob(data, 'image/png'); | ||
371 | |||
372 | if (cfg.output == 'save') { | ||
373 | saveAs(blob, cfg.fileName + '.png'); | ||
374 | } else if (cfg.output == 'datastring' || cfg.output == 'datauristring' || cfg.output == 'dataurlstring') { | ||
375 | blob = data; | ||
376 | } else if (cfg.output == 'dataurlnewwindow') { | ||
377 | window.open(data); | ||
378 | } else if (cfg.output == 'datauri' || cfg.output == 'dataurl') { | ||
379 | location.href = data; | ||
380 | } else if (cfg.output == 'datastream') { | ||
381 | location.href = data.replace('image/png', 'image/octet-stream'); | ||
382 | } | ||
383 | |||
384 | if (externalCallback) | ||
385 | externalCallback.apply(_this, [blob]); | ||
386 | |||
387 | // JPG | ||
388 | } else if (cfg.format == 'image/jpeg' || cfg.format == 'jpeg' || cfg.format == 'jpg') { | ||
389 | data = _this.canvas.toDataURL('image/jpeg'); | ||
390 | blob = _this.generateBlob(data, 'image/jpeg'); | ||
391 | |||
392 | if (cfg.output == 'save') { | ||
393 | saveAs(blob, cfg.fileName + '.jpg'); | ||
394 | } else if (cfg.output == 'datastring' || cfg.output == 'datauristring' || cfg.output == 'dataurlstring') { | ||
395 | blob = data; | ||
396 | } else if (cfg.output == 'dataurlnewwindow') { | ||
397 | window.open(data); | ||
398 | } else if (cfg.output == 'datauri' || cfg.output == 'dataurl') { | ||
399 | location.href = data; | ||
400 | } else if (cfg.output == 'datastream') { | ||
401 | location.href = data.replace('image/jpeg', 'image/octet-stream'); | ||
402 | } | ||
403 | |||
404 | if (externalCallback) | ||
405 | externalCallback.apply(_this, [blob]); | ||
406 | } | ||
407 | |||
408 | } | ||
409 | |||
410 | return _this.generateOutput(cfg, internalCallback); | ||
411 | }, | ||
412 | |||
413 | /* PUBLIC | ||
414 | Polifies missing attributes to the SVG and replaces images to embedded base64 images | ||
415 | @param none | ||
416 | */ | ||
417 | polifySVG: function(svg) { | ||
418 | var _this = this; | ||
419 | |||
420 | // Recursive function to force the attributes | ||
421 | function recursiveChange(svg, tag) { | ||
422 | var items = svg.getElementsByTagName(tag); | ||
423 | var i = items.length; | ||
424 | |||
425 | while(i--) { | ||
426 | if (_this.cfg.removeImagery) { | ||
427 | items[i].parentNode.removeChild(items[i]); | ||
428 | |||
429 | } else { | ||
430 | var image = document.createElement('img'); | ||
431 | var canvas = document.createElement('canvas'); | ||
432 | var ctx = canvas.getContext('2d'); | ||
433 | |||
434 | canvas.width = items[i].getAttribute('width'); | ||
435 | canvas.height = items[i].getAttribute('height'); | ||
436 | image.src = items[i].getAttribute('xlink:href'); | ||
437 | image.width = items[i].getAttribute('width'); | ||
438 | image.height = items[i].getAttribute('height'); | ||
439 | |||
440 | try { | ||
441 | ctx.drawImage(image, 0, 0, image.width, image.height); | ||
442 | datastring = canvas.toDataURL(); // image.src; // canvas.toDataURL(); // | ||
443 | } catch (err) { | ||
444 | datastring = image.src; // image.src; // canvas.toDataURL(); // | ||
445 | |||
446 | _this.log('Tainted canvas, reached browser CORS security; origin from imagery must be equal to the server!'); | ||
447 | throw new Error(err); | ||
448 | } | ||
449 | |||
450 | items[i].setAttribute('xlink:href', datastring); | ||
451 | } | ||
452 | |||
453 | if (_this.DEBUG == 10) { | ||
454 | _this.log('POLIFIED', items[i]); | ||
455 | } // DEBUG | ||
456 | } | ||
457 | } | ||
458 | |||
459 | // Put some attrs to it; fixed 20/03/14 xmlns is required to produce a valid svg file | ||
460 | if (AmCharts.IEversion == 0) { | ||
461 | svg.setAttribute('xmlns', 'http://www.w3.org/2000/svg'); | ||
462 | if ( !_this.cfg.removeImagery ) { | ||
463 | svg.setAttribute('xmlns:xlink','http://www.w3.org/1999/xlink'); | ||
464 | } | ||
465 | } | ||
466 | |||
467 | // DEBUG | ||
468 | if (_this.DEBUG == 10) { | ||
469 | _this.log('POLIFIED', svg); | ||
470 | } | ||
471 | |||
472 | // Force link adaption | ||
473 | recursiveChange(svg, 'pattern'); | ||
474 | recursiveChange(svg, 'image'); | ||
475 | |||
476 | _this.svgs.push(svg); | ||
477 | |||
478 | return svg; | ||
479 | }, | ||
480 | |||
481 | |||
482 | /* PUBLIC | ||
483 | Stacks multiple SVGs into one | ||
484 | @param none | ||
485 | */ | ||
486 | generateSVG: function() { | ||
487 | var _this = this; | ||
488 | var context = document.createElement('svg'); | ||
489 | context.setAttribute('xmlns', 'http://www.w3.org/2000/svg'); | ||
490 | context.setAttribute('xmlns:xlink','http://www.w3.org/1999/xlink'); | ||
491 | |||
492 | for (var i = 0; i < _this.processing.buffer.length; i++) { | ||
493 | var group = document.createElement('g'), | ||
494 | data = _this.processing.buffer[i]; | ||
495 | |||
496 | data[0].setAttribute('xmlns', 'http://www.w3.org/2000/svg'); | ||
497 | data[0].setAttribute('xmlns:xlink','http://www.w3.org/1999/xlink'); | ||
498 | |||
499 | group.setAttribute('transform', 'translate('+data[1].x+','+data[1].y+')'); | ||
500 | group.appendChild(data[0]); | ||
501 | context.appendChild(group); | ||
502 | } | ||
503 | |||
504 | return new XMLSerializer().serializeToString(context); | ||
505 | }, | ||
506 | |||
507 | /* PUBLIC | ||
508 | Generates the canvas with the given SVGs and configured renderer | ||
509 | @param callback; function(); gets called after drawing process on the canvas has been finished | ||
510 | */ | ||
511 | generateOutput: function(cfg, callback) { | ||
512 | var _this = this, | ||
513 | svgs = _this.chart.div.getElementsByTagName('svg'), | ||
514 | canvas = document.createElement('canvas'), | ||
515 | context = canvas.getContext('2d'), | ||
516 | offset = { | ||
517 | y: 0, | ||
518 | x: 0 | ||
519 | }, | ||
520 | tmp = {}; | ||
521 | |||
522 | // Reset | ||
523 | _this.processing.buffer = []; | ||
524 | _this.processing.drawn = 0; | ||
525 | _this.canvas = canvas; | ||
526 | _this.svgs = []; | ||
527 | |||
528 | // Walkthroug SVGs | ||
529 | if (_this.DEBUG == 10) { | ||
530 | _this.log('START EXPORT'); | ||
531 | } // DEBUG | ||
532 | if (_this.DEBUG == 10) { | ||
533 | _this.log('START BUFFERING'); | ||
534 | } // DEBUG | ||
535 | for (var i = 0; i < svgs.length; i++) { | ||
536 | var parent = svgs[i].parentNode, | ||
537 | svgX = Number(parent.style.left.slice(0, -2)), | ||
538 | svgY = Number(parent.style.top.slice(0, -2)), | ||
539 | svgClone = _this.polifySVG(svgs[i].cloneNode(true)), | ||
540 | tmp = AmCharts.extend({}, offset); | ||
541 | |||
542 | // Overtake parent position if given; fixed 20/03/14 distinguish between relativ and others | ||
543 | if (parent.style.position == 'relative') { | ||
544 | offset.x = svgX ? svgX : offset.x; | ||
545 | offset.y = svgY ? svgY : offset.y; | ||
546 | } else { | ||
547 | offset.x = svgX; | ||
548 | offset.y = svgY; | ||
549 | } | ||
550 | |||
551 | _this.processing.buffer.push([svgClone, AmCharts.extend({}, offset)]); | ||
552 | |||
553 | // Put back from "cache" | ||
554 | if (svgY && svgX) { | ||
555 | offset = tmp; | ||
556 | |||
557 | // New offset for next one | ||
558 | } else { | ||
559 | offset.y += svgY ? 0 : parent.offsetHeight; | ||
560 | } | ||
561 | |||
562 | if (_this.DEBUG == 10) { | ||
563 | _this.log('BUFFERED', svgs[i], offset); | ||
564 | } // DEBUG | ||
565 | } | ||
566 | if (_this.DEBUG == 10) { | ||
567 | _this.log('END BUFFERING'); | ||
568 | } // DEBUG | ||
569 | |||
570 | // Apply background | ||
571 | if (_this.DEBUG == 10) { | ||
572 | _this.log('START DRAWING', cfg.render); | ||
573 | } // DEBUG | ||
574 | if (_this.DEBUG == 10) { | ||
575 | _this.log('FILL BACKGROUND'); | ||
576 | } // DEBUG | ||
577 | canvas.id = AmCharts.getUniqueId(); | ||
578 | canvas.width = _this.chart.divRealWidth; | ||
579 | canvas.height = _this.chart.divRealHeight; | ||
580 | |||
581 | |||
582 | // Stockchart exception | ||
583 | var adapted = { | ||
584 | width: false, | ||
585 | height: false | ||
586 | }; | ||
587 | if ( _this.chart.periodSelector ) { | ||
588 | if ( ['left','right'].indexOf(_this.chart.periodSelector.position) != -1 ) { | ||
589 | canvas.width -= _this.chart.periodSelector.div.offsetWidth + 16; | ||
590 | adapted.width = true; | ||
591 | } else { | ||
592 | canvas.height -= _this.chart.periodSelector.div.offsetHeight; | ||
593 | adapted.height = true; | ||
594 | } | ||
595 | } | ||
596 | |||
597 | if ( _this.chart.dataSetSelector ) { | ||
598 | if ( ['left','right'].indexOf(_this.chart.dataSetSelector.position) != -1 ) { | ||
599 | if ( !adapted.width ) { | ||
600 | canvas.width -= _this.chart.dataSetSelector.div.offsetWidth + 16; | ||
601 | } | ||
602 | } else { | ||
603 | canvas.height -= _this.chart.dataSetSelector.div.offsetHeight; | ||
604 | } | ||
605 | } | ||
606 | |||
607 | // Set given background; jpeg default | ||
608 | if (cfg.backgroundColor || cfg.format == 'image/jpeg') { | ||
609 | context.fillStyle = cfg.backgroundColor || '#FFFFFF'; | ||
610 | context.fillRect(0, 0, canvas.width, canvas.height); | ||
611 | } | ||
612 | |||
613 | /* PRIVATE | ||
614 | Recursive function to draw the images to the canvas; | ||
615 | @param none; | ||
616 | */ | ||
617 | function drawItWhenItsLoaded() { | ||
618 | var img, buffer, offset, source; | ||
619 | |||
620 | // DRAWING PROCESS DONE | ||
621 | if (_this.processing.buffer.length == _this.processing.drawn || cfg.format == 'svg' ) { | ||
622 | if (_this.DEBUG == 10) { | ||
623 | _this.log('END DRAWING'); | ||
624 | } // DEBUG | ||
625 | return callback(); | ||
626 | |||
627 | // LOOPING LUI | ||
628 | } else { | ||
629 | if (_this.DEBUG == 10) { | ||
630 | _this.log('DRAW', _this.processing.drawn + 1, 'OF', _this.processing.buffer.length); | ||
631 | } // DEBUG | ||
632 | |||
633 | buffer = _this.processing.buffer[_this.processing.drawn]; | ||
634 | source = new XMLSerializer().serializeToString(buffer[0]); //source = 'data:image/svg+xml;base64,' + btoa(); | ||
635 | offset = buffer[1]; | ||
636 | |||
637 | if (_this.DEBUG == 10) { | ||
638 | _this.log('SOURCE', source); | ||
639 | } // DEBUG | ||
640 | |||
641 | // NATIVE | ||
642 | if (cfg.render == 'browser') { | ||
643 | img = new Image(); | ||
644 | img.id = AmCharts.getUniqueId(); | ||
645 | source = 'data:image/svg+xml;base64,' + btoa(source); | ||
646 | |||
647 | //img.crossOrigin = "Anonymous"; | ||
648 | img.onload = function() { | ||
649 | context.drawImage(this, buffer[1].x, buffer[1].y); | ||
650 | _this.processing.drawn++; | ||
651 | |||
652 | if (_this.DEBUG == 10) { | ||
653 | _this.log('ONLOAD', this); | ||
654 | } // DEBUG | ||
655 | drawItWhenItsLoaded(); | ||
656 | }; | ||
657 | img.onerror = function() { | ||
658 | if (_this.DEBUG == 10) { | ||
659 | _this.log('ONERROR', this); | ||
660 | } // DEBUG | ||
661 | context.drawImage(this, buffer[1].x, buffer[1].y); | ||
662 | _this.processing.drawn++; | ||
663 | drawItWhenItsLoaded(); | ||
664 | }; | ||
665 | img.src = source; | ||
666 | |||
667 | if (_this.DEBUG == 10) { | ||
668 | _this.log('ADD', img); | ||
669 | } // DEBUG | ||
670 | if (img.complete || typeof(img.complete) == 'undefined' || img.complete === undefined) { | ||
671 | if (_this.DEBUG == 10) { | ||
672 | _this.log('FORCE ONLOAD', img); | ||
673 | } // DEBUG | ||
674 | img.src = ""; | ||
675 | img.src = source; | ||
676 | } | ||
677 | |||
678 | // CANVG | ||
679 | } else if (cfg.render == 'canvg') { | ||
680 | canvg(canvas, source, { | ||
681 | offsetX: offset.x, | ||
682 | offsetY: offset.y, | ||
683 | ignoreMouse: true, | ||
684 | ignoreAnimation: true, | ||
685 | ignoreDimensions: true, | ||
686 | ignoreClear: true, | ||
687 | renderCallback: function() { | ||
688 | _this.processing.drawn++; | ||
689 | drawItWhenItsLoaded(); | ||
690 | } | ||
691 | }); | ||
692 | } | ||
693 | } | ||
694 | } | ||
695 | return drawItWhenItsLoaded(); | ||
696 | }, | ||
697 | |||
698 | /* | ||
699 | Generates the export menu to trigger the exportation | ||
700 | @param none; | ||
701 | */ | ||
702 | generateButtons: function() { | ||
703 | var _this = this, | ||
704 | div = document.createElement('div'), | ||
705 | lvl = 0; | ||
706 | |||
707 | // Push sublings | ||
708 | function createList(items) { | ||
709 | var ul = document.createElement('ul'); | ||
710 | |||
711 | ul.setAttribute('style', 'list-style: none; margin: 0; padding: 0;'); | ||
712 | |||
713 | // Walkthrough items | ||
714 | for (var i = 0; i < items.length; i++) { | ||
715 | var li = document.createElement('li'), | ||
716 | img = document.createElement('img'), | ||
717 | a = document.createElement('a'), | ||
718 | item = items[i], | ||
719 | children = null, | ||
720 | itemStyle = AmCharts.extend(AmCharts.extend({}, _this.cfg.menuItemStyle), items[i]); | ||
721 | |||
722 | // MERGE CFG | ||
723 | item = AmCharts.extend(AmCharts.extend({}, _this.cfg.menuItemOutput), item); | ||
724 | |||
725 | // ICON | ||
726 | if (item['icon']) { | ||
727 | img.alt = ''; | ||
728 | img.src = item['icon']; | ||
729 | img.setAttribute('style', 'margin: 0 auto;border: none;outline: none'); | ||
730 | if (item['iconTitle']) { | ||
731 | img.title = item['iconTitle']; | ||
732 | } | ||
733 | a.appendChild(img); | ||
734 | } | ||
735 | |||
736 | // TITLE; STYLING | ||
737 | a.href = '#'; | ||
738 | if (item['title']) { | ||
739 | img.setAttribute('style', 'margin-right: 5px;'); | ||
740 | a.innerHTML += item.title; | ||
741 | } | ||
742 | a.setAttribute('style', 'display: block;'); | ||
743 | AmCharts.extend(a.style, itemStyle); | ||
744 | |||
745 | // ONCLICK | ||
746 | a.onclick = item.onclick.bind(a, _this, item); | ||
747 | li.appendChild(a); | ||
748 | |||
749 | // APPEND SIBLINGS | ||
750 | if (item.items) { | ||
751 | children = createList(item.items); | ||
752 | li.appendChild(children); | ||
753 | |||
754 | li.onmouseover = function() { | ||
755 | children.style.display = 'block'; | ||
756 | }; | ||
757 | li.onmouseout = function() { | ||
758 | children.style.display = 'none'; | ||
759 | }; | ||
760 | children.style.display = 'none'; | ||
761 | } | ||
762 | |||
763 | // Append to parent | ||
764 | ul.appendChild(li); | ||
765 | |||
766 | // Apply hover | ||
767 | a.onmouseover = function() { | ||
768 | this.style.backgroundColor = itemStyle.rollOverBackgroundColor; | ||
769 | this.style.color = itemStyle.rollOverColor; | ||
770 | this.style.borderColor = itemStyle.rollOverBorderColor; | ||
771 | }; | ||
772 | a.onmouseout = function() { | ||
773 | this.style.backgroundColor = itemStyle.backgroundColor; | ||
774 | this.style.color = itemStyle.color; | ||
775 | this.style.borderColor = itemStyle.borderColor; | ||
776 | }; | ||
777 | } | ||
778 | lvl++; | ||
779 | |||
780 | if (_this.DEBUG == 10) { | ||
781 | _this.log('MENU', ul); | ||
782 | } // DEBUG | ||
783 | |||
784 | return ul; | ||
785 | } | ||
786 | |||
787 | // Style wrapper; Push into chart div | ||
788 | div.setAttribute('style', 'width:39px; height:28px; position: absolute;top:' + _this.cfg.menuTop + ';right:' + _this.cfg.menuRight + ';bottom:' + _this.cfg.menuBottom + ';left:' + _this.cfg.menuLeft + ';box-shadow:0px 0px 1px 0px rgba(0,0,0,0);'); | ||
789 | div.setAttribute('class', 'amExportButton'); | ||
790 | div.appendChild(createList(_this.cfg.menuItems)); | ||
791 | _this.chart.containerDiv.appendChild(div); | ||
792 | } | ||
793 | }); |
amcharts/exporting/canvg.js
File was created | 1 | /* | |
2 | * canvg.js - Javascript SVG parser and renderer on Canvas | ||
3 | * MIT Licensed | ||
4 | * Gabe Lerner (gabelerner@gmail.com) | ||
5 | * http://code.google.com/p/canvg/ | ||
6 | * | ||
7 | * Requires: rgbcolor.js - http://www.phpied.com/rgb-color-parser-in-javascript/ | ||
8 | */ | ||
9 | (function(){ | ||
10 | // canvg(target, s) | ||
11 | // empty parameters: replace all 'svg' elements on page with 'canvas' elements | ||
12 | // target: canvas element or the id of a canvas element | ||
13 | // s: svg string, url to svg file, or xml document | ||
14 | // opts: optional hash of options | ||
15 | // ignoreMouse: true => ignore mouse events | ||
16 | // ignoreAnimation: true => ignore animations | ||
17 | // ignoreDimensions: true => does not try to resize canvas | ||
18 | // ignoreClear: true => does not clear canvas | ||
19 | // offsetX: int => draws at a x offset | ||
20 | // offsetY: int => draws at a y offset | ||
21 | // scaleWidth: int => scales horizontally to width | ||
22 | // scaleHeight: int => scales vertically to height | ||
23 | // renderCallback: function => will call the function after the first render is completed | ||
24 | // forceRedraw: function => will call the function on every frame, if it returns true, will redraw | ||
25 | this.canvg = function (target, s, opts) { | ||
26 | // no parameters | ||
27 | if (target == null && s == null && opts == null) { | ||
28 | var svgTags = document.getElementsByTagName('svg'); | ||
29 | for (var i=0; i<svgTags.length; i++) { | ||
30 | var svgTag = svgTags[i]; | ||
31 | var c = document.createElement('canvas'); | ||
32 | c.width = svgTag.clientWidth; | ||
33 | c.height = svgTag.clientHeight; | ||
34 | svgTag.parentNode.insertBefore(c, svgTag); | ||
35 | svgTag.parentNode.removeChild(svgTag); | ||
36 | var div = document.createElement('div'); | ||
37 | div.appendChild(svgTag); | ||
38 | canvg(c, div.innerHTML); | ||
39 | } | ||
40 | return; | ||
41 | } | ||
42 | opts = opts || {}; | ||
43 | |||
44 | if (typeof target == 'string') { | ||
45 | target = document.getElementById(target); | ||
46 | } | ||
47 | |||
48 | // store class on canvas | ||
49 | if (target.svg != null) target.svg.stop(); | ||
50 | var svg = build(); | ||
51 | // on i.e. 8 for flash canvas, we can't assign the property so check for it | ||
52 | if (!(target.childNodes.length == 1 && target.childNodes[0].nodeName == 'OBJECT')) target.svg = svg; | ||
53 | svg.opts = opts; | ||
54 | |||
55 | var ctx = target.getContext('2d'); | ||
56 | if (typeof(s.documentElement) != 'undefined') { | ||
57 | // load from xml doc | ||
58 | svg.loadXmlDoc(ctx, s); | ||
59 | } | ||
60 | else if (s.substr(0,1) == '<') { | ||
61 | // load from xml string | ||
62 | svg.loadXml(ctx, s); | ||
63 | } | ||
64 | else { | ||
65 | // load from url | ||
66 | svg.load(ctx, s); | ||
67 | } | ||
68 | } | ||
69 | |||
70 | function build() { | ||
71 | var svg = { }; | ||
72 | |||
73 | svg.FRAMERATE = 30; | ||
74 | svg.MAX_VIRTUAL_PIXELS = 30000; | ||
75 | |||
76 | // globals | ||
77 | svg.init = function(ctx) { | ||
78 | var uniqueId = 0; | ||
79 | svg.UniqueId = function () { uniqueId++; return 'canvg' + uniqueId; }; | ||
80 | svg.Definitions = {}; | ||
81 | svg.Styles = {}; | ||
82 | svg.Animations = []; | ||
83 | svg.Images = []; | ||
84 | svg.ctx = ctx; | ||
85 | svg.ViewPort = new (function () { | ||
86 | this.viewPorts = []; | ||
87 | this.Clear = function() { this.viewPorts = []; } | ||
88 | this.SetCurrent = function(width, height) { this.viewPorts.push({ width: width, height: height }); } | ||
89 | this.RemoveCurrent = function() { this.viewPorts.pop(); } | ||
90 | this.Current = function() { return this.viewPorts[this.viewPorts.length - 1]; } | ||
91 | this.width = function() { return this.Current().width; } | ||
92 | this.height = function() { return this.Current().height; } | ||
93 | this.ComputeSize = function(d) { | ||
94 | if (d != null && typeof(d) == 'number') return d; | ||
95 | if (d == 'x') return this.width(); | ||
96 | if (d == 'y') return this.height(); | ||
97 | return Math.sqrt(Math.pow(this.width(), 2) + Math.pow(this.height(), 2)) / Math.sqrt(2); | ||
98 | } | ||
99 | }); | ||
100 | } | ||
101 | svg.init(); | ||
102 | |||
103 | // images loaded | ||
104 | svg.ImagesLoaded = function() { | ||
105 | for (var i=0; i<svg.Images.length; i++) { | ||
106 | if (!svg.Images[i].loaded) return false; | ||
107 | } | ||
108 | return true; | ||
109 | } | ||
110 | |||
111 | // trim | ||
112 | svg.trim = function(s) { return s.replace(/^\s+|\s+$/g, ''); } | ||
113 | |||
114 | // compress spaces | ||
115 | svg.compressSpaces = function(s) { return s.replace(/[\s\r\t\n]+/gm,' '); } | ||
116 | |||
117 | // ajax | ||
118 | svg.ajax = function(url) { | ||
119 | var AJAX; | ||
120 | if(window.XMLHttpRequest){AJAX=new XMLHttpRequest();} | ||
121 | else{AJAX=new ActiveXObject('Microsoft.XMLHTTP');} | ||
122 | if(AJAX){ | ||
123 | AJAX.open('GET',url,false); | ||
124 | AJAX.send(null); | ||
125 | return AJAX.responseText; | ||
126 | } | ||
127 | return null; | ||
128 | } | ||
129 | |||
130 | // parse xml | ||
131 | |||
132 | svg.parseXml = function(xml) { | ||
133 | if (window.DOMParser) | ||
134 | { | ||
135 | var parser = new DOMParser(); | ||
136 | return parser.parseFromString(xml, 'text/xml'); | ||
137 | } | ||
138 | else | ||
139 | { | ||
140 | xml = xml.replace(/<!DOCTYPE svg[^>]*>/, ''); | ||
141 | var xmlDoc = new ActiveXObject('Microsoft.XMLDOM'); | ||
142 | xmlDoc.async = 'false'; | ||
143 | xmlDoc.loadXML(xml); | ||
144 | return xmlDoc; | ||
145 | } | ||
146 | } | ||
147 | |||
148 | svg.Property = function(name, value) { | ||
149 | this.name = name; | ||
150 | this.value = value; | ||
151 | } | ||
152 | svg.Property.prototype.getValue = function() { | ||
153 | return this.value; | ||
154 | } | ||
155 | |||
156 | svg.Property.prototype.hasValue = function() { | ||
157 | return (this.value != null && this.value !== ''); | ||
158 | } | ||
159 | |||
160 | // return the numerical value of the property | ||
161 | svg.Property.prototype.numValue = function() { | ||
162 | if (!this.hasValue()) return 0; | ||
163 | |||
164 | var n = parseFloat(this.value); | ||
165 | if ((this.value + '').match(/%$/)) { | ||
166 | n = n / 100.0; | ||
167 | } | ||
168 | return n; | ||
169 | } | ||
170 | |||
171 | svg.Property.prototype.valueOrDefault = function(def) { | ||
172 | if (this.hasValue()) return this.value; | ||
173 | return def; | ||
174 | } | ||
175 | |||
176 | svg.Property.prototype.numValueOrDefault = function(def) { | ||
177 | if (this.hasValue()) return this.numValue(); | ||
178 | return def; | ||
179 | } | ||
180 | |||
181 | // color extensions | ||
182 | // augment the current color value with the opacity | ||
183 | svg.Property.prototype.addOpacity = function(opacity) { | ||
184 | var newValue = this.value; | ||
185 | if (opacity != null && opacity != '' && typeof(this.value)=='string') { // can only add opacity to colors, not patterns | ||
186 | var color = new RGBColor(this.value); | ||
187 | if (color.ok) { | ||
188 | newValue = 'rgba(' + color.r + ', ' + color.g + ', ' + color.b + ', ' + opacity + ')'; | ||
189 | } | ||
190 | } | ||
191 | return new svg.Property(this.name, newValue); | ||
192 | } | ||
193 | |||
194 | // definition extensions | ||
195 | // get the definition from the definitions table | ||
196 | svg.Property.prototype.getDefinition = function() { | ||
197 | var name = this.value.match(/#([^\)'"]+)/); | ||
198 | if (name) { name = name[1]; } | ||
199 | if (!name) { name = this.value; } | ||
200 | return svg.Definitions[name]; | ||
201 | } | ||
202 | |||
203 | svg.Property.prototype.isUrlDefinition = function() { | ||
204 | return this.value.indexOf('url(') == 0 | ||
205 | } | ||
206 | |||
207 | svg.Property.prototype.getFillStyleDefinition = function(e, opacityProp) { | ||
208 | var def = this.getDefinition(); | ||
209 | |||
210 | // gradient | ||
211 | if (def != null && def.createGradient) { | ||
212 | return def.createGradient(svg.ctx, e, opacityProp); | ||
213 | } | ||
214 | |||
215 | // pattern | ||
216 | if (def != null && def.createPattern) { | ||
217 | if (def.getHrefAttribute().hasValue()) { | ||
218 | var pt = def.attribute('patternTransform'); | ||
219 | def = def.getHrefAttribute().getDefinition(); | ||
220 | if (pt.hasValue()) { def.attribute('patternTransform', true).value = pt.value; } | ||
221 | } | ||
222 | return def.createPattern(svg.ctx, e); | ||
223 | } | ||
224 | |||
225 | return null; | ||
226 | } | ||
227 | |||
228 | // length extensions | ||
229 | svg.Property.prototype.getDPI = function(viewPort) { | ||
230 | return 96.0; // TODO: compute? | ||
231 | } | ||
232 | |||
233 | svg.Property.prototype.getEM = function(viewPort) { | ||
234 | var em = 12; | ||
235 | |||
236 | var fontSize = new svg.Property('fontSize', svg.Font.Parse(svg.ctx.font).fontSize); | ||
237 | if (fontSize.hasValue()) em = fontSize.toPixels(viewPort); | ||
238 | |||
239 | return em; | ||
240 | } | ||
241 | |||
242 | svg.Property.prototype.getUnits = function() { | ||
243 | var s = this.value+''; | ||
244 | return s.replace(/[0-9\.\-]/g,''); | ||
245 | } | ||
246 | |||
247 | // get the length as pixels | ||
248 | svg.Property.prototype.toPixels = function(viewPort, processPercent) { | ||
249 | if (!this.hasValue()) return 0; | ||
250 | var s = this.value+''; | ||
251 | if (s.match(/em$/)) return this.numValue() * this.getEM(viewPort); | ||
252 | if (s.match(/ex$/)) return this.numValue() * this.getEM(viewPort) / 2.0; | ||
253 | if (s.match(/px$/)) return this.numValue(); | ||
254 | if (s.match(/pt$/)) return this.numValue() * this.getDPI(viewPort) * (1.0 / 72.0); | ||
255 | if (s.match(/pc$/)) return this.numValue() * 15; | ||
256 | if (s.match(/cm$/)) return this.numValue() * this.getDPI(viewPort) / 2.54; | ||
257 | if (s.match(/mm$/)) return this.numValue() * this.getDPI(viewPort) / 25.4; | ||
258 | if (s.match(/in$/)) return this.numValue() * this.getDPI(viewPort); | ||
259 | if (s.match(/%$/)) return this.numValue() * svg.ViewPort.ComputeSize(viewPort); | ||
260 | var n = this.numValue(); | ||
261 | if (processPercent && n < 1.0) return n * svg.ViewPort.ComputeSize(viewPort); | ||
262 | return n; | ||
263 | } | ||
264 | |||
265 | // time extensions | ||
266 | // get the time as milliseconds | ||
267 | svg.Property.prototype.toMilliseconds = function() { | ||
268 | if (!this.hasValue()) return 0; | ||
269 | var s = this.value+''; | ||
270 | if (s.match(/s$/)) return this.numValue() * 1000; | ||
271 | if (s.match(/ms$/)) return this.numValue(); | ||
272 | return this.numValue(); | ||
273 | } | ||
274 | |||
275 | // angle extensions | ||
276 | // get the angle as radians | ||
277 | svg.Property.prototype.toRadians = function() { | ||
278 | if (!this.hasValue()) return 0; | ||
279 | var s = this.value+''; | ||
280 | if (s.match(/deg$/)) return this.numValue() * (Math.PI / 180.0); | ||
281 | if (s.match(/grad$/)) return this.numValue() * (Math.PI / 200.0); | ||
282 | if (s.match(/rad$/)) return this.numValue(); | ||
283 | return this.numValue() * (Math.PI / 180.0); | ||
284 | } | ||
285 | |||
286 | // fonts | ||
287 | svg.Font = new (function() { | ||
288 | this.Styles = 'normal|italic|oblique|inherit'; | ||
289 | this.Variants = 'normal|small-caps|inherit'; | ||
290 | this.Weights = 'normal|bold|bolder|lighter|100|200|300|400|500|600|700|800|900|inherit'; | ||
291 | |||
292 | this.CreateFont = function(fontStyle, fontVariant, fontWeight, fontSize, fontFamily, inherit) { | ||
293 | var f = inherit != null ? this.Parse(inherit) : this.CreateFont('', '', '', '', '', svg.ctx.font); | ||
294 | return { | ||
295 | fontFamily: fontFamily || f.fontFamily, | ||
296 | fontSize: fontSize || f.fontSize, | ||
297 | fontStyle: fontStyle || f.fontStyle, | ||
298 | fontWeight: fontWeight || f.fontWeight, | ||
299 | fontVariant: fontVariant || f.fontVariant, | ||
300 | toString: function () { return [this.fontStyle, this.fontVariant, this.fontWeight, this.fontSize, this.fontFamily].join(' ') } | ||
301 | } | ||
302 | } | ||
303 | |||
304 | var that = this; | ||
305 | this.Parse = function(s) { | ||
306 | var f = {}; | ||
307 | var d = svg.trim(svg.compressSpaces(s || '')).split(' '); | ||
308 | var set = { fontSize: false, fontStyle: false, fontWeight: false, fontVariant: false } | ||
309 | var ff = ''; | ||
310 | for (var i=0; i<d.length; i++) { | ||
311 | if (!set.fontStyle && that.Styles.indexOf(d[i]) != -1) { if (d[i] != 'inherit') f.fontStyle = d[i]; set.fontStyle = true; } | ||
312 | else if (!set.fontVariant && that.Variants.indexOf(d[i]) != -1) { if (d[i] != 'inherit') f.fontVariant = d[i]; set.fontStyle = set.fontVariant = true; } | ||
313 | else if (!set.fontWeight && that.Weights.indexOf(d[i]) != -1) { if (d[i] != 'inherit') f.fontWeight = d[i]; set.fontStyle = set.fontVariant = set.fontWeight = true; } | ||
314 | else if (!set.fontSize) { if (d[i] != 'inherit') f.fontSize = d[i].split('/')[0]; set.fontStyle = set.fontVariant = set.fontWeight = set.fontSize = true; } | ||
315 | else { if (d[i] != 'inherit') ff += d[i]; } | ||
316 | } if (ff != '') f.fontFamily = ff; | ||
317 | return f; | ||
318 | } | ||
319 | }); | ||
320 | |||
321 | // points and paths | ||
322 | svg.ToNumberArray = function(s) { | ||
323 | var a = svg.trim(svg.compressSpaces((s || '').replace(/,/g, ' '))).split(' '); | ||
324 | for (var i=0; i<a.length; i++) { | ||
325 | a[i] = parseFloat(a[i]); | ||
326 | } | ||
327 | return a; | ||
328 | } | ||
329 | svg.Point = function(x, y) { | ||
330 | this.x = x; | ||
331 | this.y = y; | ||
332 | } | ||
333 | svg.Point.prototype.angleTo = function(p) { | ||
334 | return Math.atan2(p.y - this.y, p.x - this.x); | ||
335 | } | ||
336 | |||
337 | svg.Point.prototype.applyTransform = function(v) { | ||
338 | var xp = this.x * v[0] + this.y * v[2] + v[4]; | ||
339 | var yp = this.x * v[1] + this.y * v[3] + v[5]; | ||
340 | this.x = xp; | ||
341 | this.y = yp; | ||
342 | } | ||
343 | |||
344 | svg.CreatePoint = function(s) { | ||
345 | var a = svg.ToNumberArray(s); | ||
346 | return new svg.Point(a[0], a[1]); | ||
347 | } | ||
348 | svg.CreatePath = function(s) { | ||
349 | var a = svg.ToNumberArray(s); | ||
350 | var path = []; | ||
351 | for (var i=0; i<a.length; i+=2) { | ||
352 | path.push(new svg.Point(a[i], a[i+1])); | ||
353 | } | ||
354 | return path; | ||
355 | } | ||
356 | |||
357 | // bounding box | ||
358 | svg.BoundingBox = function(x1, y1, x2, y2) { // pass in initial points if you want | ||
359 | this.x1 = Number.NaN; | ||
360 | this.y1 = Number.NaN; | ||
361 | this.x2 = Number.NaN; | ||
362 | this.y2 = Number.NaN; | ||
363 | |||
364 | this.x = function() { return this.x1; } | ||
365 | this.y = function() { return this.y1; } | ||
366 | this.width = function() { return this.x2 - this.x1; } | ||
367 | this.height = function() { return this.y2 - this.y1; } | ||
368 | |||
369 | this.addPoint = function(x, y) { | ||
370 | if (x != null) { | ||
371 | if (isNaN(this.x1) || isNaN(this.x2)) { | ||
372 | this.x1 = x; | ||
373 | this.x2 = x; | ||
374 | } | ||
375 | if (x < this.x1) this.x1 = x; | ||
376 | if (x > this.x2) this.x2 = x; | ||
377 | } | ||
378 | |||
379 | if (y != null) { | ||
380 | if (isNaN(this.y1) || isNaN(this.y2)) { | ||
381 | this.y1 = y; | ||
382 | this.y2 = y; | ||
383 | } | ||
384 | if (y < this.y1) this.y1 = y; | ||
385 | if (y > this.y2) this.y2 = y; | ||
386 | } | ||
387 | } | ||
388 | this.addX = function(x) { this.addPoint(x, null); } | ||
389 | this.addY = function(y) { this.addPoint(null, y); } | ||
390 | |||
391 | this.addBoundingBox = function(bb) { | ||
392 | this.addPoint(bb.x1, bb.y1); | ||
393 | this.addPoint(bb.x2, bb.y2); | ||
394 | } | ||
395 | |||
396 | this.addQuadraticCurve = function(p0x, p0y, p1x, p1y, p2x, p2y) { | ||
397 | var cp1x = p0x + 2/3 * (p1x - p0x); // CP1 = QP0 + 2/3 *(QP1-QP0) | ||
398 | var cp1y = p0y + 2/3 * (p1y - p0y); // CP1 = QP0 + 2/3 *(QP1-QP0) | ||
399 | var cp2x = cp1x + 1/3 * (p2x - p0x); // CP2 = CP1 + 1/3 *(QP2-QP0) | ||
400 | var cp2y = cp1y + 1/3 * (p2y - p0y); // CP2 = CP1 + 1/3 *(QP2-QP0) | ||
401 | this.addBezierCurve(p0x, p0y, cp1x, cp2x, cp1y, cp2y, p2x, p2y); | ||
402 | } | ||
403 | |||
404 | this.addBezierCurve = function(p0x, p0y, p1x, p1y, p2x, p2y, p3x, p3y) { | ||
405 | // from http://blog.hackers-cafe.net/2009/06/how-to-calculate-bezier-curves-bounding.html | ||
406 | var p0 = [p0x, p0y], p1 = [p1x, p1y], p2 = [p2x, p2y], p3 = [p3x, p3y]; | ||
407 | this.addPoint(p0[0], p0[1]); | ||
408 | this.addPoint(p3[0], p3[1]); | ||
409 | |||
410 | for (i=0; i<=1; i++) { | ||
411 | var f = function(t) { | ||
412 | return Math.pow(1-t, 3) * p0[i] | ||
413 | + 3 * Math.pow(1-t, 2) * t * p1[i] | ||
414 | + 3 * (1-t) * Math.pow(t, 2) * p2[i] | ||
415 | + Math.pow(t, 3) * p3[i]; | ||
416 | } | ||
417 | |||
418 | var b = 6 * p0[i] - 12 * p1[i] + 6 * p2[i]; | ||
419 | var a = -3 * p0[i] + 9 * p1[i] - 9 * p2[i] + 3 * p3[i]; | ||
420 | var c = 3 * p1[i] - 3 * p0[i]; | ||
421 | |||
422 | if (a == 0) { | ||
423 | if (b == 0) continue; | ||
424 | var t = -c / b; | ||
425 | if (0 < t && t < 1) { | ||
426 | if (i == 0) this.addX(f(t)); | ||
427 | if (i == 1) this.addY(f(t)); | ||
428 | } | ||
429 | continue; | ||
430 | } | ||
431 | |||
432 | var b2ac = Math.pow(b, 2) - 4 * c * a; | ||
433 | if (b2ac < 0) continue; | ||
434 | var t1 = (-b + Math.sqrt(b2ac)) / (2 * a); | ||
435 | if (0 < t1 && t1 < 1) { | ||
436 | if (i == 0) this.addX(f(t1)); | ||
437 | if (i == 1) this.addY(f(t1)); | ||
438 | } | ||
439 | var t2 = (-b - Math.sqrt(b2ac)) / (2 * a); | ||
440 | if (0 < t2 && t2 < 1) { | ||
441 | if (i == 0) this.addX(f(t2)); | ||
442 | if (i == 1) this.addY(f(t2)); | ||
443 | } | ||
444 | } | ||
445 | } | ||
446 | |||
447 | this.isPointInBox = function(x, y) { | ||
448 | return (this.x1 <= x && x <= this.x2 && this.y1 <= y && y <= this.y2); | ||
449 | } | ||
450 | |||
451 | this.addPoint(x1, y1); | ||
452 | this.addPoint(x2, y2); | ||
453 | } | ||
454 | |||
455 | // transforms | ||
456 | svg.Transform = function(v) { | ||
457 | var that = this; | ||
458 | this.Type = {} | ||
459 | |||
460 | // translate | ||
461 | this.Type.translate = function(s) { | ||
462 | this.p = svg.CreatePoint(s); | ||
463 | this.apply = function(ctx) { | ||
464 | ctx.translate(this.p.x || 0.0, this.p.y || 0.0); | ||
465 | } | ||
466 | this.unapply = function(ctx) { | ||
467 | ctx.translate(-1.0 * this.p.x || 0.0, -1.0 * this.p.y || 0.0); | ||
468 | } | ||
469 | this.applyToPoint = function(p) { | ||
470 | p.applyTransform([1, 0, 0, 1, this.p.x || 0.0, this.p.y || 0.0]); | ||
471 | } | ||
472 | } | ||
473 | |||
474 | // rotate | ||
475 | this.Type.rotate = function(s) { | ||
476 | var a = svg.ToNumberArray(s); | ||
477 | this.angle = new svg.Property('angle', a[0]); | ||
478 | this.cx = a[1] || 0; | ||
479 | this.cy = a[2] || 0; | ||
480 | this.apply = function(ctx) { | ||
481 | ctx.translate(this.cx, this.cy); | ||
482 | ctx.rotate(this.angle.toRadians()); | ||
483 | ctx.translate(-this.cx, -this.cy); | ||
484 | } | ||
485 | this.unapply = function(ctx) { | ||
486 | ctx.translate(this.cx, this.cy); | ||
487 | ctx.rotate(-1.0 * this.angle.toRadians()); | ||
488 | ctx.translate(-this.cx, -this.cy); | ||
489 | } | ||
490 | this.applyToPoint = function(p) { | ||
491 | var a = this.angle.toRadians(); | ||
492 | p.applyTransform([1, 0, 0, 1, this.p.x || 0.0, this.p.y || 0.0]); | ||
493 | p.applyTransform([Math.cos(a), Math.sin(a), -Math.sin(a), Math.cos(a), 0, 0]); | ||
494 | p.applyTransform([1, 0, 0, 1, -this.p.x || 0.0, -this.p.y || 0.0]); | ||
495 | } | ||
496 | } | ||
497 | |||
498 | this.Type.scale = function(s) { | ||
499 | this.p = svg.CreatePoint(s); | ||
500 | this.apply = function(ctx) { | ||
501 | ctx.scale(this.p.x || 1.0, this.p.y || this.p.x || 1.0); | ||
502 | } | ||
503 | this.unapply = function(ctx) { | ||
504 | ctx.scale(1.0 / this.p.x || 1.0, 1.0 / this.p.y || this.p.x || 1.0); | ||
505 | } | ||
506 | this.applyToPoint = function(p) { | ||
507 | p.applyTransform([this.p.x || 0.0, 0, 0, this.p.y || 0.0, 0, 0]); | ||
508 | } | ||
509 | } | ||
510 | |||
511 | this.Type.matrix = function(s) { | ||
512 | this.m = svg.ToNumberArray(s); | ||
513 | this.apply = function(ctx) { | ||
514 | ctx.transform(this.m[0], this.m[1], this.m[2], this.m[3], this.m[4], this.m[5]); | ||
515 | } | ||
516 | this.applyToPoint = function(p) { | ||
517 | p.applyTransform(this.m); | ||
518 | } | ||
519 | } | ||
520 | |||
521 | this.Type.SkewBase = function(s) { | ||
522 | this.base = that.Type.matrix; | ||
523 | this.base(s); | ||
524 | this.angle = new svg.Property('angle', s); | ||
525 | } | ||
526 | this.Type.SkewBase.prototype = new this.Type.matrix; | ||
527 | |||
528 | this.Type.skewX = function(s) { | ||
529 | this.base = that.Type.SkewBase; | ||
530 | this.base(s); | ||
531 | this.m = [1, 0, Math.tan(this.angle.toRadians()), 1, 0, 0]; | ||
532 | } | ||
533 | this.Type.skewX.prototype = new this.Type.SkewBase; | ||
534 | |||
535 | this.Type.skewY = function(s) { | ||
536 | this.base = that.Type.SkewBase; | ||
537 | this.base(s); | ||
538 | this.m = [1, Math.tan(this.angle.toRadians()), 0, 1, 0, 0]; | ||
539 | } | ||
540 | this.Type.skewY.prototype = new this.Type.SkewBase; | ||
541 | |||
542 | this.transforms = []; | ||
543 | |||
544 | this.apply = function(ctx) { | ||
545 | for (var i=0; i<this.transforms.length; i++) { | ||
546 | this.transforms[i].apply(ctx); | ||
547 | } | ||
548 | } | ||
549 | |||
550 | this.unapply = function(ctx) { | ||
551 | for (var i=this.transforms.length-1; i>=0; i--) { | ||
552 | this.transforms[i].unapply(ctx); | ||
553 | } | ||
554 | } | ||
555 | |||
556 | this.applyToPoint = function(p) { | ||
557 | for (var i=0; i<this.transforms.length; i++) { | ||
558 | this.transforms[i].applyToPoint(p); | ||
559 | } | ||
560 | } | ||
561 | |||
562 | var data = svg.trim(svg.compressSpaces(v)).replace(/\)(\s?,\s?)/g,') ').split(/\s(?=[a-z])/); | ||
563 | for (var i=0; i<data.length; i++) { | ||
564 | var type = svg.trim(data[i].split('(')[0]); | ||
565 | var s = data[i].split('(')[1].replace(')',''); | ||
566 | var transform = new this.Type[type](s); | ||
567 | transform.type = type; | ||
568 | this.transforms.push(transform); | ||
569 | } | ||
570 | } | ||
571 | |||
572 | // aspect ratio | ||
573 | svg.AspectRatio = function(ctx, aspectRatio, width, desiredWidth, height, desiredHeight, minX, minY, refX, refY) { | ||
574 | // aspect ratio - http://www.w3.org/TR/SVG/coords.html#PreserveAspectRatioAttribute | ||
575 | aspectRatio = svg.compressSpaces(aspectRatio); | ||
576 | aspectRatio = aspectRatio.replace(/^defer\s/,''); // ignore defer | ||
577 | var align = aspectRatio.split(' ')[0] || 'xMidYMid'; | ||
578 | var meetOrSlice = aspectRatio.split(' ')[1] || 'meet'; | ||
579 | |||
580 | // calculate scale | ||
581 | var scaleX = width / desiredWidth; | ||
582 | var scaleY = height / desiredHeight; | ||
583 | var scaleMin = Math.min(scaleX, scaleY); | ||
584 | var scaleMax = Math.max(scaleX, scaleY); | ||
585 | if (meetOrSlice == 'meet') { desiredWidth *= scaleMin; desiredHeight *= scaleMin; } | ||
586 | if (meetOrSlice == 'slice') { desiredWidth *= scaleMax; desiredHeight *= scaleMax; } | ||
587 | |||
588 | refX = new svg.Property('refX', refX); | ||
589 | refY = new svg.Property('refY', refY); | ||
590 | if (refX.hasValue() && refY.hasValue()) { | ||
591 | ctx.translate(-scaleMin * refX.toPixels('x'), -scaleMin * refY.toPixels('y')); | ||
592 | } | ||
593 | else { | ||
594 | // align | ||
595 | if (align.match(/^xMid/) && ((meetOrSlice == 'meet' && scaleMin == scaleY) || (meetOrSlice == 'slice' && scaleMax == scaleY))) ctx.translate(width / 2.0 - desiredWidth / 2.0, 0); | ||
596 | if (align.match(/YMid$/) && ((meetOrSlice == 'meet' && scaleMin == scaleX) || (meetOrSlice == 'slice' && scaleMax == scaleX))) ctx.translate(0, height / 2.0 - desiredHeight / 2.0); | ||
597 | if (align.match(/^xMax/) && ((meetOrSlice == 'meet' && scaleMin == scaleY) || (meetOrSlice == 'slice' && scaleMax == scaleY))) ctx.translate(width - desiredWidth, 0); | ||
598 | if (align.match(/YMax$/) && ((meetOrSlice == 'meet' && scaleMin == scaleX) || (meetOrSlice == 'slice' && scaleMax == scaleX))) ctx.translate(0, height - desiredHeight); | ||
599 | } | ||
600 | |||
601 | // scale | ||
602 | if (align == 'none') ctx.scale(scaleX, scaleY); | ||
603 | else if (meetOrSlice == 'meet') ctx.scale(scaleMin, scaleMin); | ||
604 | else if (meetOrSlice == 'slice') ctx.scale(scaleMax, scaleMax); | ||
605 | |||
606 | // translate | ||
607 | ctx.translate(minX == null ? 0 : -minX, minY == null ? 0 : -minY); | ||
608 | } | ||
609 | |||
610 | // elements | ||
611 | svg.Element = {} | ||
612 | |||
613 | svg.EmptyProperty = new svg.Property('EMPTY', ''); | ||
614 | |||
615 | svg.Element.ElementBase = function(node) { | ||
616 | this.attributes = {}; | ||
617 | this.styles = {}; | ||
618 | this.children = []; | ||
619 | |||
620 | // get or create attribute | ||
621 | this.attribute = function(name, createIfNotExists) { | ||
622 | var a = this.attributes[name]; | ||
623 | if (a != null) return a; | ||
624 | |||
625 | if (createIfNotExists == true) { a = new svg.Property(name, ''); this.attributes[name] = a; } | ||
626 | return a || svg.EmptyProperty; | ||
627 | } | ||
628 | |||
629 | this.getHrefAttribute = function() { | ||
630 | for (var a in this.attributes) { | ||
631 | if (a.match(/:href$/)) { | ||
632 | return this.attributes[a]; | ||
633 | } | ||
634 | } | ||
635 | return svg.EmptyProperty; | ||
636 | } | ||
637 | |||
638 | // get or create style, crawls up node tree | ||
639 | this.style = function(name, createIfNotExists) { | ||
640 | var s = this.styles[name]; | ||
641 | if (s != null) return s; | ||
642 | |||
643 | var a = this.attribute(name); | ||
644 | if (a != null && a.hasValue()) { | ||
645 | this.styles[name] = a; // move up to me to cache | ||
646 | return a; | ||
647 | } | ||
648 | |||
649 | var p = this.parent; | ||
650 | if (p != null) { | ||
651 | var ps = p.style(name); | ||
652 | if (ps != null && ps.hasValue()) { | ||
653 | return ps; | ||
654 | } | ||
655 | } | ||
656 | |||
657 | if (createIfNotExists == true) { s = new svg.Property(name, ''); this.styles[name] = s; } | ||
658 | return s || svg.EmptyProperty; | ||
659 | } | ||
660 | |||
661 | // base render | ||
662 | this.render = function(ctx) { | ||
663 | // don't render display=none | ||
664 | if (this.style('display').value == 'none') return; | ||
665 | |||
666 | // don't render visibility=hidden | ||
667 | if (this.attribute('visibility').value == 'hidden') return; | ||
668 | |||
669 | ctx.save(); | ||
670 | if (this.attribute('mask').hasValue()) { // mask | ||
671 | var mask = this.attribute('mask').getDefinition(); | ||
672 | if (mask != null) mask.apply(ctx, this); | ||
673 | } | ||
674 | else if (this.style('filter').hasValue()) { // filter | ||
675 | var filter = this.style('filter').getDefinition(); | ||
676 | if (filter != null) filter.apply(ctx, this); | ||
677 | } | ||
678 | else { | ||
679 | this.setContext(ctx); | ||
680 | this.renderChildren(ctx); | ||
681 | this.clearContext(ctx); | ||
682 | } | ||
683 | ctx.restore(); | ||
684 | } | ||
685 | |||
686 | // base set context | ||
687 | this.setContext = function(ctx) { | ||
688 | // OVERRIDE ME! | ||
689 | } | ||
690 | |||
691 | // base clear context | ||
692 | this.clearContext = function(ctx) { | ||
693 | // OVERRIDE ME! | ||
694 | } | ||
695 | |||
696 | // base render children | ||
697 | this.renderChildren = function(ctx) { | ||
698 | for (var i=0; i<this.children.length; i++) { | ||
699 | this.children[i].render(ctx); | ||
700 | } | ||
701 | } | ||
702 | |||
703 | this.addChild = function(childNode, create) { | ||
704 | var child = childNode; | ||
705 | if (create) child = svg.CreateElement(childNode); | ||
706 | child.parent = this; | ||
707 | this.children.push(child); | ||
708 | } | ||
709 | |||
710 | if (node != null && node.nodeType == 1) { //ELEMENT_NODE | ||
711 | // add children | ||
712 | for (var i=0; i<node.childNodes.length; i++) { | ||
713 | var childNode = node.childNodes[i]; | ||
714 | if (childNode.nodeType == 1) this.addChild(childNode, true); //ELEMENT_NODE | ||
715 | if (this.captureTextNodes && childNode.nodeType == 3) { | ||
716 | var text = childNode.nodeValue || childNode.text || ''; | ||
717 | if (svg.trim(svg.compressSpaces(text)) != '') { | ||
718 | this.addChild(new svg.Element.tspan(childNode), false); // TEXT_NODE | ||
719 | } | ||
720 | } | ||
721 | } | ||
722 | |||
723 | // add attributes | ||
724 | for (var i=0; i<node.attributes.length; i++) { | ||
725 | var attribute = node.attributes[i]; | ||
726 | this.attributes[attribute.nodeName] = new svg.Property(attribute.nodeName, attribute.nodeValue); | ||
727 | } | ||
728 | |||
729 | // add tag styles | ||
730 | var styles = svg.Styles[node.nodeName]; | ||
731 | if (styles != null) { | ||
732 | for (var name in styles) { | ||
733 | this.styles[name] = styles[name]; | ||
734 | } | ||
735 | } | ||
736 | |||
737 | // add class styles | ||
738 | if (this.attribute('class').hasValue()) { | ||
739 | var classes = svg.compressSpaces(this.attribute('class').value).split(' '); | ||
740 | for (var j=0; j<classes.length; j++) { | ||
741 | styles = svg.Styles['.'+classes[j]]; | ||
742 | if (styles != null) { | ||
743 | for (var name in styles) { | ||
744 | this.styles[name] = styles[name]; | ||
745 | } | ||
746 | } | ||
747 | styles = svg.Styles[node.nodeName+'.'+classes[j]]; | ||
748 | if (styles != null) { | ||
749 | for (var name in styles) { | ||
750 | this.styles[name] = styles[name]; | ||
751 | } | ||
752 | } | ||
753 | } | ||
754 | } | ||
755 | |||
756 | // add id styles | ||
757 | if (this.attribute('id').hasValue()) { | ||
758 | var styles = svg.Styles['#' + this.attribute('id').value]; | ||
759 | if (styles != null) { | ||
760 | for (var name in styles) { | ||
761 | this.styles[name] = styles[name]; | ||
762 | } | ||
763 | } | ||
764 | } | ||
765 | |||
766 | // add inline styles | ||
767 | if (this.attribute('style').hasValue()) { | ||
768 | var styles = this.attribute('style').value.split(';'); | ||
769 | for (var i=0; i<styles.length; i++) { | ||
770 | if (svg.trim(styles[i]) != '') { | ||
771 | var style = styles[i].split(':'); | ||
772 | var name = svg.trim(style[0]); | ||
773 | var value = svg.trim(style[1]); | ||
774 | this.styles[name] = new svg.Property(name, value); | ||
775 | } | ||
776 | } | ||
777 | } | ||
778 | |||
779 | // add id | ||
780 | if (this.attribute('id').hasValue()) { | ||
781 | if (svg.Definitions[this.attribute('id').value] == null) { | ||
782 | svg.Definitions[this.attribute('id').value] = this; | ||
783 | } | ||
784 | } | ||
785 | } | ||
786 | } | ||
787 | |||
788 | svg.Element.RenderedElementBase = function(node) { | ||
789 | this.base = svg.Element.ElementBase; | ||
790 | this.base(node); | ||
791 | |||
792 | this.setContext = function(ctx) { | ||
793 | // fill | ||
794 | if (this.style('fill').isUrlDefinition()) { | ||
795 | var fs = this.style('fill').getFillStyleDefinition(this, this.style('fill-opacity')); | ||
796 | if (fs != null) ctx.fillStyle = fs; | ||
797 | } | ||
798 | else if (this.style('fill').hasValue()) { | ||
799 | var fillStyle = this.style('fill'); | ||
800 | if (fillStyle.value == 'currentColor') fillStyle.value = this.style('color').value; | ||
801 | ctx.fillStyle = (fillStyle.value == 'none' ? 'rgba(0,0,0,0)' : fillStyle.value); | ||
802 | } | ||
803 | if (this.style('fill-opacity').hasValue()) { | ||
804 | var fillStyle = new svg.Property('fill', ctx.fillStyle); | ||
805 | fillStyle = fillStyle.addOpacity(this.style('fill-opacity').value); | ||
806 | ctx.fillStyle = fillStyle.value; | ||
807 | } | ||
808 | |||
809 | // stroke | ||
810 | if (this.style('stroke').isUrlDefinition()) { | ||
811 | var fs = this.style('stroke').getFillStyleDefinition(this, this.style('stroke-opacity')); | ||
812 | if (fs != null) ctx.strokeStyle = fs; | ||
813 | } | ||
814 | else if (this.style('stroke').hasValue()) { | ||
815 | var strokeStyle = this.style('stroke'); | ||
816 | if (strokeStyle.value == 'currentColor') strokeStyle.value = this.style('color').value; | ||
817 | ctx.strokeStyle = (strokeStyle.value == 'none' ? 'rgba(0,0,0,0)' : strokeStyle.value); | ||
818 | } | ||
819 | if (this.style('stroke-opacity').hasValue()) { | ||
820 | var strokeStyle = new svg.Property('stroke', ctx.strokeStyle); | ||
821 | strokeStyle = strokeStyle.addOpacity(this.style('stroke-opacity').value); | ||
822 | ctx.strokeStyle = strokeStyle.value; | ||
823 | } | ||
824 | if (this.style('stroke-width').hasValue()) { | ||
825 | var newLineWidth = this.style('stroke-width').toPixels(); | ||
826 | ctx.lineWidth = newLineWidth == 0 ? 0.001 : newLineWidth; // browsers don't respect 0 | ||
827 | } | ||
828 | if (this.style('stroke-linecap').hasValue()) ctx.lineCap = this.style('stroke-linecap').value; | ||
829 | if (this.style('stroke-linejoin').hasValue()) ctx.lineJoin = this.style('stroke-linejoin').value; | ||
830 | if (this.style('stroke-miterlimit').hasValue()) ctx.miterLimit = this.style('stroke-miterlimit').value; | ||
831 | if (this.style('stroke-dasharray').hasValue()) { | ||
832 | var gaps = svg.ToNumberArray(this.style('stroke-dasharray').value); | ||
833 | if (typeof(ctx.setLineDash) != 'undefined') { ctx.setLineDash(gaps); } | ||
834 | else if (typeof(ctx.webkitLineDash) != 'undefined') { ctx.webkitLineDash = gaps; } | ||
835 | else if (typeof(ctx.mozDash ) != 'undefined') { ctx.mozDash = gaps; } | ||
836 | |||
837 | var offset = this.style('stroke-dashoffset').numValueOrDefault(1); | ||
838 | if (typeof(ctx.lineDashOffset) != 'undefined') { ctx.lineDashOffset = offset; } | ||
839 | else if (typeof(ctx.webkitLineDashOffset) != 'undefined') { ctx.webkitLineDashOffset = offset; } | ||
840 | else if (typeof(ctx.mozDashOffset) != 'undefined') { ctx.mozDashOffset = offset; } | ||
841 | } | ||
842 | |||
843 | // font | ||
844 | if (typeof(ctx.font) != 'undefined') { | ||
845 | ctx.font = svg.Font.CreateFont( | ||
846 | this.style('font-style').value, | ||
847 | this.style('font-variant').value, | ||
848 | this.style('font-weight').value, | ||
849 | this.style('font-size').hasValue() ? this.style('font-size').toPixels() + 'px' : '', | ||
850 | this.style('font-family').value).toString(); | ||
851 | } | ||
852 | |||
853 | // transform | ||
854 | if (this.attribute('transform').hasValue()) { | ||
855 | var transform = new svg.Transform(this.attribute('transform').value); | ||
856 | transform.apply(ctx); | ||
857 | } | ||
858 | |||
859 | // clip | ||
860 | if (this.style('clip-path').hasValue()) { | ||
861 | var clip = this.style('clip-path').getDefinition(); | ||
862 | if (clip != null) clip.apply(ctx); | ||
863 | } | ||
864 | |||
865 | // opacity | ||
866 | if (this.style('opacity').hasValue()) { | ||
867 | ctx.globalAlpha = this.style('opacity').numValue(); | ||
868 | } | ||
869 | } | ||
870 | } | ||
871 | svg.Element.RenderedElementBase.prototype = new svg.Element.ElementBase; | ||
872 | |||
873 | svg.Element.PathElementBase = function(node) { | ||
874 | this.base = svg.Element.RenderedElementBase; | ||
875 | this.base(node); | ||
876 | |||
877 | this.path = function(ctx) { | ||
878 | if (ctx != null) ctx.beginPath(); | ||
879 | return new svg.BoundingBox(); | ||
880 | } | ||
881 | |||
882 | this.renderChildren = function(ctx) { | ||
883 | this.path(ctx); | ||
884 | svg.Mouse.checkPath(this, ctx); | ||
885 | if (ctx.fillStyle != '') { | ||
886 | if (this.attribute('fill-rule').hasValue()) { ctx.fill(this.attribute('fill-rule').value); } | ||
887 | else { ctx.fill(); } | ||
888 | } | ||
889 | if (ctx.strokeStyle != '') ctx.stroke(); | ||
890 | |||
891 | var markers = this.getMarkers(); | ||
892 | if (markers != null) { | ||
893 | if (this.style('marker-start').isUrlDefinition()) { | ||
894 | var marker = this.style('marker-start').getDefinition(); | ||
895 | marker.render(ctx, markers[0][0], markers[0][1]); | ||
896 | } | ||
897 | if (this.style('marker-mid').isUrlDefinition()) { | ||
898 | var marker = this.style('marker-mid').getDefinition(); | ||
899 | for (var i=1;i<markers.length-1;i++) { | ||
900 | marker.render(ctx, markers[i][0], markers[i][1]); | ||
901 | } | ||
902 | } | ||
903 | if (this.style('marker-end').isUrlDefinition()) { | ||
904 | var marker = this.style('marker-end').getDefinition(); | ||
905 | marker.render(ctx, markers[markers.length-1][0], markers[markers.length-1][1]); | ||
906 | } | ||
907 | } | ||
908 | } | ||
909 | |||
910 | this.getBoundingBox = function() { | ||
911 | return this.path(); | ||
912 | } | ||
913 | |||
914 | this.getMarkers = function() { | ||
915 | return null; | ||
916 | } | ||
917 | } | ||
918 | svg.Element.PathElementBase.prototype = new svg.Element.RenderedElementBase; | ||
919 | |||
920 | // svg element | ||
921 | svg.Element.svg = function(node) { | ||
922 | this.base = svg.Element.RenderedElementBase; | ||
923 | this.base(node); | ||
924 | |||
925 | this.baseClearContext = this.clearContext; | ||
926 | this.clearContext = function(ctx) { | ||
927 | this.baseClearContext(ctx); | ||
928 | svg.ViewPort.RemoveCurrent(); | ||
929 | } | ||
930 | |||
931 | this.baseSetContext = this.setContext; | ||
932 | this.setContext = function(ctx) { | ||
933 | // initial values | ||
934 | ctx.strokeStyle = 'rgba(0,0,0,0)'; | ||
935 | ctx.lineCap = 'butt'; | ||
936 | ctx.lineJoin = 'miter'; | ||
937 | ctx.miterLimit = 4; | ||
938 | |||
939 | this.baseSetContext(ctx); | ||
940 | |||
941 | // create new view port | ||
942 | if (!this.attribute('x').hasValue()) this.attribute('x', true).value = 0; | ||
943 | if (!this.attribute('y').hasValue()) this.attribute('y', true).value = 0; | ||
944 | ctx.translate(this.attribute('x').toPixels('x'), this.attribute('y').toPixels('y')); | ||
945 | |||
946 | var width = svg.ViewPort.width(); | ||
947 | var height = svg.ViewPort.height(); | ||
948 | |||
949 | if (!this.attribute('width').hasValue()) this.attribute('width', true).value = '100%'; | ||
950 | if (!this.attribute('height').hasValue()) this.attribute('height', true).value = '100%'; | ||
951 | if (typeof(this.root) == 'undefined') { | ||
952 | width = this.attribute('width').toPixels('x'); | ||
953 | height = this.attribute('height').toPixels('y'); | ||
954 | |||
955 | var x = 0; | ||
956 | var y = 0; | ||
957 | if (this.attribute('refX').hasValue() && this.attribute('refY').hasValue()) { | ||
958 | x = -this.attribute('refX').toPixels('x'); | ||
959 | y = -this.attribute('refY').toPixels('y'); | ||
960 | } | ||
961 | |||
962 | ctx.beginPath(); | ||
963 | ctx.moveTo(x, y); | ||
964 | ctx.lineTo(width, y); | ||
965 | ctx.lineTo(width, height); | ||
966 | ctx.lineTo(x, height); | ||
967 | ctx.closePath(); | ||
968 | ctx.clip(); | ||
969 | } | ||
970 | svg.ViewPort.SetCurrent(width, height); | ||
971 | |||
972 | // viewbox | ||
973 | if (this.attribute('viewBox').hasValue()) { | ||
974 | var viewBox = svg.ToNumberArray(this.attribute('viewBox').value); | ||
975 | var minX = viewBox[0]; | ||
976 | var minY = viewBox[1]; | ||
977 | width = viewBox[2]; | ||
978 | height = viewBox[3]; | ||
979 | |||
980 | svg.AspectRatio(ctx, | ||
981 | this.attribute('preserveAspectRatio').value, | ||
982 | svg.ViewPort.width(), | ||
983 | width, | ||
984 | svg.ViewPort.height(), | ||
985 | height, | ||
986 | minX, | ||
987 | minY, | ||
988 | this.attribute('refX').value, | ||
989 | this.attribute('refY').value); | ||
990 | |||
991 | svg.ViewPort.RemoveCurrent(); | ||
992 | svg.ViewPort.SetCurrent(viewBox[2], viewBox[3]); | ||
993 | } | ||
994 | } | ||
995 | } | ||
996 | svg.Element.svg.prototype = new svg.Element.RenderedElementBase; | ||
997 | |||
998 | // rect element | ||
999 | svg.Element.rect = function(node) { | ||
1000 | this.base = svg.Element.PathElementBase; | ||
1001 | this.base(node); | ||
1002 | |||
1003 | this.path = function(ctx) { | ||
1004 | var x = this.attribute('x').toPixels('x'); | ||
1005 | var y = this.attribute('y').toPixels('y'); | ||
1006 | var width = this.attribute('width').toPixels('x'); | ||
1007 | var height = this.attribute('height').toPixels('y'); | ||
1008 | var rx = this.attribute('rx').toPixels('x'); | ||
1009 | var ry = this.attribute('ry').toPixels('y'); | ||
1010 | if (this.attribute('rx').hasValue() && !this.attribute('ry').hasValue()) ry = rx; | ||
1011 | if (this.attribute('ry').hasValue() && !this.attribute('rx').hasValue()) rx = ry; | ||
1012 | rx = Math.min(rx, width / 2.0); | ||
1013 | ry = Math.min(ry, height / 2.0); | ||
1014 | if (ctx != null) { | ||
1015 | ctx.beginPath(); | ||
1016 | ctx.moveTo(x + rx, y); | ||
1017 | ctx.lineTo(x + width - rx, y); | ||
1018 | ctx.quadraticCurveTo(x + width, y, x + width, y + ry) | ||
1019 | ctx.lineTo(x + width, y + height - ry); | ||
1020 | ctx.quadraticCurveTo(x + width, y + height, x + width - rx, y + height) | ||
1021 | ctx.lineTo(x + rx, y + height); | ||
1022 | ctx.quadraticCurveTo(x, y + height, x, y + height - ry) | ||
1023 | ctx.lineTo(x, y + ry); | ||
1024 | ctx.quadraticCurveTo(x, y, x + rx, y) | ||
1025 | ctx.closePath(); | ||
1026 | } | ||
1027 | |||
1028 | return new svg.BoundingBox(x, y, x + width, y + height); | ||
1029 | } | ||
1030 | } | ||
1031 | svg.Element.rect.prototype = new svg.Element.PathElementBase; | ||
1032 | |||
1033 | // circle element | ||
1034 | svg.Element.circle = function(node) { | ||
1035 | this.base = svg.Element.PathElementBase; | ||
1036 | this.base(node); | ||
1037 | |||
1038 | this.path = function(ctx) { | ||
1039 | var cx = this.attribute('cx').toPixels('x'); | ||
1040 | var cy = this.attribute('cy').toPixels('y'); | ||
1041 | var r = this.attribute('r').toPixels(); | ||
1042 | |||
1043 | if (ctx != null) { | ||
1044 | ctx.beginPath(); | ||
1045 | ctx.arc(cx, cy, r, 0, Math.PI * 2, true); | ||
1046 | ctx.closePath(); | ||
1047 | } | ||
1048 | |||
1049 | return new svg.BoundingBox(cx - r, cy - r, cx + r, cy + r); | ||
1050 | } | ||
1051 | } | ||
1052 | svg.Element.circle.prototype = new svg.Element.PathElementBase; | ||
1053 | |||
1054 | // ellipse element | ||
1055 | svg.Element.ellipse = function(node) { | ||
1056 | this.base = svg.Element.PathElementBase; | ||
1057 | this.base(node); | ||
1058 | |||
1059 | this.path = function(ctx) { | ||
1060 | var KAPPA = 4 * ((Math.sqrt(2) - 1) / 3); | ||
1061 | var rx = this.attribute('rx').toPixels('x'); | ||
1062 | var ry = this.attribute('ry').toPixels('y'); | ||
1063 | var cx = this.attribute('cx').toPixels('x'); | ||
1064 | var cy = this.attribute('cy').toPixels('y'); | ||
1065 | |||
1066 | if (ctx != null) { | ||
1067 | ctx.beginPath(); | ||
1068 | ctx.moveTo(cx, cy - ry); | ||
1069 | ctx.bezierCurveTo(cx + (KAPPA * rx), cy - ry, cx + rx, cy - (KAPPA * ry), cx + rx, cy); | ||
1070 | ctx.bezierCurveTo(cx + rx, cy + (KAPPA * ry), cx + (KAPPA * rx), cy + ry, cx, cy + ry); | ||
1071 | ctx.bezierCurveTo(cx - (KAPPA * rx), cy + ry, cx - rx, cy + (KAPPA * ry), cx - rx, cy); | ||
1072 | ctx.bezierCurveTo(cx - rx, cy - (KAPPA * ry), cx - (KAPPA * rx), cy - ry, cx, cy - ry); | ||
1073 | ctx.closePath(); | ||
1074 | } | ||
1075 | |||
1076 | return new svg.BoundingBox(cx - rx, cy - ry, cx + rx, cy + ry); | ||
1077 | } | ||
1078 | } | ||
1079 | svg.Element.ellipse.prototype = new svg.Element.PathElementBase; | ||
1080 | |||
1081 | // line element | ||
1082 | svg.Element.line = function(node) { | ||
1083 | this.base = svg.Element.PathElementBase; | ||
1084 | this.base(node); | ||
1085 | |||
1086 | this.getPoints = function() { | ||
1087 | return [ | ||
1088 | new svg.Point(this.attribute('x1').toPixels('x'), this.attribute('y1').toPixels('y')), | ||
1089 | new svg.Point(this.attribute('x2').toPixels('x'), this.attribute('y2').toPixels('y'))]; | ||
1090 | } | ||
1091 | |||
1092 | this.path = function(ctx) { | ||
1093 | var points = this.getPoints(); | ||
1094 | |||
1095 | if (ctx != null) { | ||
1096 | ctx.beginPath(); | ||
1097 | ctx.moveTo(points[0].x, points[0].y); | ||
1098 | ctx.lineTo(points[1].x, points[1].y); | ||
1099 | } | ||
1100 | |||
1101 | return new svg.BoundingBox(points[0].x, points[0].y, points[1].x, points[1].y); | ||
1102 | } | ||
1103 | |||
1104 | this.getMarkers = function() { | ||
1105 | var points = this.getPoints(); | ||
1106 | var a = points[0].angleTo(points[1]); | ||
1107 | return [[points[0], a], [points[1], a]]; | ||
1108 | } | ||
1109 | } | ||
1110 | svg.Element.line.prototype = new svg.Element.PathElementBase; | ||
1111 | |||
1112 | // polyline element | ||
1113 | svg.Element.polyline = function(node) { | ||
1114 | this.base = svg.Element.PathElementBase; | ||
1115 | this.base(node); | ||
1116 | |||
1117 | this.points = svg.CreatePath(this.attribute('points').value); | ||
1118 | this.path = function(ctx) { | ||
1119 | var bb = new svg.BoundingBox(this.points[0].x, this.points[0].y); | ||
1120 | if (ctx != null) { | ||
1121 | ctx.beginPath(); | ||
1122 | ctx.moveTo(this.points[0].x, this.points[0].y); | ||
1123 | } | ||
1124 | for (var i=1; i<this.points.length; i++) { | ||
1125 | bb.addPoint(this.points[i].x, this.points[i].y); | ||
1126 | if (ctx != null) ctx.lineTo(this.points[i].x, this.points[i].y); | ||
1127 | } | ||
1128 | return bb; | ||
1129 | } | ||
1130 | |||
1131 | this.getMarkers = function() { | ||
1132 | var markers = []; | ||
1133 | for (var i=0; i<this.points.length - 1; i++) { | ||
1134 | markers.push([this.points[i], this.points[i].angleTo(this.points[i+1])]); | ||
1135 | } | ||
1136 | markers.push([this.points[this.points.length-1], markers[markers.length-1][1]]); | ||
1137 | return markers; | ||
1138 | } | ||
1139 | } | ||
1140 | svg.Element.polyline.prototype = new svg.Element.PathElementBase; | ||
1141 | |||
1142 | // polygon element | ||
1143 | svg.Element.polygon = function(node) { | ||
1144 | this.base = svg.Element.polyline; | ||
1145 | this.base(node); | ||
1146 | |||
1147 | this.basePath = this.path; | ||
1148 | this.path = function(ctx) { | ||
1149 | var bb = this.basePath(ctx); | ||
1150 | if (ctx != null) { | ||
1151 | ctx.lineTo(this.points[0].x, this.points[0].y); | ||
1152 | ctx.closePath(); | ||
1153 | } | ||
1154 | return bb; | ||
1155 | } | ||
1156 | } | ||
1157 | svg.Element.polygon.prototype = new svg.Element.polyline; | ||
1158 | |||
1159 | // path element | ||
1160 | svg.Element.path = function(node) { | ||
1161 | this.base = svg.Element.PathElementBase; | ||
1162 | this.base(node); | ||
1163 | |||
1164 | var d = this.attribute('d').value; | ||
1165 | // TODO: convert to real lexer based on http://www.w3.org/TR/SVG11/paths.html#PathDataBNF | ||
1166 | d = d.replace(/,/gm,' '); // get rid of all commas | ||
1167 | d = d.replace(/([MmZzLlHhVvCcSsQqTtAa])([MmZzLlHhVvCcSsQqTtAa])/gm,'$1 $2'); // separate commands from commands | ||
1168 | d = d.replace(/([MmZzLlHhVvCcSsQqTtAa])([MmZzLlHhVvCcSsQqTtAa])/gm,'$1 $2'); // separate commands from commands | ||
1169 | d = d.replace(/([MmZzLlHhVvCcSsQqTtAa])([^\s])/gm,'$1 $2'); // separate commands from points | ||
1170 | d = d.replace(/([^\s])([MmZzLlHhVvCcSsQqTtAa])/gm,'$1 $2'); // separate commands from points | ||
1171 | d = d.replace(/([0-9])([+\-])/gm,'$1 $2'); // separate digits when no comma | ||
1172 | d = d.replace(/(\.[0-9]*)(\.)/gm,'$1 $2'); // separate digits when no comma | ||
1173 | d = d.replace(/([Aa](\s+[0-9]+){3})\s+([01])\s*([01])/gm,'$1 $3 $4 '); // shorthand elliptical arc path syntax | ||
1174 | d = svg.compressSpaces(d); // compress multiple spaces | ||
1175 | d = svg.trim(d); | ||
1176 | this.PathParser = new (function(d) { | ||
1177 | this.tokens = d.split(' '); | ||
1178 | |||
1179 | this.reset = function() { | ||
1180 | this.i = -1; | ||
1181 | this.command = ''; | ||
1182 | this.previousCommand = ''; | ||
1183 | this.start = new svg.Point(0, 0); | ||
1184 | this.control = new svg.Point(0, 0); | ||
1185 | this.current = new svg.Point(0, 0); | ||
1186 | this.points = []; | ||
1187 | this.angles = []; | ||
1188 | } | ||
1189 | |||
1190 | this.isEnd = function() { | ||
1191 | return this.i >= this.tokens.length - 1; | ||
1192 | } | ||
1193 | |||
1194 | this.isCommandOrEnd = function() { | ||
1195 | if (this.isEnd()) return true; | ||
1196 | return this.tokens[this.i + 1].match(/^[A-Za-z]$/) != null; | ||
1197 | } | ||
1198 | |||
1199 | this.isRelativeCommand = function() { | ||
1200 | switch(this.command) | ||
1201 | { | ||
1202 | case 'm': | ||
1203 | case 'l': | ||
1204 | case 'h': | ||
1205 | case 'v': | ||
1206 | case 'c': | ||
1207 | case 's': | ||
1208 | case 'q': | ||
1209 | case 't': | ||
1210 | case 'a': | ||
1211 | case 'z': | ||
1212 | return true; | ||
1213 | break; | ||
1214 | } | ||
1215 | return false; | ||
1216 | } | ||
1217 | |||
1218 | this.getToken = function() { | ||
1219 | this.i++; | ||
1220 | return this.tokens[this.i]; | ||
1221 | } | ||
1222 | |||
1223 | this.getScalar = function() { | ||
1224 | return parseFloat(this.getToken()); | ||
1225 | } | ||
1226 | |||
1227 | this.nextCommand = function() { | ||
1228 | this.previousCommand = this.command; | ||
1229 | this.command = this.getToken(); | ||
1230 | } | ||
1231 | |||
1232 | this.getPoint = function() { | ||
1233 | var p = new svg.Point(this.getScalar(), this.getScalar()); | ||
1234 | return this.makeAbsolute(p); | ||
1235 | } | ||
1236 | |||
1237 | this.getAsControlPoint = function() { | ||
1238 | var p = this.getPoint(); | ||
1239 | this.control = p; | ||
1240 | return p; | ||
1241 | } | ||
1242 | |||
1243 | this.getAsCurrentPoint = function() { | ||
1244 | var p = this.getPoint(); | ||
1245 | this.current = p; | ||
1246 | return p; | ||
1247 | } | ||
1248 | |||
1249 | this.getReflectedControlPoint = function() { | ||
1250 | if (this.previousCommand.toLowerCase() != 'c' && | ||
1251 | this.previousCommand.toLowerCase() != 's' && | ||
1252 | this.previousCommand.toLowerCase() != 'q' && | ||
1253 | this.previousCommand.toLowerCase() != 't' ){ | ||
1254 | return this.current; | ||
1255 | } | ||
1256 | |||
1257 | // reflect point | ||
1258 | var p = new svg.Point(2 * this.current.x - this.control.x, 2 * this.current.y - this.control.y); | ||
1259 | return p; | ||
1260 | } | ||
1261 | |||
1262 | this.makeAbsolute = function(p) { | ||
1263 | if (this.isRelativeCommand()) { | ||
1264 | p.x += this.current.x; | ||
1265 | p.y += this.current.y; | ||
1266 | } | ||
1267 | return p; | ||
1268 | } | ||
1269 | |||
1270 | this.addMarker = function(p, from, priorTo) { | ||
1271 | // if the last angle isn't filled in because we didn't have this point yet ... | ||
1272 | if (priorTo != null && this.angles.length > 0 && this.angles[this.angles.length-1] == null) { | ||
1273 | this.angles[this.angles.length-1] = this.points[this.points.length-1].angleTo(priorTo); | ||
1274 | } | ||
1275 | this.addMarkerAngle(p, from == null ? null : from.angleTo(p)); | ||
1276 | } | ||
1277 | |||
1278 | this.addMarkerAngle = function(p, a) { | ||
1279 | this.points.push(p); | ||
1280 | this.angles.push(a); | ||
1281 | } | ||
1282 | |||
1283 | this.getMarkerPoints = function() { return this.points; } | ||
1284 | this.getMarkerAngles = function() { | ||
1285 | for (var i=0; i<this.angles.length; i++) { | ||
1286 | if (this.angles[i] == null) { | ||
1287 | for (var j=i+1; j<this.angles.length; j++) { | ||
1288 | if (this.angles[j] != null) { | ||
1289 | this.angles[i] = this.angles[j]; | ||
1290 | break; | ||
1291 | } | ||
1292 | } | ||
1293 | } | ||
1294 | } | ||
1295 | return this.angles; | ||
1296 | } | ||
1297 | })(d); | ||
1298 | |||
1299 | this.path = function(ctx) { | ||
1300 | var pp = this.PathParser; | ||
1301 | pp.reset(); | ||
1302 | |||
1303 | var bb = new svg.BoundingBox(); | ||
1304 | if (ctx != null) ctx.beginPath(); | ||
1305 | while (!pp.isEnd()) { | ||
1306 | pp.nextCommand(); | ||
1307 | switch (pp.command) { | ||
1308 | case 'M': | ||
1309 | case 'm': | ||
1310 | var p = pp.getAsCurrentPoint(); | ||
1311 | pp.addMarker(p); | ||
1312 | bb.addPoint(p.x, p.y); | ||
1313 | if (ctx != null) ctx.moveTo(p.x, p.y); | ||
1314 | pp.start = pp.current; | ||
1315 | while (!pp.isCommandOrEnd()) { | ||
1316 | var p = pp.getAsCurrentPoint(); | ||
1317 | pp.addMarker(p, pp.start); | ||
1318 | bb.addPoint(p.x, p.y); | ||
1319 | if (ctx != null) ctx.lineTo(p.x, p.y); | ||
1320 | } | ||
1321 | break; | ||
1322 | case 'L': | ||
1323 | case 'l': | ||
1324 | while (!pp.isCommandOrEnd()) { | ||
1325 | var c = pp.current; | ||
1326 | var p = pp.getAsCurrentPoint(); | ||
1327 | pp.addMarker(p, c); | ||
1328 | bb.addPoint(p.x, p.y); | ||
1329 | if (ctx != null) ctx.lineTo(p.x, p.y); | ||
1330 | } | ||
1331 | break; | ||
1332 | case 'H': | ||
1333 | case 'h': | ||
1334 | while (!pp.isCommandOrEnd()) { | ||
1335 | var newP = new svg.Point((pp.isRelativeCommand() ? pp.current.x : 0) + pp.getScalar(), pp.current.y); | ||
1336 | pp.addMarker(newP, pp.current); | ||
1337 | pp.current = newP; | ||
1338 | bb.addPoint(pp.current.x, pp.current.y); | ||
1339 | if (ctx != null) ctx.lineTo(pp.current.x, pp.current.y); | ||
1340 | } | ||
1341 | break; | ||
1342 | case 'V': | ||
1343 | case 'v': | ||
1344 | while (!pp.isCommandOrEnd()) { | ||
1345 | var newP = new svg.Point(pp.current.x, (pp.isRelativeCommand() ? pp.current.y : 0) + pp.getScalar()); | ||
1346 | pp.addMarker(newP, pp.current); | ||
1347 | pp.current = newP; | ||
1348 | bb.addPoint(pp.current.x, pp.current.y); | ||
1349 | if (ctx != null) ctx.lineTo(pp.current.x, pp.current.y); | ||
1350 | } | ||
1351 | break; | ||
1352 | case 'C': | ||
1353 | case 'c': | ||
1354 | while (!pp.isCommandOrEnd()) { | ||
1355 | var curr = pp.current; | ||
1356 | var p1 = pp.getPoint(); | ||
1357 | var cntrl = pp.getAsControlPoint(); | ||
1358 | var cp = pp.getAsCurrentPoint(); | ||
1359 | pp.addMarker(cp, cntrl, p1); | ||
1360 | bb.addBezierCurve(curr.x, curr.y, p1.x, p1.y, cntrl.x, cntrl.y, cp.x, cp.y); | ||
1361 | if (ctx != null) ctx.bezierCurveTo(p1.x, p1.y, cntrl.x, cntrl.y, cp.x, cp.y); | ||
1362 | } | ||
1363 | break; | ||
1364 | case 'S': | ||
1365 | case 's': | ||
1366 | while (!pp.isCommandOrEnd()) { | ||
1367 | var curr = pp.current; | ||
1368 | var p1 = pp.getReflectedControlPoint(); | ||
1369 | var cntrl = pp.getAsControlPoint(); | ||
1370 | var cp = pp.getAsCurrentPoint(); | ||
1371 | pp.addMarker(cp, cntrl, p1); | ||
1372 | bb.addBezierCurve(curr.x, curr.y, p1.x, p1.y, cntrl.x, cntrl.y, cp.x, cp.y); | ||
1373 | if (ctx != null) ctx.bezierCurveTo(p1.x, p1.y, cntrl.x, cntrl.y, cp.x, cp.y); | ||
1374 | } | ||
1375 | break; | ||
1376 | case 'Q': | ||
1377 | case 'q': | ||
1378 | while (!pp.isCommandOrEnd()) { | ||
1379 | var curr = pp.current; | ||
1380 | var cntrl = pp.getAsControlPoint(); | ||
1381 | var cp = pp.getAsCurrentPoint(); | ||
1382 | pp.addMarker(cp, cntrl, cntrl); | ||
1383 | bb.addQuadraticCurve(curr.x, curr.y, cntrl.x, cntrl.y, cp.x, cp.y); | ||
1384 | if (ctx != null) ctx.quadraticCurveTo(cntrl.x, cntrl.y, cp.x, cp.y); | ||
1385 | } | ||
1386 | break; | ||
1387 | case 'T': | ||
1388 | case 't': | ||
1389 | while (!pp.isCommandOrEnd()) { | ||
1390 | var curr = pp.current; | ||
1391 | var cntrl = pp.getReflectedControlPoint(); | ||
1392 | pp.control = cntrl; | ||
1393 | var cp = pp.getAsCurrentPoint(); | ||
1394 | pp.addMarker(cp, cntrl, cntrl); | ||
1395 | bb.addQuadraticCurve(curr.x, curr.y, cntrl.x, cntrl.y, cp.x, cp.y); | ||
1396 | if (ctx != null) ctx.quadraticCurveTo(cntrl.x, cntrl.y, cp.x, cp.y); | ||
1397 | } | ||
1398 | break; | ||
1399 | case 'A': | ||
1400 | case 'a': | ||
1401 | while (!pp.isCommandOrEnd()) { | ||
1402 | var curr = pp.current; | ||
1403 | var rx = pp.getScalar(); | ||
1404 | var ry = pp.getScalar(); | ||
1405 | var xAxisRotation = pp.getScalar() * (Math.PI / 180.0); | ||
1406 | var largeArcFlag = pp.getScalar(); | ||
1407 | var sweepFlag = pp.getScalar(); | ||
1408 | var cp = pp.getAsCurrentPoint(); | ||
1409 | |||
1410 | // Conversion from endpoint to center parameterization | ||
1411 | // http://www.w3.org/TR/SVG11/implnote.html#ArcImplementationNotes | ||
1412 | // x1', y1' | ||
1413 | var currp = new svg.Point( | ||
1414 | Math.cos(xAxisRotation) * (curr.x - cp.x) / 2.0 + Math.sin(xAxisRotation) * (curr.y - cp.y) / 2.0, | ||
1415 | -Math.sin(xAxisRotation) * (curr.x - cp.x) / 2.0 + Math.cos(xAxisRotation) * (curr.y - cp.y) / 2.0 | ||
1416 | ); | ||
1417 | // adjust radii | ||
1418 | var l = Math.pow(currp.x,2)/Math.pow(rx,2)+Math.pow(currp.y,2)/Math.pow(ry,2); | ||
1419 | if (l > 1) { | ||
1420 | rx *= Math.sqrt(l); | ||
1421 | ry *= Math.sqrt(l); | ||
1422 | } | ||
1423 | // cx', cy' | ||
1424 | var s = (largeArcFlag == sweepFlag ? -1 : 1) * Math.sqrt( | ||
1425 | ((Math.pow(rx,2)*Math.pow(ry,2))-(Math.pow(rx,2)*Math.pow(currp.y,2))-(Math.pow(ry,2)*Math.pow(currp.x,2))) / | ||
1426 | (Math.pow(rx,2)*Math.pow(currp.y,2)+Math.pow(ry,2)*Math.pow(currp.x,2)) | ||
1427 | ); | ||
1428 | if (isNaN(s)) s = 0; | ||
1429 | var cpp = new svg.Point(s * rx * currp.y / ry, s * -ry * currp.x / rx); | ||
1430 | // cx, cy | ||
1431 | var centp = new svg.Point( | ||
1432 | (curr.x + cp.x) / 2.0 + Math.cos(xAxisRotation) * cpp.x - Math.sin(xAxisRotation) * cpp.y, | ||
1433 | (curr.y + cp.y) / 2.0 + Math.sin(xAxisRotation) * cpp.x + Math.cos(xAxisRotation) * cpp.y | ||
1434 | ); | ||
1435 | // vector magnitude | ||
1436 | var m = function(v) { return Math.sqrt(Math.pow(v[0],2) + Math.pow(v[1],2)); } | ||
1437 | // ratio between two vectors | ||
1438 | var r = function(u, v) { return (u[0]*v[0]+u[1]*v[1]) / (m(u)*m(v)) } | ||
1439 | // angle between two vectors | ||
1440 | var a = function(u, v) { return (u[0]*v[1] < u[1]*v[0] ? -1 : 1) * Math.acos(r(u,v)); } | ||
1441 | // initial angle | ||
1442 | var a1 = a([1,0], [(currp.x-cpp.x)/rx,(currp.y-cpp.y)/ry]); | ||
1443 | // angle delta | ||
1444 | var u = [(currp.x-cpp.x)/rx,(currp.y-cpp.y)/ry]; | ||
1445 | var v = [(-currp.x-cpp.x)/rx,(-currp.y-cpp.y)/ry]; | ||
1446 | var ad = a(u, v); | ||
1447 | if (r(u,v) <= -1) ad = Math.PI; | ||
1448 | if (r(u,v) >= 1) ad = 0; | ||
1449 | |||
1450 | // for markers | ||
1451 | var dir = 1 - sweepFlag ? 1.0 : -1.0; | ||
1452 | var ah = a1 + dir * (ad / 2.0); | ||
1453 | var halfWay = new svg.Point( | ||
1454 | centp.x + rx * Math.cos(ah), | ||
1455 | centp.y + ry * Math.sin(ah) | ||
1456 | ); | ||
1457 | pp.addMarkerAngle(halfWay, ah - dir * Math.PI / 2); | ||
1458 | pp.addMarkerAngle(cp, ah - dir * Math.PI); | ||
1459 | |||
1460 | bb.addPoint(cp.x, cp.y); // TODO: this is too naive, make it better | ||
1461 | if (ctx != null) { | ||
1462 | var r = rx > ry ? rx : ry; | ||
1463 | var sx = rx > ry ? 1 : rx / ry; | ||
1464 | var sy = rx > ry ? ry / rx : 1; | ||
1465 | |||
1466 | ctx.translate(centp.x, centp.y); | ||
1467 | ctx.rotate(xAxisRotation); | ||
1468 | ctx.scale(sx, sy); | ||
1469 | ctx.arc(0, 0, r, a1, a1 + ad, 1 - sweepFlag); | ||
1470 | ctx.scale(1/sx, 1/sy); | ||
1471 | ctx.rotate(-xAxisRotation); | ||
1472 | ctx.translate(-centp.x, -centp.y); | ||
1473 | } | ||
1474 | } | ||
1475 | break; | ||
1476 | case 'Z': | ||
1477 | case 'z': | ||
1478 | if (ctx != null) ctx.closePath(); | ||
1479 | pp.current = pp.start; | ||
1480 | } | ||
1481 | } | ||
1482 | |||
1483 | return bb; | ||
1484 | } | ||
1485 | |||
1486 | this.getMarkers = function() { | ||
1487 | var points = this.PathParser.getMarkerPoints(); | ||
1488 | var angles = this.PathParser.getMarkerAngles(); | ||
1489 | |||
1490 | var markers = []; | ||
1491 | for (var i=0; i<points.length; i++) { | ||
1492 | markers.push([points[i], angles[i]]); | ||
1493 | } | ||
1494 | return markers; | ||
1495 | } | ||
1496 | } | ||
1497 | svg.Element.path.prototype = new svg.Element.PathElementBase; | ||
1498 | |||
1499 | // pattern element | ||
1500 | svg.Element.pattern = function(node) { | ||
1501 | this.base = svg.Element.ElementBase; | ||
1502 | this.base(node); | ||
1503 | |||
1504 | this.createPattern = function(ctx, element) { | ||
1505 | var width = this.attribute('width').toPixels('x', true); | ||
1506 | var height = this.attribute('height').toPixels('y', true); | ||
1507 | |||
1508 | // render me using a temporary svg element | ||
1509 | var tempSvg = new svg.Element.svg(); | ||
1510 | tempSvg.attributes['viewBox'] = new svg.Property('viewBox', this.attribute('viewBox').value); | ||
1511 | tempSvg.attributes['width'] = new svg.Property('width', width + 'px'); | ||
1512 | tempSvg.attributes['height'] = new svg.Property('height', height + 'px'); | ||
1513 | tempSvg.attributes['transform'] = new svg.Property('transform', this.attribute('patternTransform').value); | ||
1514 | tempSvg.children = this.children; | ||
1515 | |||
1516 | var c = document.createElement('canvas'); | ||
1517 | c.width = width; | ||
1518 | c.height = height; | ||
1519 | var cctx = c.getContext('2d'); | ||
1520 | if (this.attribute('x').hasValue() && this.attribute('y').hasValue()) { | ||
1521 | cctx.translate(this.attribute('x').toPixels('x', true), this.attribute('y').toPixels('y', true)); | ||
1522 | } | ||
1523 | // render 3x3 grid so when we transform there's no white space on edges | ||
1524 | for (var x=-1; x<=1; x++) { | ||
1525 | for (var y=-1; y<=1; y++) { | ||
1526 | cctx.save(); | ||
1527 | cctx.translate(x * c.width, y * c.height); | ||
1528 | tempSvg.render(cctx); | ||
1529 | cctx.restore(); | ||
1530 | } | ||
1531 | } | ||
1532 | var pattern = ctx.createPattern(c, 'repeat'); | ||
1533 | return pattern; | ||
1534 | } | ||
1535 | } | ||
1536 | svg.Element.pattern.prototype = new svg.Element.ElementBase; | ||
1537 | |||
1538 | // marker element | ||
1539 | svg.Element.marker = function(node) { | ||
1540 | this.base = svg.Element.ElementBase; | ||
1541 | this.base(node); | ||
1542 | |||
1543 | this.baseRender = this.render; | ||
1544 | this.render = function(ctx, point, angle) { | ||
1545 | ctx.translate(point.x, point.y); | ||
1546 | if (this.attribute('orient').valueOrDefault('auto') == 'auto') ctx.rotate(angle); | ||
1547 | if (this.attribute('markerUnits').valueOrDefault('strokeWidth') == 'strokeWidth') ctx.scale(ctx.lineWidth, ctx.lineWidth); | ||
1548 | ctx.save(); | ||
1549 | |||
1550 | // render me using a temporary svg element | ||
1551 | var tempSvg = new svg.Element.svg(); | ||
1552 | tempSvg.attributes['viewBox'] = new svg.Property('viewBox', this.attribute('viewBox').value); | ||
1553 | tempSvg.attributes['refX'] = new svg.Property('refX', this.attribute('refX').value); | ||
1554 | tempSvg.attributes['refY'] = new svg.Property('refY', this.attribute('refY').value); | ||
1555 | tempSvg.attributes['width'] = new svg.Property('width', this.attribute('markerWidth').value); | ||
1556 | tempSvg.attributes['height'] = new svg.Property('height', this.attribute('markerHeight').value); | ||
1557 | tempSvg.attributes['fill'] = new svg.Property('fill', this.attribute('fill').valueOrDefault('black')); | ||
1558 | tempSvg.attributes['stroke'] = new svg.Property('stroke', this.attribute('stroke').valueOrDefault('none')); | ||
1559 | tempSvg.children = this.children; | ||
1560 | tempSvg.render(ctx); | ||
1561 | |||
1562 | ctx.restore(); | ||
1563 | if (this.attribute('markerUnits').valueOrDefault('strokeWidth') == 'strokeWidth') ctx.scale(1/ctx.lineWidth, 1/ctx.lineWidth); | ||
1564 | if (this.attribute('orient').valueOrDefault('auto') == 'auto') ctx.rotate(-angle); | ||
1565 | ctx.translate(-point.x, -point.y); | ||
1566 | } | ||
1567 | } | ||
1568 | svg.Element.marker.prototype = new svg.Element.ElementBase; | ||
1569 | |||
1570 | // definitions element | ||
1571 | svg.Element.defs = function(node) { | ||
1572 | this.base = svg.Element.ElementBase; | ||
1573 | this.base(node); | ||
1574 | |||
1575 | this.render = function(ctx) { | ||
1576 | // NOOP | ||
1577 | } | ||
1578 | } | ||
1579 | svg.Element.defs.prototype = new svg.Element.ElementBase; | ||
1580 | |||
1581 | // base for gradients | ||
1582 | svg.Element.GradientBase = function(node) { | ||
1583 | this.base = svg.Element.ElementBase; | ||
1584 | this.base(node); | ||
1585 | |||
1586 | this.gradientUnits = this.attribute('gradientUnits').valueOrDefault('objectBoundingBox'); | ||
1587 | |||
1588 | this.stops = []; | ||
1589 | for (var i=0; i<this.children.length; i++) { | ||
1590 | var child = this.children[i]; | ||
1591 | if (child.type == 'stop') this.stops.push(child); | ||
1592 | } | ||
1593 | |||
1594 | this.getGradient = function() { | ||
1595 | // OVERRIDE ME! | ||
1596 | } | ||
1597 | |||
1598 | this.createGradient = function(ctx, element, parentOpacityProp) { | ||
1599 | var stopsContainer = this; | ||
1600 | if (this.getHrefAttribute().hasValue()) { | ||
1601 | stopsContainer = this.getHrefAttribute().getDefinition(); | ||
1602 | } | ||
1603 | |||
1604 | var addParentOpacity = function (color) { | ||
1605 | if (parentOpacityProp.hasValue()) { | ||
1606 | var p = new svg.Property('color', color); | ||
1607 | return p.addOpacity(parentOpacityProp.value).value; | ||
1608 | } | ||
1609 | return color; | ||
1610 | }; | ||
1611 | |||
1612 | var g = this.getGradient(ctx, element); | ||
1613 | if (g == null) return addParentOpacity(stopsContainer.stops[stopsContainer.stops.length - 1].color); | ||
1614 | for (var i=0; i<stopsContainer.stops.length; i++) { | ||
1615 | g.addColorStop(stopsContainer.stops[i].offset, addParentOpacity(stopsContainer.stops[i].color)); | ||
1616 | } | ||
1617 | |||
1618 | if (this.attribute('gradientTransform').hasValue()) { | ||
1619 | // render as transformed pattern on temporary canvas | ||
1620 | var rootView = svg.ViewPort.viewPorts[0]; | ||
1621 | |||
1622 | var rect = new svg.Element.rect(); | ||
1623 | rect.attributes['x'] = new svg.Property('x', -svg.MAX_VIRTUAL_PIXELS/3.0); | ||
1624 | rect.attributes['y'] = new svg.Property('y', -svg.MAX_VIRTUAL_PIXELS/3.0); | ||
1625 | rect.attributes['width'] = new svg.Property('width', svg.MAX_VIRTUAL_PIXELS); | ||
1626 | rect.attributes['height'] = new svg.Property('height', svg.MAX_VIRTUAL_PIXELS); | ||
1627 | |||
1628 | var group = new svg.Element.g(); | ||
1629 | group.attributes['transform'] = new svg.Property('transform', this.attribute('gradientTransform').value); | ||
1630 | group.children = [ rect ]; | ||
1631 | |||
1632 | var tempSvg = new svg.Element.svg(); | ||
1633 | tempSvg.attributes['x'] = new svg.Property('x', 0); | ||
1634 | tempSvg.attributes['y'] = new svg.Property('y', 0); | ||
1635 | tempSvg.attributes['width'] = new svg.Property('width', rootView.width); | ||
1636 | tempSvg.attributes['height'] = new svg.Property('height', rootView.height); | ||
1637 | tempSvg.children = [ group ]; | ||
1638 | |||
1639 | var c = document.createElement('canvas'); | ||
1640 | c.width = rootView.width; | ||
1641 | c.height = rootView.height; | ||
1642 | var tempCtx = c.getContext('2d'); | ||
1643 | tempCtx.fillStyle = g; | ||
1644 | tempSvg.render(tempCtx); | ||
1645 | return tempCtx.createPattern(c, 'no-repeat'); | ||
1646 | } | ||
1647 | |||
1648 | return g; | ||
1649 | } | ||
1650 | } | ||
1651 | svg.Element.GradientBase.prototype = new svg.Element.ElementBase; | ||
1652 | |||
1653 | // linear gradient element | ||
1654 | svg.Element.linearGradient = function(node) { | ||
1655 | this.base = svg.Element.GradientBase; | ||
1656 | this.base(node); | ||
1657 | |||
1658 | this.getGradient = function(ctx, element) { | ||
1659 | var bb = element.getBoundingBox(); | ||
1660 | |||
1661 | if (!this.attribute('x1').hasValue() | ||
1662 | && !this.attribute('y1').hasValue() | ||
1663 | && !this.attribute('x2').hasValue() | ||
1664 | && !this.attribute('y2').hasValue()) { | ||
1665 | this.attribute('x1', true).value = 0; | ||
1666 | this.attribute('y1', true).value = 0; | ||
1667 | this.attribute('x2', true).value = 1; | ||
1668 | this.attribute('y2', true).value = 0; | ||
1669 | } | ||
1670 | |||
1671 | var x1 = (this.gradientUnits == 'objectBoundingBox' | ||
1672 | ? bb.x() + bb.width() * this.attribute('x1').numValue() | ||
1673 | : this.attribute('x1').toPixels('x')); | ||
1674 | var y1 = (this.gradientUnits == 'objectBoundingBox' | ||
1675 | ? bb.y() + bb.height() * this.attribute('y1').numValue() | ||
1676 | : this.attribute('y1').toPixels('y')); | ||
1677 | var x2 = (this.gradientUnits == 'objectBoundingBox' | ||
1678 | ? bb.x() + bb.width() * this.attribute('x2').numValue() | ||
1679 | : this.attribute('x2').toPixels('x')); | ||
1680 | var y2 = (this.gradientUnits == 'objectBoundingBox' | ||
1681 | ? bb.y() + bb.height() * this.attribute('y2').numValue() | ||
1682 | : this.attribute('y2').toPixels('y')); | ||
1683 | |||
1684 | if (x1 == x2 && y1 == y2) return null; | ||
1685 | return ctx.createLinearGradient(x1, y1, x2, y2); | ||
1686 | } | ||
1687 | } | ||
1688 | svg.Element.linearGradient.prototype = new svg.Element.GradientBase; | ||
1689 | |||
1690 | // radial gradient element | ||
1691 | svg.Element.radialGradient = function(node) { | ||
1692 | this.base = svg.Element.GradientBase; | ||
1693 | this.base(node); | ||
1694 | |||
1695 | this.getGradient = function(ctx, element) { | ||
1696 | var bb = element.getBoundingBox(); | ||
1697 | |||
1698 | if (!this.attribute('cx').hasValue()) this.attribute('cx', true).value = '50%'; | ||
1699 | if (!this.attribute('cy').hasValue()) this.attribute('cy', true).value = '50%'; | ||
1700 | if (!this.attribute('r').hasValue()) this.attribute('r', true).value = '50%'; | ||
1701 | |||
1702 | var cx = (this.gradientUnits == 'objectBoundingBox' | ||
1703 | ? bb.x() + bb.width() * this.attribute('cx').numValue() | ||
1704 | : this.attribute('cx').toPixels('x')); | ||
1705 | var cy = (this.gradientUnits == 'objectBoundingBox' | ||
1706 | ? bb.y() + bb.height() * this.attribute('cy').numValue() | ||
1707 | : this.attribute('cy').toPixels('y')); | ||
1708 | |||
1709 | var fx = cx; | ||
1710 | var fy = cy; | ||
1711 | if (this.attribute('fx').hasValue()) { | ||
1712 | fx = (this.gradientUnits == 'objectBoundingBox' | ||
1713 | ? bb.x() + bb.width() * this.attribute('fx').numValue() | ||
1714 | : this.attribute('fx').toPixels('x')); | ||
1715 | } | ||
1716 | if (this.attribute('fy').hasValue()) { | ||
1717 | fy = (this.gradientUnits == 'objectBoundingBox' | ||
1718 | ? bb.y() + bb.height() * this.attribute('fy').numValue() | ||
1719 | : this.attribute('fy').toPixels('y')); | ||
1720 | } | ||
1721 | |||
1722 | var r = (this.gradientUnits == 'objectBoundingBox' | ||
1723 | ? (bb.width() + bb.height()) / 2.0 * this.attribute('r').numValue() | ||
1724 | : this.attribute('r').toPixels()); | ||
1725 | |||
1726 | return ctx.createRadialGradient(fx, fy, 0, cx, cy, r); | ||
1727 | } | ||
1728 | } | ||
1729 | svg.Element.radialGradient.prototype = new svg.Element.GradientBase; | ||
1730 | |||
1731 | // gradient stop element | ||
1732 | svg.Element.stop = function(node) { | ||
1733 | this.base = svg.Element.ElementBase; | ||
1734 | this.base(node); | ||
1735 | |||
1736 | this.offset = this.attribute('offset').numValue(); | ||
1737 | if (this.offset < 0) this.offset = 0; | ||
1738 | if (this.offset > 1) this.offset = 1; | ||
1739 | |||
1740 | var stopColor = this.style('stop-color'); | ||
1741 | if (this.style('stop-opacity').hasValue()) stopColor = stopColor.addOpacity(this.style('stop-opacity').value); | ||
1742 | this.color = stopColor.value; | ||
1743 | } | ||
1744 | svg.Element.stop.prototype = new svg.Element.ElementBase; | ||
1745 | |||
1746 | // animation base element | ||
1747 | svg.Element.AnimateBase = function(node) { | ||
1748 | this.base = svg.Element.ElementBase; | ||
1749 | this.base(node); | ||
1750 | |||
1751 | svg.Animations.push(this); | ||
1752 | |||
1753 | this.duration = 0.0; | ||
1754 | this.begin = this.attribute('begin').toMilliseconds(); | ||
1755 | this.maxDuration = this.begin + this.attribute('dur').toMilliseconds(); | ||
1756 | |||
1757 | this.getProperty = function() { | ||
1758 | var attributeType = this.attribute('attributeType').value; | ||
1759 | var attributeName = this.attribute('attributeName').value; | ||
1760 | |||
1761 | if (attributeType == 'CSS') { | ||
1762 | return this.parent.style(attributeName, true); | ||
1763 | } | ||
1764 | return this.parent.attribute(attributeName, true); | ||
1765 | }; | ||
1766 | |||
1767 | this.initialValue = null; | ||
1768 | this.initialUnits = ''; | ||
1769 | this.removed = false; | ||
1770 | |||
1771 | this.calcValue = function() { | ||
1772 | // OVERRIDE ME! | ||
1773 | return ''; | ||
1774 | } | ||
1775 | |||
1776 | this.update = function(delta) { | ||
1777 | // set initial value | ||
1778 | if (this.initialValue == null) { | ||
1779 | this.initialValue = this.getProperty().value; | ||
1780 | this.initialUnits = this.getProperty().getUnits(); | ||
1781 | } | ||
1782 | |||
1783 | // if we're past the end time | ||
1784 | if (this.duration > this.maxDuration) { | ||
1785 | // loop for indefinitely repeating animations | ||
1786 | if (this.attribute('repeatCount').value == 'indefinite' | ||
1787 | || this.attribute('repeatDur').value == 'indefinite') { | ||
1788 | this.duration = 0.0 | ||
1789 | } | ||
1790 | else if (this.attribute('fill').valueOrDefault('remove') == 'remove' && !this.removed) { | ||
1791 | this.removed = true; | ||
1792 | this.getProperty().value = this.initialValue; | ||
1793 | return true; | ||
1794 | } | ||
1795 | else { | ||
1796 | return false; // no updates made | ||
1797 | } | ||
1798 | } | ||
1799 | this.duration = this.duration + delta; | ||
1800 | |||
1801 | // if we're past the begin time | ||
1802 | var updated = false; | ||
1803 | if (this.begin < this.duration) { | ||
1804 | var newValue = this.calcValue(); // tween | ||
1805 | |||
1806 | if (this.attribute('type').hasValue()) { | ||
1807 | // for transform, etc. | ||
1808 | var type = this.attribute('type').value; | ||
1809 | newValue = type + '(' + newValue + ')'; | ||
1810 | } | ||
1811 | |||
1812 | this.getProperty().value = newValue; | ||
1813 | updated = true; | ||
1814 | } | ||
1815 | |||
1816 | return updated; | ||
1817 | } | ||
1818 | |||
1819 | this.from = this.attribute('from'); | ||
1820 | this.to = this.attribute('to'); | ||
1821 | this.values = this.attribute('values'); | ||
1822 | if (this.values.hasValue()) this.values.value = this.values.value.split(';'); | ||
1823 | |||
1824 | // fraction of duration we've covered | ||
1825 | this.progress = function() { | ||
1826 | var ret = { progress: (this.duration - this.begin) / (this.maxDuration - this.begin) }; | ||
1827 | if (this.values.hasValue()) { | ||
1828 | var p = ret.progress * (this.values.value.length - 1); | ||
1829 | var lb = Math.floor(p), ub = Math.ceil(p); | ||
1830 | ret.from = new svg.Property('from', parseFloat(this.values.value[lb])); | ||
1831 | ret.to = new svg.Property('to', parseFloat(this.values.value[ub])); | ||
1832 | ret.progress = (p - lb) / (ub - lb); | ||
1833 | } | ||
1834 | else { | ||
1835 | ret.from = this.from; | ||
1836 | ret.to = this.to; | ||
1837 | } | ||
1838 | return ret; | ||
1839 | } | ||
1840 | } | ||
1841 | svg.Element.AnimateBase.prototype = new svg.Element.ElementBase; | ||
1842 | |||
1843 | // animate element | ||
1844 | svg.Element.animate = function(node) { | ||
1845 | this.base = svg.Element.AnimateBase; | ||
1846 | this.base(node); | ||
1847 | |||
1848 | this.calcValue = function() { | ||
1849 | var p = this.progress(); | ||
1850 | |||
1851 | // tween value linearly | ||
1852 | var newValue = p.from.numValue() + (p.to.numValue() - p.from.numValue()) * p.progress; | ||
1853 | return newValue + this.initialUnits; | ||
1854 | }; | ||
1855 | } | ||
1856 | svg.Element.animate.prototype = new svg.Element.AnimateBase; | ||
1857 | |||
1858 | // animate color element | ||
1859 | svg.Element.animateColor = function(node) { | ||
1860 | this.base = svg.Element.AnimateBase; | ||
1861 | this.base(node); | ||
1862 | |||
1863 | this.calcValue = function() { | ||
1864 | var p = this.progress(); | ||
1865 | var from = new RGBColor(p.from.value); | ||
1866 | var to = new RGBColor(p.to.value); | ||
1867 | |||
1868 | if (from.ok && to.ok) { | ||
1869 | // tween color linearly | ||
1870 | var r = from.r + (to.r - from.r) * p.progress; | ||
1871 | var g = from.g + (to.g - from.g) * p.progress; | ||
1872 | var b = from.b + (to.b - from.b) * p.progress; | ||
1873 | return 'rgb('+parseInt(r,10)+','+parseInt(g,10)+','+parseInt(b,10)+')'; | ||
1874 | } | ||
1875 | return this.attribute('from').value; | ||
1876 | }; | ||
1877 | } | ||
1878 | svg.Element.animateColor.prototype = new svg.Element.AnimateBase; | ||
1879 | |||
1880 | // animate transform element | ||
1881 | svg.Element.animateTransform = function(node) { | ||
1882 | this.base = svg.Element.AnimateBase; | ||
1883 | this.base(node); | ||
1884 | |||
1885 | this.calcValue = function() { | ||
1886 | var p = this.progress(); | ||
1887 | |||
1888 | // tween value linearly | ||
1889 | var from = svg.ToNumberArray(p.from.value); | ||
1890 | var to = svg.ToNumberArray(p.to.value); | ||
1891 | var newValue = ''; | ||
1892 | for (var i=0; i<from.length; i++) { | ||
1893 | newValue += from[i] + (to[i] - from[i]) * p.progress + ' '; | ||
1894 | } | ||
1895 | return newValue; | ||
1896 | }; | ||
1897 | } | ||
1898 | svg.Element.animateTransform.prototype = new svg.Element.animate; | ||
1899 | |||
1900 | // font element | ||
1901 | svg.Element.font = function(node) { | ||
1902 | this.base = svg.Element.ElementBase; | ||
1903 | this.base(node); | ||
1904 | |||
1905 | this.horizAdvX = this.attribute('horiz-adv-x').numValue(); | ||
1906 | |||
1907 | this.isRTL = false; | ||
1908 | this.isArabic = false; | ||
1909 | this.fontFace = null; | ||
1910 | this.missingGlyph = null; | ||
1911 | this.glyphs = []; | ||
1912 | for (var i=0; i<this.children.length; i++) { | ||
1913 | var child = this.children[i]; | ||
1914 | if (child.type == 'font-face') { | ||
1915 | this.fontFace = child; | ||
1916 | if (child.style('font-family').hasValue()) { | ||
1917 | svg.Definitions[child.style('font-family').value] = this; | ||
1918 | } | ||
1919 | } | ||
1920 | else if (child.type == 'missing-glyph') this.missingGlyph = child; | ||
1921 | else if (child.type == 'glyph') { | ||
1922 | if (child.arabicForm != '') { | ||
1923 | this.isRTL = true; | ||
1924 | this.isArabic = true; | ||
1925 | if (typeof(this.glyphs[child.unicode]) == 'undefined') this.glyphs[child.unicode] = []; | ||
1926 | this.glyphs[child.unicode][child.arabicForm] = child; | ||
1927 | } | ||
1928 | else { | ||
1929 | this.glyphs[child.unicode] = child; | ||
1930 | } | ||
1931 | } | ||
1932 | } | ||
1933 | } | ||
1934 | svg.Element.font.prototype = new svg.Element.ElementBase; | ||
1935 | |||
1936 | // font-face element | ||
1937 | svg.Element.fontface = function(node) { | ||
1938 | this.base = svg.Element.ElementBase; | ||
1939 | this.base(node); | ||
1940 | |||
1941 | this.ascent = this.attribute('ascent').value; | ||
1942 | this.descent = this.attribute('descent').value; | ||
1943 | this.unitsPerEm = this.attribute('units-per-em').numValue(); | ||
1944 | } | ||
1945 | svg.Element.fontface.prototype = new svg.Element.ElementBase; | ||
1946 | |||
1947 | // missing-glyph element | ||
1948 | svg.Element.missingglyph = function(node) { | ||
1949 | this.base = svg.Element.path; | ||
1950 | this.base(node); | ||
1951 | |||
1952 | this.horizAdvX = 0; | ||
1953 | } | ||
1954 | svg.Element.missingglyph.prototype = new svg.Element.path; | ||
1955 | |||
1956 | // glyph element | ||
1957 | svg.Element.glyph = function(node) { | ||
1958 | this.base = svg.Element.path; | ||
1959 | this.base(node); | ||
1960 | |||
1961 | this.horizAdvX = this.attribute('horiz-adv-x').numValue(); | ||
1962 | this.unicode = this.attribute('unicode').value; | ||
1963 | this.arabicForm = this.attribute('arabic-form').value; | ||
1964 | } | ||
1965 | svg.Element.glyph.prototype = new svg.Element.path; | ||
1966 | |||
1967 | // text element | ||
1968 | svg.Element.text = function(node) { | ||
1969 | this.captureTextNodes = true; | ||
1970 | this.base = svg.Element.RenderedElementBase; | ||
1971 | this.base(node); | ||
1972 | |||
1973 | this.baseSetContext = this.setContext; | ||
1974 | this.setContext = function(ctx) { | ||
1975 | this.baseSetContext(ctx); | ||
1976 | if (this.style('dominant-baseline').hasValue()) ctx.textBaseline = this.style('dominant-baseline').value; | ||
1977 | if (this.style('alignment-baseline').hasValue()) ctx.textBaseline = this.style('alignment-baseline').value; | ||
1978 | } | ||
1979 | |||
1980 | this.getBoundingBox = function () { | ||
1981 | // TODO: implement | ||
1982 | return new svg.BoundingBox(this.attribute('x').toPixels('x'), this.attribute('y').toPixels('y'), 0, 0); | ||
1983 | } | ||
1984 | |||
1985 | this.renderChildren = function(ctx) { | ||
1986 | this.x = this.attribute('x').toPixels('x'); | ||
1987 | this.y = this.attribute('y').toPixels('y'); | ||
1988 | this.x += this.getAnchorDelta(ctx, this, 0); | ||
1989 | for (var i=0; i<this.children.length; i++) { | ||
1990 | this.renderChild(ctx, this, i); | ||
1991 | } | ||
1992 | } | ||
1993 | |||
1994 | this.getAnchorDelta = function (ctx, parent, startI) { | ||
1995 | var textAnchor = this.style('text-anchor').valueOrDefault('start'); | ||
1996 | if (textAnchor != 'start') { | ||
1997 | var width = 0; | ||
1998 | for (var i=startI; i<parent.children.length; i++) { | ||
1999 | var child = parent.children[i]; | ||
2000 | if (i > startI && child.attribute('x').hasValue()) break; // new group | ||
2001 | width += child.measureTextRecursive(ctx); | ||
2002 | } | ||
2003 | return -1 * (textAnchor == 'end' ? width : width / 2.0); | ||
2004 | } | ||
2005 | return 0; | ||
2006 | } | ||
2007 | |||
2008 | this.renderChild = function(ctx, parent, i) { | ||
2009 | var child = parent.children[i]; | ||
2010 | if (child.attribute('x').hasValue()) { | ||
2011 | child.x = child.attribute('x').toPixels('x') + this.getAnchorDelta(ctx, parent, i); | ||
2012 | } | ||
2013 | else { | ||
2014 | if (this.attribute('dx').hasValue()) this.x += this.attribute('dx').toPixels('x'); | ||
2015 | if (child.attribute('dx').hasValue()) this.x += child.attribute('dx').toPixels('x'); | ||
2016 | child.x = this.x; | ||
2017 | } | ||
2018 | this.x = child.x + child.measureText(ctx); | ||
2019 | |||
2020 | if (child.attribute('y').hasValue()) { | ||
2021 | child.y = child.attribute('y').toPixels('y'); | ||
2022 | } | ||
2023 | else { | ||
2024 | if (this.attribute('dy').hasValue()) this.y += this.attribute('dy').toPixels('y'); | ||
2025 | if (child.attribute('dy').hasValue()) this.y += child.attribute('dy').toPixels('y'); | ||
2026 | child.y = this.y; | ||
2027 | } | ||
2028 | this.y = child.y; | ||
2029 | |||
2030 | child.render(ctx); | ||
2031 | |||
2032 | for (var i=0; i<child.children.length; i++) { | ||
2033 | this.renderChild(ctx, child, i); | ||
2034 | } | ||
2035 | } | ||
2036 | } | ||
2037 | svg.Element.text.prototype = new svg.Element.RenderedElementBase; | ||
2038 | |||
2039 | // text base | ||
2040 | svg.Element.TextElementBase = function(node) { | ||
2041 | this.base = svg.Element.RenderedElementBase; | ||
2042 | this.base(node); | ||
2043 | |||
2044 | this.getGlyph = function(font, text, i) { | ||
2045 | var c = text[i]; | ||
2046 | var glyph = null; | ||
2047 | if (font.isArabic) { | ||
2048 | var arabicForm = 'isolated'; | ||
2049 | if ((i==0 || text[i-1]==' ') && i<text.length-2 && text[i+1]!=' ') arabicForm = 'terminal'; | ||
2050 | if (i>0 && text[i-1]!=' ' && i<text.length-2 && text[i+1]!=' ') arabicForm = 'medial'; | ||
2051 | if (i>0 && text[i-1]!=' ' && (i == text.length-1 || text[i+1]==' ')) arabicForm = 'initial'; | ||
2052 | if (typeof(font.glyphs[c]) != 'undefined') { | ||
2053 | glyph = font.glyphs[c][arabicForm]; | ||
2054 | if (glyph == null && font.glyphs[c].type == 'glyph') glyph = font.glyphs[c]; | ||
2055 | } | ||
2056 | } | ||
2057 | else { | ||
2058 | glyph = font.glyphs[c]; | ||
2059 | } | ||
2060 | if (glyph == null) glyph = font.missingGlyph; | ||
2061 | return glyph; | ||
2062 | } | ||
2063 | |||
2064 | this.renderChildren = function(ctx) { | ||
2065 | var customFont = this.parent.style('font-family').getDefinition(); | ||
2066 | if (customFont != null) { | ||
2067 | var fontSize = this.parent.style('font-size').numValueOrDefault(svg.Font.Parse(svg.ctx.font).fontSize); | ||
2068 | var fontStyle = this.parent.style('font-style').valueOrDefault(svg.Font.Parse(svg.ctx.font).fontStyle); | ||
2069 | var text = this.getText(); | ||
2070 | if (customFont.isRTL) text = text.split("").reverse().join(""); | ||
2071 | |||
2072 | var dx = svg.ToNumberArray(this.parent.attribute('dx').value); | ||
2073 | for (var i=0; i<text.length; i++) { | ||
2074 | var glyph = this.getGlyph(customFont, text, i); | ||
2075 | var scale = fontSize / customFont.fontFace.unitsPerEm; | ||
2076 | ctx.translate(this.x, this.y); | ||
2077 | ctx.scale(scale, -scale); | ||
2078 | var lw = ctx.lineWidth; | ||
2079 | ctx.lineWidth = ctx.lineWidth * customFont.fontFace.unitsPerEm / fontSize; | ||
2080 | if (fontStyle == 'italic') ctx.transform(1, 0, .4, 1, 0, 0); | ||
2081 | glyph.render(ctx); | ||
2082 | if (fontStyle == 'italic') ctx.transform(1, 0, -.4, 1, 0, 0); | ||
2083 | ctx.lineWidth = lw; | ||
2084 | ctx.scale(1/scale, -1/scale); | ||
2085 | ctx.translate(-this.x, -this.y); | ||
2086 | |||
2087 | this.x += fontSize * (glyph.horizAdvX || customFont.horizAdvX) / customFont.fontFace.unitsPerEm; | ||
2088 | if (typeof(dx[i]) != 'undefined' && !isNaN(dx[i])) { | ||
2089 | this.x += dx[i]; | ||
2090 | } | ||
2091 | } | ||
2092 | return; | ||
2093 | } | ||
2094 | |||
2095 | if (ctx.fillStyle != '') ctx.fillText(svg.compressSpaces(this.getText()), this.x, this.y); | ||
2096 | if (ctx.strokeStyle != '') ctx.strokeText(svg.compressSpaces(this.getText()), this.x, this.y); | ||
2097 | } | ||
2098 | |||
2099 | this.getText = function() { | ||
2100 | // OVERRIDE ME | ||
2101 | } | ||
2102 | |||
2103 | this.measureTextRecursive = function(ctx) { | ||
2104 | var width = this.measureText(ctx); | ||
2105 | for (var i=0; i<this.children.length; i++) { | ||
2106 | width += this.children[i].measureTextRecursive(ctx); | ||
2107 | } | ||
2108 | return width; | ||
2109 | } | ||
2110 | |||
2111 | this.measureText = function(ctx) { | ||
2112 | var customFont = this.parent.style('font-family').getDefinition(); | ||
2113 | if (customFont != null) { | ||
2114 | var fontSize = this.parent.style('font-size').numValueOrDefault(svg.Font.Parse(svg.ctx.font).fontSize); | ||
2115 | var measure = 0; | ||
2116 | var text = this.getText(); | ||
2117 | if (customFont.isRTL) text = text.split("").reverse().join(""); | ||
2118 | var dx = svg.ToNumberArray(this.parent.attribute('dx').value); | ||
2119 | for (var i=0; i<text.length; i++) { | ||
2120 | var glyph = this.getGlyph(customFont, text, i); | ||
2121 | measure += (glyph.horizAdvX || customFont.horizAdvX) * fontSize / customFont.fontFace.unitsPerEm; | ||
2122 | if (typeof(dx[i]) != 'undefined' && !isNaN(dx[i])) { | ||
2123 | measure += dx[i]; | ||
2124 | } | ||
2125 | } | ||
2126 | return measure; | ||
2127 | } | ||
2128 | |||
2129 | var textToMeasure = svg.compressSpaces(this.getText()); | ||
2130 | if (!ctx.measureText) return textToMeasure.length * 10; | ||
2131 | |||
2132 | ctx.save(); | ||
2133 | this.setContext(ctx); | ||
2134 | var width = ctx.measureText(textToMeasure).width; | ||
2135 | ctx.restore(); | ||
2136 | return width; | ||
2137 | } | ||
2138 | } | ||
2139 | svg.Element.TextElementBase.prototype = new svg.Element.RenderedElementBase; | ||
2140 | |||
2141 | // tspan | ||
2142 | svg.Element.tspan = function(node) { | ||
2143 | this.captureTextNodes = true; | ||
2144 | this.base = svg.Element.TextElementBase; | ||
2145 | this.base(node); | ||
2146 | |||
2147 | this.text = node.nodeValue || node.text || ''; | ||
2148 | this.getText = function() { | ||
2149 | return this.text; | ||
2150 | } | ||
2151 | } | ||
2152 | svg.Element.tspan.prototype = new svg.Element.TextElementBase; | ||
2153 | |||
2154 | // tref | ||
2155 | svg.Element.tref = function(node) { | ||
2156 | this.base = svg.Element.TextElementBase; | ||
2157 | this.base(node); | ||
2158 | |||
2159 | this.getText = function() { | ||
2160 | var element = this.getHrefAttribute().getDefinition(); | ||
2161 | if (element != null) return element.children[0].getText(); | ||
2162 | } | ||
2163 | } | ||
2164 | svg.Element.tref.prototype = new svg.Element.TextElementBase; | ||
2165 | |||
2166 | // a element | ||
2167 | svg.Element.a = function(node) { | ||
2168 | this.base = svg.Element.TextElementBase; | ||
2169 | this.base(node); | ||
2170 | |||
2171 | this.hasText = true; | ||
2172 | for (var i=0; i<node.childNodes.length; i++) { | ||
2173 | if (node.childNodes[i].nodeType != 3) this.hasText = false; | ||
2174 | } | ||
2175 | |||
2176 | // this might contain text | ||
2177 | this.text = this.hasText ? node.childNodes[0].nodeValue : ''; | ||
2178 | this.getText = function() { | ||
2179 | return this.text; | ||
2180 | } | ||
2181 | |||
2182 | this.baseRenderChildren = this.renderChildren; | ||
2183 | this.renderChildren = function(ctx) { | ||
2184 | if (this.hasText) { | ||
2185 | // render as text element | ||
2186 | this.baseRenderChildren(ctx); | ||
2187 | var fontSize = new svg.Property('fontSize', svg.Font.Parse(svg.ctx.font).fontSize); | ||
2188 | svg.Mouse.checkBoundingBox(this, new svg.BoundingBox(this.x, this.y - fontSize.toPixels('y'), this.x + this.measureText(ctx), this.y)); | ||
2189 | } | ||
2190 | else { | ||
2191 | // render as temporary group | ||
2192 | var g = new svg.Element.g(); | ||
2193 | g.children = this.children; | ||
2194 | g.parent = this; | ||
2195 | g.render(ctx); | ||
2196 | } | ||
2197 | } | ||
2198 | |||
2199 | this.onclick = function() { | ||
2200 | window.open(this.getHrefAttribute().value); | ||
2201 | } | ||
2202 | |||
2203 | this.onmousemove = function() { | ||
2204 | svg.ctx.canvas.style.cursor = 'pointer'; | ||
2205 | } | ||
2206 | } | ||
2207 | svg.Element.a.prototype = new svg.Element.TextElementBase; | ||
2208 | |||
2209 | // image element | ||
2210 | svg.Element.image = function(node) { | ||
2211 | this.base = svg.Element.RenderedElementBase; | ||
2212 | this.base(node); | ||
2213 | |||
2214 | var href = this.getHrefAttribute().value; | ||
2215 | var isSvg = href.match(/\.svg$/) | ||
2216 | |||
2217 | svg.Images.push(this); | ||
2218 | this.loaded = false; | ||
2219 | if (!isSvg) { | ||
2220 | this.img = document.createElement('img'); | ||
2221 | var self = this; | ||
2222 | this.img.onload = function() { self.loaded = true; } | ||
2223 | this.img.onerror = function() { if (typeof(console) != 'undefined') { console.log('ERROR: image "' + href + '" not found'); self.loaded = true; } } | ||
2224 | this.img.src = href; | ||
2225 | } | ||
2226 | else { | ||
2227 | this.img = svg.ajax(href); | ||
2228 | this.loaded = true; | ||
2229 | } | ||
2230 | |||
2231 | this.renderChildren = function(ctx) { | ||
2232 | var x = this.attribute('x').toPixels('x'); | ||
2233 | var y = this.attribute('y').toPixels('y'); | ||
2234 | |||
2235 | var width = this.attribute('width').toPixels('x'); | ||
2236 | var height = this.attribute('height').toPixels('y'); | ||
2237 | if (width == 0 || height == 0) return; | ||
2238 | |||
2239 | ctx.save(); | ||
2240 | if (isSvg) { | ||
2241 | ctx.drawSvg(this.img, x, y, width, height); | ||
2242 | } | ||
2243 | else { | ||
2244 | ctx.translate(x, y); | ||
2245 | svg.AspectRatio(ctx, | ||
2246 | this.attribute('preserveAspectRatio').value, | ||
2247 | width, | ||
2248 | this.img.width, | ||
2249 | height, | ||
2250 | this.img.height, | ||
2251 | 0, | ||
2252 | 0); | ||
2253 | ctx.drawImage(this.img, 0, 0); | ||
2254 | } | ||
2255 | ctx.restore(); | ||
2256 | } | ||
2257 | |||
2258 | this.getBoundingBox = function() { | ||
2259 | var x = this.attribute('x').toPixels('x'); | ||
2260 | var y = this.attribute('y').toPixels('y'); | ||
2261 | var width = this.attribute('width').toPixels('x'); | ||
2262 | var height = this.attribute('height').toPixels('y'); | ||
2263 | return new svg.BoundingBox(x, y, x + width, y + height); | ||
2264 | } | ||
2265 | } | ||
2266 | svg.Element.image.prototype = new svg.Element.RenderedElementBase; | ||
2267 | |||
2268 | // group element | ||
2269 | svg.Element.g = function(node) { | ||
2270 | this.base = svg.Element.RenderedElementBase; | ||
2271 | this.base(node); | ||
2272 | |||
2273 | this.getBoundingBox = function() { | ||
2274 | var bb = new svg.BoundingBox(); | ||
2275 | for (var i=0; i<this.children.length; i++) { | ||
2276 | bb.addBoundingBox(this.children[i].getBoundingBox()); | ||
2277 | } | ||
2278 | return bb; | ||
2279 | }; | ||
2280 | } | ||
2281 | svg.Element.g.prototype = new svg.Element.RenderedElementBase; | ||
2282 | |||
2283 | // symbol element | ||
2284 | svg.Element.symbol = function(node) { | ||
2285 | this.base = svg.Element.RenderedElementBase; | ||
2286 | this.base(node); | ||
2287 | |||
2288 | this.baseSetContext = this.setContext; | ||
2289 | this.setContext = function(ctx) { | ||
2290 | this.baseSetContext(ctx); | ||
2291 | |||
2292 | // viewbox | ||
2293 | if (this.attribute('viewBox').hasValue()) { | ||
2294 | var viewBox = svg.ToNumberArray(this.attribute('viewBox').value); | ||
2295 | var minX = viewBox[0]; | ||
2296 | var minY = viewBox[1]; | ||
2297 | width = viewBox[2]; | ||
2298 | height = viewBox[3]; | ||
2299 | |||
2300 | svg.AspectRatio(ctx, | ||
2301 | this.attribute('preserveAspectRatio').value, | ||
2302 | this.attribute('width').toPixels('x'), | ||
2303 | width, | ||
2304 | this.attribute('height').toPixels('y'), | ||
2305 | height, | ||
2306 | minX, | ||
2307 | minY); | ||
2308 | |||
2309 | svg.ViewPort.SetCurrent(viewBox[2], viewBox[3]); | ||
2310 | } | ||
2311 | } | ||
2312 | } | ||
2313 | svg.Element.symbol.prototype = new svg.Element.RenderedElementBase; | ||
2314 | |||
2315 | // style element | ||
2316 | svg.Element.style = function(node) { | ||
2317 | this.base = svg.Element.ElementBase; | ||
2318 | this.base(node); | ||
2319 | |||
2320 | // text, or spaces then CDATA | ||
2321 | var css = '' | ||
2322 | for (var i=0; i<node.childNodes.length; i++) { | ||
2323 | css += node.childNodes[i].nodeValue; | ||
2324 | } | ||
2325 | css = css.replace(/(\/\*([^*]|[\r\n]|(\*+([^*\/]|[\r\n])))*\*+\/)|(^[\s]*\/\/.*)/gm, ''); // remove comments | ||
2326 | css = svg.compressSpaces(css); // replace whitespace | ||
2327 | var cssDefs = css.split('}'); | ||
2328 | for (var i=0; i<cssDefs.length; i++) { | ||
2329 | if (svg.trim(cssDefs[i]) != '') { | ||
2330 | var cssDef = cssDefs[i].split('{'); | ||
2331 | var cssClasses = cssDef[0].split(','); | ||
2332 | var cssProps = cssDef[1].split(';'); | ||
2333 | for (var j=0; j<cssClasses.length; j++) { | ||
2334 | var cssClass = svg.trim(cssClasses[j]); | ||
2335 | if (cssClass != '') { | ||
2336 | var props = {}; | ||
2337 | for (var k=0; k<cssProps.length; k++) { | ||
2338 | var prop = cssProps[k].indexOf(':'); | ||
2339 | var name = cssProps[k].substr(0, prop); | ||
2340 | var value = cssProps[k].substr(prop + 1, cssProps[k].length - prop); | ||
2341 | if (name != null && value != null) { | ||
2342 | props[svg.trim(name)] = new svg.Property(svg.trim(name), svg.trim(value)); | ||
2343 | } | ||
2344 | } | ||
2345 | svg.Styles[cssClass] = props; | ||
2346 | if (cssClass == '@font-face') { | ||
2347 | var fontFamily = props['font-family'].value.replace(/"/g,''); | ||
2348 | var srcs = props['src'].value.split(','); | ||
2349 | for (var s=0; s<srcs.length; s++) { | ||
2350 | if (srcs[s].indexOf('format("svg")') > 0) { | ||
2351 | var urlStart = srcs[s].indexOf('url'); | ||
2352 | var urlEnd = srcs[s].indexOf(')', urlStart); | ||
2353 | var url = srcs[s].substr(urlStart + 5, urlEnd - urlStart - 6); | ||
2354 | var doc = svg.parseXml(svg.ajax(url)); | ||
2355 | var fonts = doc.getElementsByTagName('font'); | ||
2356 | for (var f=0; f<fonts.length; f++) { | ||
2357 | var font = svg.CreateElement(fonts[f]); | ||
2358 | svg.Definitions[fontFamily] = font; | ||
2359 | } | ||
2360 | } | ||
2361 | } | ||
2362 | } | ||
2363 | } | ||
2364 | } | ||
2365 | } | ||
2366 | } | ||
2367 | } | ||
2368 | svg.Element.style.prototype = new svg.Element.ElementBase; | ||
2369 | |||
2370 | // use element | ||
2371 | svg.Element.use = function(node) { | ||
2372 | this.base = svg.Element.RenderedElementBase; | ||
2373 | this.base(node); | ||
2374 | |||
2375 | this.baseSetContext = this.setContext; | ||
2376 | this.setContext = function(ctx) { | ||
2377 | this.baseSetContext(ctx); | ||
2378 | if (this.attribute('x').hasValue()) ctx.translate(this.attribute('x').toPixels('x'), 0); | ||
2379 | if (this.attribute('y').hasValue()) ctx.translate(0, this.attribute('y').toPixels('y')); | ||
2380 | } | ||
2381 | |||
2382 | this.getDefinition = function() { | ||
2383 | var element = this.getHrefAttribute().getDefinition(); | ||
2384 | if (this.attribute('width').hasValue()) element.attribute('width', true).value = this.attribute('width').value; | ||
2385 | if (this.attribute('height').hasValue()) element.attribute('height', true).value = this.attribute('height').value; | ||
2386 | return element; | ||
2387 | } | ||
2388 | |||
2389 | this.path = function(ctx) { | ||
2390 | var element = this.getDefinition(); | ||
2391 | if (element != null) element.path(ctx); | ||
2392 | } | ||
2393 | |||
2394 | this.getBoundingBox = function() { | ||
2395 | var element = this.getDefinition(); | ||
2396 | if (element != null) return element.getBoundingBox(); | ||
2397 | } | ||
2398 | |||
2399 | this.renderChildren = function(ctx) { | ||
2400 | var element = this.getDefinition(); | ||
2401 | if (element != null) { | ||
2402 | // temporarily detach from parent and render | ||
2403 | var oldParent = element.parent; | ||
2404 | element.parent = null; | ||
2405 | element.render(ctx); | ||
2406 | element.parent = oldParent; | ||
2407 | } | ||
2408 | } | ||
2409 | } | ||
2410 | svg.Element.use.prototype = new svg.Element.RenderedElementBase; | ||
2411 | |||
2412 | // mask element | ||
2413 | svg.Element.mask = function(node) { | ||
2414 | this.base = svg.Element.ElementBase; | ||
2415 | this.base(node); | ||
2416 | |||
2417 | this.apply = function(ctx, element) { | ||
2418 | // render as temp svg | ||
2419 | var x = this.attribute('x').toPixels('x'); | ||
2420 | var y = this.attribute('y').toPixels('y'); | ||
2421 | var width = this.attribute('width').toPixels('x'); | ||
2422 | var height = this.attribute('height').toPixels('y'); | ||
2423 | |||
2424 | if (width == 0 && height == 0) { | ||
2425 | var bb = new svg.BoundingBox(); | ||
2426 | for (var i=0; i<this.children.length; i++) { | ||
2427 | bb.addBoundingBox(this.children[i].getBoundingBox()); | ||
2428 | } | ||
2429 | var x = Math.floor(bb.x1); | ||
2430 | var y = Math.floor(bb.y1); | ||
2431 | var width = Math.floor(bb.width()); | ||
2432 | var height = Math.floor(bb.height()); | ||
2433 | } | ||
2434 | |||
2435 | // temporarily remove mask to avoid recursion | ||
2436 | var mask = element.attribute('mask').value; | ||
2437 | element.attribute('mask').value = ''; | ||
2438 | |||
2439 | var cMask = document.createElement('canvas'); | ||
2440 | cMask.width = x + width; | ||
2441 | cMask.height = y + height; | ||
2442 | var maskCtx = cMask.getContext('2d'); | ||
2443 | this.renderChildren(maskCtx); | ||
2444 | |||
2445 | var c = document.createElement('canvas'); | ||
2446 | c.width = x + width; | ||
2447 | c.height = y + height; | ||
2448 | var tempCtx = c.getContext('2d'); | ||
2449 | element.render(tempCtx); | ||
2450 | tempCtx.globalCompositeOperation = 'destination-in'; | ||
2451 | tempCtx.fillStyle = maskCtx.createPattern(cMask, 'no-repeat'); | ||
2452 | tempCtx.fillRect(0, 0, x + width, y + height); | ||
2453 | |||
2454 | ctx.fillStyle = tempCtx.createPattern(c, 'no-repeat'); | ||
2455 | ctx.fillRect(0, 0, x + width, y + height); | ||
2456 | |||
2457 | // reassign mask | ||
2458 | element.attribute('mask').value = mask; | ||
2459 | } | ||
2460 | |||
2461 | this.render = function(ctx) { | ||
2462 | // NO RENDER | ||
2463 | } | ||
2464 | } | ||
2465 | svg.Element.mask.prototype = new svg.Element.ElementBase; | ||
2466 | |||
2467 | // clip element | ||
2468 | svg.Element.clipPath = function(node) { | ||
2469 | this.base = svg.Element.ElementBase; | ||
2470 | this.base(node); | ||
2471 | |||
2472 | this.apply = function(ctx) { | ||
2473 | for (var i=0; i<this.children.length; i++) { | ||
2474 | var child = this.children[i]; | ||
2475 | if (typeof(child.path) != 'undefined') { | ||
2476 | var transform = null; | ||
2477 | if (child.attribute('transform').hasValue()) { | ||
2478 | transform = new svg.Transform(child.attribute('transform').value); | ||
2479 | transform.apply(ctx); | ||
2480 | } | ||
2481 | child.path(ctx); | ||
2482 | ctx.clip(); | ||
2483 | if (transform) { transform.unapply(ctx); } | ||
2484 | } | ||
2485 | } | ||
2486 | } | ||
2487 | |||
2488 | this.render = function(ctx) { | ||
2489 | // NO RENDER | ||
2490 | } | ||
2491 | } | ||
2492 | svg.Element.clipPath.prototype = new svg.Element.ElementBase; | ||
2493 | |||
2494 | // filters | ||
2495 | svg.Element.filter = function(node) { | ||
2496 | this.base = svg.Element.ElementBase; | ||
2497 | this.base(node); | ||
2498 | |||
2499 | this.apply = function(ctx, element) { | ||
2500 | // render as temp svg | ||
2501 | var bb = element.getBoundingBox(); | ||
2502 | var x = Math.floor(bb.x1); | ||
2503 | var y = Math.floor(bb.y1); | ||
2504 | var width = Math.floor(bb.width()); | ||
2505 | var height = Math.floor(bb.height()); | ||
2506 | |||
2507 | // temporarily remove filter to avoid recursion | ||
2508 | var filter = element.style('filter').value; | ||
2509 | element.style('filter').value = ''; | ||
2510 | |||
2511 | var px = 0, py = 0; | ||
2512 | for (var i=0; i<this.children.length; i++) { | ||
2513 | var efd = this.children[i].extraFilterDistance || 0; | ||
2514 | px = Math.max(px, efd); | ||
2515 | py = Math.max(py, efd); | ||
2516 | } | ||
2517 | |||
2518 | var c = document.createElement('canvas'); | ||
2519 | c.width = width + 2*px; | ||
2520 | c.height = height + 2*py; | ||
2521 | var tempCtx = c.getContext('2d'); | ||
2522 | tempCtx.translate(-x + px, -y + py); | ||
2523 | element.render(tempCtx); | ||
2524 | |||
2525 | // apply filters | ||
2526 | for (var i=0; i<this.children.length; i++) { | ||
2527 | this.children[i].apply(tempCtx, 0, 0, width + 2*px, height + 2*py); | ||
2528 | } | ||
2529 | |||
2530 | // render on me | ||
2531 | ctx.drawImage(c, 0, 0, width + 2*px, height + 2*py, x - px, y - py, width + 2*px, height + 2*py); | ||
2532 | |||
2533 | // reassign filter | ||
2534 | element.style('filter', true).value = filter; | ||
2535 | } | ||
2536 | |||
2537 | this.render = function(ctx) { | ||
2538 | // NO RENDER | ||
2539 | } | ||
2540 | } | ||
2541 | svg.Element.filter.prototype = new svg.Element.ElementBase; | ||
2542 | |||
2543 | svg.Element.feMorphology = function(node) { | ||
2544 | this.base = svg.Element.ElementBase; | ||
2545 | this.base(node); | ||
2546 | |||
2547 | this.apply = function(ctx, x, y, width, height) { | ||
2548 | // TODO: implement | ||
2549 | } | ||
2550 | } | ||
2551 | svg.Element.feMorphology.prototype = new svg.Element.ElementBase; | ||
2552 | |||
2553 | svg.Element.feColorMatrix = function(node) { | ||
2554 | this.base = svg.Element.ElementBase; | ||
2555 | this.base(node); | ||
2556 | |||
2557 | function imGet(img, x, y, width, height, rgba) { | ||
2558 | return img[y*width*4 + x*4 + rgba]; | ||
2559 | } | ||
2560 | |||
2561 | function imSet(img, x, y, width, height, rgba, val) { | ||
2562 | img[y*width*4 + x*4 + rgba] = val; | ||
2563 | } | ||
2564 | |||
2565 | this.apply = function(ctx, x, y, width, height) { | ||
2566 | // only supporting grayscale for now per Issue 195, need to extend to all matrix | ||
2567 | // assuming x==0 && y==0 for now | ||
2568 | var srcData = ctx.getImageData(0, 0, width, height); | ||
2569 | for (var y = 0; y < height; y++) { | ||
2570 | for (var x = 0; x < width; x++) { | ||
2571 | var r = imGet(srcData.data, x, y, width, height, 0); | ||
2572 | var g = imGet(srcData.data, x, y, width, height, 1); | ||
2573 | var b = imGet(srcData.data, x, y, width, height, 2); | ||
2574 | var gray = (r + g + b) / 3; | ||
2575 | imSet(srcData.data, x, y, width, height, 0, gray); | ||
2576 | imSet(srcData.data, x, y, width, height, 1, gray); | ||
2577 | imSet(srcData.data, x, y, width, height, 2, gray); | ||
2578 | } | ||
2579 | } | ||
2580 | ctx.clearRect(0, 0, width, height); | ||
2581 | ctx.putImageData(srcData, 0, 0); | ||
2582 | } | ||
2583 | } | ||
2584 | svg.Element.feColorMatrix.prototype = new svg.Element.ElementBase; | ||
2585 | |||
2586 | svg.Element.feGaussianBlur = function(node) { | ||
2587 | this.base = svg.Element.ElementBase; | ||
2588 | this.base(node); | ||
2589 | |||
2590 | this.blurRadius = Math.floor(this.attribute('stdDeviation').numValue()); | ||
2591 | this.extraFilterDistance = this.blurRadius; | ||
2592 | |||
2593 | this.apply = function(ctx, x, y, width, height) { | ||
2594 | if (typeof(stackBlurCanvasRGBA) == 'undefined') { | ||
2595 | if (typeof(console) != 'undefined') { console.log('ERROR: StackBlur.js must be included for blur to work'); } | ||
2596 | return; | ||
2597 | } | ||
2598 | |||
2599 | // StackBlur requires canvas be on document | ||
2600 | ctx.canvas.id = svg.UniqueId(); | ||
2601 | ctx.canvas.style.display = 'none'; | ||
2602 | document.body.appendChild(ctx.canvas); | ||
2603 | stackBlurCanvasRGBA(ctx.canvas.id, x, y, width, height, this.blurRadius); | ||
2604 | document.body.removeChild(ctx.canvas); | ||
2605 | } | ||
2606 | } | ||
2607 | svg.Element.feGaussianBlur.prototype = new svg.Element.ElementBase; | ||
2608 | |||
2609 | // title element, do nothing | ||
2610 | svg.Element.title = function(node) { | ||
2611 | } | ||
2612 | svg.Element.title.prototype = new svg.Element.ElementBase; | ||
2613 | |||
2614 | // desc element, do nothing | ||
2615 | svg.Element.desc = function(node) { | ||
2616 | } | ||
2617 | svg.Element.desc.prototype = new svg.Element.ElementBase; | ||
2618 | |||
2619 | svg.Element.MISSING = function(node) { | ||
2620 | if (typeof(console) != 'undefined') { console.log('ERROR: Element \'' + node.nodeName + '\' not yet implemented.'); } | ||
2621 | } | ||
2622 | svg.Element.MISSING.prototype = new svg.Element.ElementBase; | ||
2623 | |||
2624 | // element factory | ||
2625 | svg.CreateElement = function(node) { | ||
2626 | var className = node.nodeName.replace(/^[^:]+:/,''); // remove namespace | ||
2627 | className = className.replace(/\-/g,''); // remove dashes | ||
2628 | var e = null; | ||
2629 | if (typeof(svg.Element[className]) != 'undefined') { | ||
2630 | e = new svg.Element[className](node); | ||
2631 | } | ||
2632 | else { | ||
2633 | e = new svg.Element.MISSING(node); | ||
2634 | } | ||
2635 | |||
2636 | e.type = node.nodeName; | ||
2637 | return e; | ||
2638 | } | ||
2639 | |||
2640 | // load from url | ||
2641 | svg.load = function(ctx, url) { | ||
2642 | svg.loadXml(ctx, svg.ajax(url)); | ||
2643 | } | ||
2644 | |||
2645 | // load from xml | ||
2646 | svg.loadXml = function(ctx, xml) { | ||
2647 | svg.loadXmlDoc(ctx, svg.parseXml(xml)); | ||
2648 | } | ||
2649 | |||
2650 | svg.loadXmlDoc = function(ctx, dom) { | ||
2651 | svg.init(ctx); | ||
2652 | |||
2653 | var mapXY = function(p) { | ||
2654 | var e = ctx.canvas; | ||
2655 | while (e) { | ||
2656 | p.x -= e.offsetLeft; | ||
2657 | p.y -= e.offsetTop; | ||
2658 | e = e.offsetParent; | ||
2659 | } | ||
2660 | if (window.scrollX) p.x += window.scrollX; | ||
2661 | if (window.scrollY) p.y += window.scrollY; | ||
2662 | return p; | ||
2663 | } | ||
2664 | |||
2665 | // bind mouse | ||
2666 | if (svg.opts['ignoreMouse'] != true) { | ||
2667 | ctx.canvas.onclick = function(e) { | ||
2668 | var p = mapXY(new svg.Point(e != null ? e.clientX : event.clientX, e != null ? e.clientY : event.clientY)); | ||
2669 | svg.Mouse.onclick(p.x, p.y); | ||
2670 | }; | ||
2671 | ctx.canvas.onmousemove = function(e) { | ||
2672 | var p = mapXY(new svg.Point(e != null ? e.clientX : event.clientX, e != null ? e.clientY : event.clientY)); | ||
2673 | svg.Mouse.onmousemove(p.x, p.y); | ||
2674 | }; | ||
2675 | } | ||
2676 | |||
2677 | var e = svg.CreateElement(dom.documentElement); | ||
2678 | e.root = true; | ||
2679 | |||
2680 | // render loop | ||
2681 | var isFirstRender = true; | ||
2682 | var draw = function() { | ||
2683 | svg.ViewPort.Clear(); | ||
2684 | if (ctx.canvas.parentNode) svg.ViewPort.SetCurrent(ctx.canvas.parentNode.clientWidth, ctx.canvas.parentNode.clientHeight); | ||
2685 | |||
2686 | if (svg.opts['ignoreDimensions'] != true) { | ||
2687 | // set canvas size | ||
2688 | if (e.style('width').hasValue()) { | ||
2689 | ctx.canvas.width = e.style('width').toPixels('x'); | ||
2690 | ctx.canvas.style.width = ctx.canvas.width + 'px'; | ||
2691 | } | ||
2692 | if (e.style('height').hasValue()) { | ||
2693 | ctx.canvas.height = e.style('height').toPixels('y'); | ||
2694 | ctx.canvas.style.height = ctx.canvas.height + 'px'; | ||
2695 | } | ||
2696 | } | ||
2697 | var cWidth = ctx.canvas.clientWidth || ctx.canvas.width; | ||
2698 | var cHeight = ctx.canvas.clientHeight || ctx.canvas.height; | ||
2699 | if (svg.opts['ignoreDimensions'] == true && e.style('width').hasValue() && e.style('height').hasValue()) { | ||
2700 | cWidth = e.style('width').toPixels('x'); | ||
2701 | cHeight = e.style('height').toPixels('y'); | ||
2702 | } | ||
2703 | svg.ViewPort.SetCurrent(cWidth, cHeight); | ||
2704 | |||
2705 | if (svg.opts['offsetX'] != null) e.attribute('x', true).value = svg.opts['offsetX']; | ||
2706 | if (svg.opts['offsetY'] != null) e.attribute('y', true).value = svg.opts['offsetY']; | ||
2707 | if (svg.opts['scaleWidth'] != null && svg.opts['scaleHeight'] != null) { | ||
2708 | var xRatio = 1, yRatio = 1, viewBox = svg.ToNumberArray(e.attribute('viewBox').value); | ||
2709 | if (e.attribute('width').hasValue()) xRatio = e.attribute('width').toPixels('x') / svg.opts['scaleWidth']; | ||
2710 | else if (!isNaN(viewBox[2])) xRatio = viewBox[2] / svg.opts['scaleWidth']; | ||
2711 | if (e.attribute('height').hasValue()) yRatio = e.attribute('height').toPixels('y') / svg.opts['scaleHeight']; | ||
2712 | else if (!isNaN(viewBox[3])) yRatio = viewBox[3] / svg.opts['scaleHeight']; | ||
2713 | |||
2714 | e.attribute('width', true).value = svg.opts['scaleWidth']; | ||
2715 | e.attribute('height', true).value = svg.opts['scaleHeight']; | ||
2716 | e.attribute('viewBox', true).value = '0 0 ' + (cWidth * xRatio) + ' ' + (cHeight * yRatio); | ||
2717 | e.attribute('preserveAspectRatio', true).value = 'none'; | ||
2718 | } | ||
2719 | |||
2720 | // clear and render | ||
2721 | if (svg.opts['ignoreClear'] != true) { | ||
2722 | ctx.clearRect(0, 0, cWidth, cHeight); | ||
2723 | } | ||
2724 | e.render(ctx); | ||
2725 | if (isFirstRender) { | ||
2726 | isFirstRender = false; | ||
2727 | if (typeof(svg.opts['renderCallback']) == 'function') svg.opts['renderCallback'](dom); | ||
2728 | } | ||
2729 | } | ||
2730 | |||
2731 | var waitingForImages = true; | ||
2732 | if (svg.ImagesLoaded()) { | ||
2733 | waitingForImages = false; | ||
2734 | draw(); | ||
2735 | } | ||
2736 | svg.intervalID = setInterval(function() { | ||
2737 | var needUpdate = false; | ||
2738 | |||
2739 | if (waitingForImages && svg.ImagesLoaded()) { | ||
2740 | waitingForImages = false; | ||
2741 | needUpdate = true; | ||
2742 | } | ||
2743 | |||
2744 | // need update from mouse events? | ||
2745 | if (svg.opts['ignoreMouse'] != true) { | ||
2746 | needUpdate = needUpdate | svg.Mouse.hasEvents(); | ||
2747 | } | ||
2748 | |||
2749 | // need update from animations? | ||
2750 | if (svg.opts['ignoreAnimation'] != true) { | ||
2751 | for (var i=0; i<svg.Animations.length; i++) { | ||
2752 | needUpdate = needUpdate | svg.Animations[i].update(1000 / svg.FRAMERATE); | ||
2753 | } | ||
2754 | } | ||
2755 | |||
2756 | // need update from redraw? | ||
2757 | if (typeof(svg.opts['forceRedraw']) == 'function') { | ||
2758 | if (svg.opts['forceRedraw']() == true) needUpdate = true; | ||
2759 | } | ||
2760 | |||
2761 | // render if needed | ||
2762 | if (needUpdate) { | ||
2763 | draw(); | ||
2764 | svg.Mouse.runEvents(); // run and clear our events | ||
2765 | } | ||
2766 | }, 1000 / svg.FRAMERATE); | ||
2767 | } | ||
2768 | |||
2769 | svg.stop = function() { | ||
2770 | if (svg.intervalID) { | ||
2771 | clearInterval(svg.intervalID); | ||
2772 | } | ||
2773 | } | ||
2774 | |||
2775 | svg.Mouse = new (function() { | ||
2776 | this.events = []; | ||
2777 | this.hasEvents = function() { return this.events.length != 0; } | ||
2778 | |||
2779 | this.onclick = function(x, y) { | ||
2780 | this.events.push({ type: 'onclick', x: x, y: y, | ||
2781 | run: function(e) { if (e.onclick) e.onclick(); } | ||
2782 | }); | ||
2783 | } | ||
2784 | |||
2785 | this.onmousemove = function(x, y) { | ||
2786 | this.events.push({ type: 'onmousemove', x: x, y: y, | ||
2787 | run: function(e) { if (e.onmousemove) e.onmousemove(); } | ||
2788 | }); | ||
2789 | } | ||
2790 | |||
2791 | this.eventElements = []; | ||
2792 | |||
2793 | this.checkPath = function(element, ctx) { | ||
2794 | for (var i=0; i<this.events.length; i++) { | ||
2795 | var e = this.events[i]; | ||
2796 | if (ctx.isPointInPath && ctx.isPointInPath(e.x, e.y)) this.eventElements[i] = element; | ||
2797 | } | ||
2798 | } | ||
2799 | |||
2800 | this.checkBoundingBox = function(element, bb) { | ||
2801 | for (var i=0; i<this.events.length; i++) { | ||
2802 | var e = this.events[i]; | ||
2803 | if (bb.isPointInBox(e.x, e.y)) this.eventElements[i] = element; | ||
2804 | } | ||
2805 | } | ||
2806 | |||
2807 | this.runEvents = function() { | ||
2808 | svg.ctx.canvas.style.cursor = ''; | ||
2809 | |||
2810 | for (var i=0; i<this.events.length; i++) { | ||
2811 | var e = this.events[i]; | ||
2812 | var element = this.eventElements[i]; | ||
2813 | while (element) { | ||
2814 | e.run(element); | ||
2815 | element = element.parent; | ||
2816 | } | ||
2817 | } | ||
2818 | |||
2819 | // done running, clear | ||
2820 | this.events = []; | ||
2821 | this.eventElements = []; | ||
2822 | } | ||
2823 | }); | ||
2824 | |||
2825 | return svg; | ||
2826 | } | ||
2827 | })(); | ||
2828 | |||
2829 | if (typeof(CanvasRenderingContext2D) != 'undefined') { | ||
2830 | CanvasRenderingContext2D.prototype.drawSvg = function(s, dx, dy, dw, dh) { | ||
2831 | canvg(this.canvas, s, { | ||
2832 | ignoreMouse: true, | ||
2833 | ignoreAnimation: true, | ||
2834 | ignoreDimensions: true, | ||
2835 | ignoreClear: true, | ||
2836 | offsetX: dx, | ||
2837 | offsetY: dy, | ||
2838 | scaleWidth: dw, | ||
2839 | scaleHeight: dh | ||
2840 | }); | ||
2841 | } | ||
2842 | } |
amcharts/exporting/filesaver.js
File was created | 1 | /* FileSaver.js | |
2 | * A saveAs() FileSaver implementation. | ||
3 | * 2013-10-21 | ||
4 | * | ||
5 | * By Eli Grey, http://eligrey.com | ||
6 | * License: X11/MIT | ||
7 | * See LICENSE.md | ||
8 | */ | ||
9 | |||
10 | /*global self */ | ||
11 | /*jslint bitwise: true, regexp: true, confusion: true, es5: true, vars: true, white: true, | ||
12 | plusplus: true */ | ||
13 | |||
14 | /*! @source http://purl.eligrey.com/github/FileSaver.js/blob/master/FileSaver.js */ | ||
15 | if(AmCharts.isModern){ /// added by AmCharts to avoid old IE problems if this file is included | ||
16 | var saveAs = saveAs | ||
17 | || (typeof navigator !== 'undefined' && navigator.msSaveOrOpenBlob && navigator.msSaveOrOpenBlob.bind(navigator)) | ||
18 | || (function(view) { | ||
19 | "use strict"; | ||
20 | var | ||
21 | doc = view.document | ||
22 | // only get URL when necessary in case BlobBuilder.js hasn't overridden it yet | ||
23 | , get_URL = function() { | ||
24 | return view.URL || view.webkitURL || view; | ||
25 | } | ||
26 | , URL = view.URL || view.webkitURL || view | ||
27 | , save_link = doc.createElementNS("http://www.w3.org/1999/xhtml", "a") | ||
28 | , can_use_save_link = !view.externalHost && "download" in save_link | ||
29 | , click = function(node) { | ||
30 | var event = doc.createEvent("MouseEvents"); | ||
31 | event.initMouseEvent( | ||
32 | "click", true, false, view, 0, 0, 0, 0, 0 | ||
33 | , false, false, false, false, 0, null | ||
34 | ); | ||
35 | node.dispatchEvent(event); | ||
36 | } | ||
37 | , webkit_req_fs = view.webkitRequestFileSystem | ||
38 | , req_fs = view.requestFileSystem || webkit_req_fs || view.mozRequestFileSystem | ||
39 | , throw_outside = function (ex) { | ||
40 | (view.setImmediate || view.setTimeout)(function() { | ||
41 | throw ex; | ||
42 | }, 0); | ||
43 | } | ||
44 | , force_saveable_type = "application/octet-stream" | ||
45 | , fs_min_size = 0 | ||
46 | , deletion_queue = [] | ||
47 | , process_deletion_queue = function() { | ||
48 | var i = deletion_queue.length; | ||
49 | while (i--) { | ||
50 | var file = deletion_queue[i]; | ||
51 | if (typeof file === "string") { // file is an object URL | ||
52 | URL.revokeObjectURL(file); | ||
53 | } else { // file is a File | ||
54 | file.remove(); | ||
55 | } | ||
56 | } | ||
57 | deletion_queue.length = 0; // clear queue | ||
58 | } | ||
59 | , dispatch = function(filesaver, event_types, event) { | ||
60 | event_types = [].concat(event_types); | ||
61 | var i = event_types.length; | ||
62 | while (i--) { | ||
63 | var listener = filesaver["on" + event_types[i]]; | ||
64 | if (typeof listener === "function") { | ||
65 | try { | ||
66 | listener.call(filesaver, event || filesaver); | ||
67 | } catch (ex) { | ||
68 | throw_outside(ex); | ||
69 | } | ||
70 | } | ||
71 | } | ||
72 | } | ||
73 | , FileSaver = function(blob, name) { | ||
74 | // First try a.download, then web filesystem, then object URLs | ||
75 | var | ||
76 | filesaver = this | ||
77 | , type = blob.type | ||
78 | , blob_changed = false | ||
79 | , object_url | ||
80 | , target_view | ||
81 | , get_object_url = function() { | ||
82 | var object_url = get_URL().createObjectURL(blob); | ||
83 | deletion_queue.push(object_url); | ||
84 | return object_url; | ||
85 | } | ||
86 | , dispatch_all = function() { | ||
87 | dispatch(filesaver, "writestart progress write writeend".split(" ")); | ||
88 | } | ||
89 | // on any filesys errors revert to saving with object URLs | ||
90 | , fs_error = function() { | ||
91 | // don't create more object URLs than needed | ||
92 | if (blob_changed || !object_url) { | ||
93 | object_url = get_object_url(blob); | ||
94 | } | ||
95 | if (target_view) { | ||
96 | target_view.location.href = object_url; | ||
97 | } else { | ||
98 | window.open(object_url, "_blank"); | ||
99 | } | ||
100 | filesaver.readyState = filesaver.DONE; | ||
101 | dispatch_all(); | ||
102 | } | ||
103 | , abortable = function(func) { | ||
104 | return function() { | ||
105 | if (filesaver.readyState !== filesaver.DONE) { | ||
106 | return func.apply(this, arguments); | ||
107 | } | ||
108 | }; | ||
109 | } | ||
110 | , create_if_not_found = {create: true, exclusive: false} | ||
111 | , slice | ||
112 | ; | ||
113 | filesaver.readyState = filesaver.INIT; | ||
114 | if (!name) { | ||
115 | name = "download"; | ||
116 | } | ||
117 | if (can_use_save_link) { | ||
118 | object_url = get_object_url(blob); | ||
119 | // FF for Android has a nasty garbage collection mechanism | ||
120 | // that turns all objects that are not pure javascript into 'deadObject' | ||
121 | // this means `doc` and `save_link` are unusable and need to be recreated | ||
122 | // `view` is usable though: | ||
123 | doc = view.document; | ||
124 | save_link = doc.createElementNS("http://www.w3.org/1999/xhtml", "a"); | ||
125 | save_link.href = object_url; | ||
126 | save_link.download = name; | ||
127 | var event = doc.createEvent("MouseEvents"); | ||
128 | event.initMouseEvent( | ||
129 | "click", true, false, view, 0, 0, 0, 0, 0 | ||
130 | , false, false, false, false, 0, null | ||
131 | ); | ||
132 | save_link.dispatchEvent(event); | ||
133 | filesaver.readyState = filesaver.DONE; | ||
134 | dispatch_all(); | ||
135 | return; | ||
136 | } | ||
137 | // Object and web filesystem URLs have a problem saving in Google Chrome when | ||
138 | // viewed in a tab, so I force save with application/octet-stream | ||
139 | // http://code.google.com/p/chromium/issues/detail?id=91158 | ||
140 | if (view.chrome && type && type !== force_saveable_type) { | ||
141 | slice = blob.slice || blob.webkitSlice; | ||
142 | blob = slice.call(blob, 0, blob.size, force_saveable_type); | ||
143 | blob_changed = true; | ||
144 | } | ||
145 | // Since I can't be sure that the guessed media type will trigger a download | ||
146 | // in WebKit, I append .download to the filename. | ||
147 | // https://bugs.webkit.org/show_bug.cgi?id=65440 | ||
148 | if (webkit_req_fs && name !== "download") { | ||
149 | name += ".download"; | ||
150 | } | ||
151 | if (type === force_saveable_type || webkit_req_fs) { | ||
152 | target_view = view; | ||
153 | } | ||
154 | if (!req_fs) { | ||
155 | fs_error(); | ||
156 | return; | ||
157 | } | ||
158 | fs_min_size += blob.size; | ||
159 | req_fs(view.TEMPORARY, fs_min_size, abortable(function(fs) { | ||
160 | fs.root.getDirectory("saved", create_if_not_found, abortable(function(dir) { | ||
161 | var save = function() { | ||
162 | dir.getFile(name, create_if_not_found, abortable(function(file) { | ||
163 | file.createWriter(abortable(function(writer) { | ||
164 | writer.onwriteend = function(event) { | ||
165 | target_view.location.href = file.toURL(); | ||
166 | deletion_queue.push(file); | ||
167 | filesaver.readyState = filesaver.DONE; | ||
168 | dispatch(filesaver, "writeend", event); | ||
169 | }; | ||
170 | writer.onerror = function() { | ||
171 | var error = writer.error; | ||
172 | if (error.code !== error.ABORT_ERR) { | ||
173 | fs_error(); | ||
174 | } | ||
175 | }; | ||
176 | "writestart progress write abort".split(" ").forEach(function(event) { | ||
177 | writer["on" + event] = filesaver["on" + event]; | ||
178 | }); | ||
179 | writer.write(blob); | ||
180 | filesaver.abort = function() { | ||
181 | writer.abort(); | ||
182 | filesaver.readyState = filesaver.DONE; | ||
183 | }; | ||
184 | filesaver.readyState = filesaver.WRITING; | ||
185 | }), fs_error); | ||
186 | }), fs_error); | ||
187 | }; | ||
188 | dir.getFile(name, {create: false}, abortable(function(file) { | ||
189 | // delete file if it already exists | ||
190 | file.remove(); | ||
191 | save(); | ||
192 | }), abortable(function(ex) { | ||
193 | if (ex.code === ex.NOT_FOUND_ERR) { | ||
194 | save(); | ||
195 | } else { | ||
196 | fs_error(); | ||
197 | } | ||
198 | })); | ||
199 | }), fs_error); | ||
200 | }), fs_error); | ||
201 | } | ||
202 | , FS_proto = FileSaver.prototype | ||
203 | , saveAs = function(blob, name) { | ||
204 | return new FileSaver(blob, name); | ||
205 | } | ||
206 | ; | ||
207 | FS_proto.abort = function() { | ||
208 | var filesaver = this; | ||
209 | filesaver.readyState = filesaver.DONE; | ||
210 | dispatch(filesaver, "abort"); | ||
211 | }; | ||
212 | FS_proto.readyState = FS_proto.INIT = 0; | ||
213 | FS_proto.WRITING = 1; | ||
214 | FS_proto.DONE = 2; | ||
215 | |||
216 | FS_proto.error = | ||
217 | FS_proto.onwritestart = | ||
218 | FS_proto.onprogress = | ||
219 | FS_proto.onwrite = | ||
220 | FS_proto.onabort = | ||
221 | FS_proto.onerror = | ||
222 | FS_proto.onwriteend = | ||
223 | null; | ||
224 | |||
225 | view.addEventListener("unload", process_deletion_queue, false); | ||
226 | return saveAs; | ||
227 | }(this.self || this.window || this.content)); | ||
228 | // `self` is undefined in Firefox for Android content script context | ||
229 | // while `this` is nsIContentFrameMessageManager | ||
230 | // with an attribute `content` that corresponds to the window | ||
231 | |||
232 | if (typeof module !== 'undefined') module.exports = saveAs; | ||
233 | }/// added by AmCharts to avoid old IE problems if this file is included |
amcharts/exporting/jspdf.js
File was created | 1 | /** @preserve jsPDF 0.9.0rc2 ( ${buildDate} ${commitID} ) | |
2 | Copyright (c) 2010-2012 James Hall, james@snapshotmedia.co.uk, https://github.com/MrRio/jsPDF | ||
3 | Copyright (c) 2012 Willow Systems Corporation, willow-systems.com | ||
4 | MIT license. | ||
5 | */ | ||
6 | |||
7 | /* | ||
8 | * Permission is hereby granted, free of charge, to any person obtaining | ||
9 | * a copy of this software and associated documentation files (the | ||
10 | * "Software"), to deal in the Software without restriction, including | ||
11 | * without limitation the rights to use, copy, modify, merge, publish, | ||
12 | * distribute, sublicense, and/or sell copies of the Software, and to | ||
13 | * permit persons to whom the Software is furnished to do so, subject to | ||
14 | * the following conditions: | ||
15 | * | ||
16 | * The above copyright notice and this permission notice shall be | ||
17 | * included in all copies or substantial portions of the Software. | ||
18 | * | ||
19 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | ||
20 | * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | ||
21 | * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND | ||
22 | * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE | ||
23 | * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION | ||
24 | * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION | ||
25 | * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||
26 | * ==================================================================== | ||
27 | */ | ||
28 | |||
29 | |||
30 | /** | ||
31 | Creates new jsPDF document object instance | ||
32 | @class | ||
33 | @param orientation One of "portrait" or "landscape" (or shortcuts "p" (Default), "l") | ||
34 | @param unit Measurement unit to be used when coordinates are specified. One of "pt" (points), "mm" (Default), "cm", "in" | ||
35 | @param format One of 'a0', 'a1', 'a2', 'a3', 'a4' (Default) etc to 'a10', 'b0' to 'b10', 'c0' to 'c10', 'letter', 'government-letter', 'legal', 'junior-legal', 'ledger' or 'tabloid' | ||
36 | @returns {jsPDF} | ||
37 | @name jsPDF | ||
38 | */ | ||
39 | var jsPDF = (function () { | ||
40 | 'use strict'; | ||
41 | /*jslint browser:true, plusplus: true, bitwise: true, nomen: true */ | ||
42 | /*global document: false, btoa, atob, zpipe, Uint8Array, ArrayBuffer, Blob, saveAs, adler32cs, Deflater */ | ||
43 | |||
44 | // this will run on <=IE9, possibly some niche browsers | ||
45 | // new webkit-based, FireFox, IE10 already have native version of this. | ||
46 | if (typeof btoa === 'undefined') { | ||
47 | window.btoa = function (data) { | ||
48 | // DO NOT ADD UTF8 ENCODING CODE HERE!!!! | ||
49 | |||
50 | // UTF8 encoding encodes bytes over char code 128 | ||
51 | // and, essentially, turns an 8-bit binary streams | ||
52 | // (that base64 can deal with) into 7-bit binary streams. | ||
53 | // (by default server does not know that and does not recode the data back to 8bit) | ||
54 | // You destroy your data. | ||
55 | |||
56 | // binary streams like jpeg image data etc, while stored in JavaScript strings, | ||
57 | // (which are 16bit arrays) are in 8bit format already. | ||
58 | // You do NOT need to char-encode that before base64 encoding. | ||
59 | |||
60 | // if you, by act of fate | ||
61 | // have string which has individual characters with code | ||
62 | // above 255 (pure unicode chars), encode that BEFORE you base64 here. | ||
63 | // you can use absolutely any approch there, as long as in the end, | ||
64 | // base64 gets an 8bit (char codes 0 - 255) stream. | ||
65 | // when you get it on the server after un-base64, you must | ||
66 | // UNencode it too, to get back to 16, 32bit or whatever original bin stream. | ||
67 | |||
68 | // Note, Yes, JavaScript strings are, in most cases UCS-2 - | ||
69 | // 16-bit character arrays. This does not mean, however, | ||
70 | // that you always have to UTF8 it before base64. | ||
71 | // it means that if you have actual characters anywhere in | ||
72 | // that string that have char code above 255, you need to | ||
73 | // recode *entire* string from 16-bit (or 32bit) to 8-bit array. | ||
74 | // You can do binary split to UTF16 (BE or LE) | ||
75 | // you can do utf8, you can split the thing by hand and prepend BOM to it, | ||
76 | // but whatever you do, make sure you mirror the opposite on | ||
77 | // the server. If server does not expect to post-process un-base64 | ||
78 | // 8-bit binary stream, think very very hard about messing around with encoding. | ||
79 | |||
80 | // so, long story short: | ||
81 | // DO NOT ADD UTF8 ENCODING CODE HERE!!!! | ||
82 | |||
83 | /* @preserve | ||
84 | ==================================================================== | ||
85 | base64 encoder | ||
86 | MIT, GPL | ||
87 | |||
88 | version: 1109.2015 | ||
89 | discuss at: http://phpjs.org/functions/base64_encode | ||
90 | + original by: Tyler Akins (http://rumkin.com) | ||
91 | + improved by: Bayron Guevara | ||
92 | + improved by: Thunder.m | ||
93 | + improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net) | ||
94 | + bugfixed by: Pellentesque Malesuada | ||
95 | + improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net) | ||
96 | + improved by: Rafal Kukawski (http://kukawski.pl) | ||
97 | + Daniel Dotsenko, Willow Systems Corp, willow-systems.com | ||
98 | ==================================================================== | ||
99 | */ | ||
100 | |||
101 | var b64 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=", | ||
102 | b64a = b64.split(''), | ||
103 | o1, | ||
104 | o2, | ||
105 | o3, | ||
106 | h1, | ||
107 | h2, | ||
108 | h3, | ||
109 | h4, | ||
110 | bits, | ||
111 | i = 0, | ||
112 | ac = 0, | ||
113 | enc = "", | ||
114 | tmp_arr = [], | ||
115 | r; | ||
116 | |||
117 | do { // pack three octets into four hexets | ||
118 | o1 = data.charCodeAt(i++); | ||
119 | o2 = data.charCodeAt(i++); | ||
120 | o3 = data.charCodeAt(i++); | ||
121 | |||
122 | bits = o1 << 16 | o2 << 8 | o3; | ||
123 | |||
124 | h1 = bits >> 18 & 0x3f; | ||
125 | h2 = bits >> 12 & 0x3f; | ||
126 | h3 = bits >> 6 & 0x3f; | ||
127 | h4 = bits & 0x3f; | ||
128 | |||
129 | // use hexets to index into b64, and append result to encoded string | ||
130 | tmp_arr[ac++] = b64a[h1] + b64a[h2] + b64a[h3] + b64a[h4]; | ||
131 | } while (i < data.length); | ||
132 | |||
133 | enc = tmp_arr.join(''); | ||
134 | r = data.length % 3; | ||
135 | return (r ? enc.slice(0, r - 3) : enc) + '==='.slice(r || 3); | ||
136 | // end of base64 encoder MIT, GPL | ||
137 | }; | ||
138 | } | ||
139 | |||
140 | if (typeof atob === 'undefined') { | ||
141 | window.atob = function (data) { | ||
142 | // http://kevin.vanzonneveld.net | ||
143 | // + original by: Tyler Akins (http://rumkin.com) | ||
144 | // + improved by: Thunder.m | ||
145 | // + input by: Aman Gupta | ||
146 | // + improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net) | ||
147 | // + bugfixed by: Onno Marsman | ||
148 | // + bugfixed by: Pellentesque Malesuada | ||
149 | // + improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net) | ||
150 | // + input by: Brett Zamir (http://brett-zamir.me) | ||
151 | // + bugfixed by: Kevin van Zonneveld (http://kevin.vanzonneveld.net) | ||
152 | // * example 1: base64_decode('S2V2aW4gdmFuIFpvbm5ldmVsZA=='); | ||
153 | // * returns 1: 'Kevin van Zonneveld' | ||
154 | // mozilla has this native | ||
155 | // - but breaks in 2.0.0.12! | ||
156 | //if (typeof this.window['atob'] == 'function') { | ||
157 | // return atob(data); | ||
158 | //} | ||
159 | var b64 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=", | ||
160 | o1, | ||
161 | o2, | ||
162 | o3, | ||
163 | h1, | ||
164 | h2, | ||
165 | h3, | ||
166 | h4, | ||
167 | bits, | ||
168 | i = 0, | ||
169 | ac = 0, | ||
170 | dec = "", | ||
171 | tmp_arr = []; | ||
172 | |||
173 | if (!data) { | ||
174 | return data; | ||
175 | } | ||
176 | |||
177 | data += ''; | ||
178 | |||
179 | do { // unpack four hexets into three octets using index points in b64 | ||
180 | h1 = b64.indexOf(data.charAt(i++)); | ||
181 | h2 = b64.indexOf(data.charAt(i++)); | ||
182 | h3 = b64.indexOf(data.charAt(i++)); | ||
183 | h4 = b64.indexOf(data.charAt(i++)); | ||
184 | |||
185 | bits = h1 << 18 | h2 << 12 | h3 << 6 | h4; | ||
186 | |||
187 | o1 = bits >> 16 & 0xff; | ||
188 | o2 = bits >> 8 & 0xff; | ||
189 | o3 = bits & 0xff; | ||
190 | |||
191 | if (h3 === 64) { | ||
192 | tmp_arr[ac++] = String.fromCharCode(o1); | ||
193 | } else if (h4 === 64) { | ||
194 | tmp_arr[ac++] = String.fromCharCode(o1, o2); | ||
195 | } else { | ||
196 | tmp_arr[ac++] = String.fromCharCode(o1, o2, o3); | ||
197 | } | ||
198 | } while (i < data.length); | ||
199 | dec = tmp_arr.join(''); | ||
200 | return dec; | ||
201 | }; | ||
202 | } | ||
203 | |||
204 | var getObjectLength = typeof Object.keys === 'function' ? | ||
205 | function (object) { | ||
206 | return Object.keys(object).length; | ||
207 | } : | ||
208 | function (object) { | ||
209 | var i = 0, e; | ||
210 | for (e in object) { | ||
211 | if (object.hasOwnProperty(e)) { | ||
212 | i++; | ||
213 | } | ||
214 | } | ||
215 | return i; | ||
216 | }, | ||
217 | |||
218 | /** | ||
219 | PubSub implementation | ||
220 | |||
221 | @class | ||
222 | @name PubSub | ||
223 | */ | ||
224 | PubSub = function (context) { | ||
225 | /** @preserve | ||
226 | ----------------------------------------------------------------------------------------------- | ||
227 | JavaScript PubSub library | ||
228 | 2012 (c) ddotsenko@willowsystems.com | ||
229 | based on Peter Higgins (dante@dojotoolkit.org) | ||
230 | Loosely based on Dojo publish/subscribe API, limited in scope. Rewritten blindly. | ||
231 | Original is (c) Dojo Foundation 2004-2010. Released under either AFL or new BSD, see: | ||
232 | http://dojofoundation.org/license for more information. | ||
233 | ----------------------------------------------------------------------------------------------- | ||
234 | */ | ||
235 | /** | ||
236 | @private | ||
237 | @fieldOf PubSub | ||
238 | */ | ||
239 | this.topics = {}; | ||
240 | /** | ||
241 | Stores what will be `this` within the callback functions. | ||
242 | |||
243 | @private | ||
244 | @fieldOf PubSub# | ||
245 | */ | ||
246 | this.context = context; | ||
247 | /** | ||
248 | Allows caller to emit an event and pass arguments to event listeners. | ||
249 | @public | ||
250 | @function | ||
251 | @param topic {String} Name of the channel on which to voice this event | ||
252 | @param args Any number of arguments you want to pass to the listeners of this event. | ||
253 | @methodOf PubSub# | ||
254 | @name publish | ||
255 | */ | ||
256 | this.publish = function (topic, args) { | ||
257 | if (this.topics[topic]) { | ||
258 | var currentTopic = this.topics[topic], | ||
259 | toremove = [], | ||
260 | fn, | ||
261 | i, | ||
262 | l, | ||
263 | pair, | ||
264 | emptyFunc = function () {}; | ||
265 | args = Array.prototype.slice.call(arguments, 1); | ||
266 | for (i = 0, l = currentTopic.length; i < l; i++) { | ||
267 | pair = currentTopic[i]; // this is a [function, once_flag] array | ||
268 | fn = pair[0]; | ||
269 | if (pair[1]) { /* 'run once' flag set */ | ||
270 | pair[0] = emptyFunc; | ||
271 | toremove.push(i); | ||
272 | } | ||
273 | fn.apply(this.context, args); | ||
274 | } | ||
275 | for (i = 0, l = toremove.length; i < l; i++) { | ||
276 | currentTopic.splice(toremove[i], 1); | ||
277 | } | ||
278 | } | ||
279 | }; | ||
280 | /** | ||
281 | Allows listener code to subscribe to channel and be called when data is available | ||
282 | @public | ||
283 | @function | ||
284 | @param topic {String} Name of the channel on which to voice this event | ||
285 | @param callback {Function} Executable (function pointer) that will be ran when event is voiced on this channel. | ||
286 | @param once {Boolean} (optional. False by default) Flag indicating if the function is to be triggered only once. | ||
287 | @returns {Object} A token object that cen be used for unsubscribing. | ||
288 | @methodOf PubSub# | ||
289 | @name subscribe | ||
290 | */ | ||
291 | this.subscribe = function (topic, callback, once) { | ||
292 | if (!this.topics[topic]) { | ||
293 | this.topics[topic] = [[callback, once]]; | ||
294 | } else { | ||
295 | this.topics[topic].push([callback, once]); | ||
296 | } | ||
297 | return { | ||
298 | "topic": topic, | ||
299 | "callback": callback | ||
300 | }; | ||
301 | }; | ||
302 | /** | ||
303 | Allows listener code to unsubscribe from a channel | ||
304 | @public | ||
305 | @function | ||
306 | @param token {Object} A token object that was returned by `subscribe` method | ||
307 | @methodOf PubSub# | ||
308 | @name unsubscribe | ||
309 | */ | ||
310 | this.unsubscribe = function (token) { | ||
311 | if (this.topics[token.topic]) { | ||
312 | var currentTopic = this.topics[token.topic], i, l; | ||
313 | |||
314 | for (i = 0, l = currentTopic.length; i < l; i++) { | ||
315 | if (currentTopic[i][0] === token.callback) { | ||
316 | currentTopic.splice(i, 1); | ||
317 | } | ||
318 | } | ||
319 | } | ||
320 | }; | ||
321 | }; | ||
322 | |||
323 | |||
324 | /** | ||
325 | @constructor | ||
326 | @private | ||
327 | */ | ||
328 | function jsPDF(orientation, unit, format, compressPdf) { /** String orientation, String unit, String format, Boolean compressed */ | ||
329 | |||
330 | // Default parameter values | ||
331 | if (typeof orientation === 'undefined') { | ||
332 | orientation = 'p'; | ||
333 | } else { | ||
334 | orientation = orientation.toString().toLowerCase(); | ||
335 | } | ||
336 | if (typeof unit === 'undefined') { unit = 'mm'; } | ||
337 | if (typeof format === 'undefined') { format = 'a4'; } | ||
338 | if (typeof compressPdf === 'undefined' && typeof zpipe === 'undefined') { compressPdf = false; } | ||
339 | |||
340 | var format_as_string = format.toString().toLowerCase(), | ||
341 | version = '0.9.0rc2', | ||
342 | content = [], | ||
343 | content_length = 0, | ||
344 | compress = compressPdf, | ||
345 | pdfVersion = '1.3', // PDF Version | ||
346 | pageFormats = { // Size in pt of various paper formats | ||
347 | 'a0': [2383.94, 3370.39], | ||
348 | 'a1': [1683.78, 2383.94], | ||
349 | 'a2': [1190.55, 1683.78], | ||
350 | 'a3': [841.89, 1190.55], | ||
351 | 'a4': [595.28, 841.89], | ||
352 | 'a5': [419.53, 595.28], | ||
353 | 'a6': [297.64, 419.53], | ||
354 | 'a7': [209.76, 297.64], | ||
355 | 'a8': [147.4 , 209.76], | ||
356 | 'a9': [104.88, 147.4], | ||
357 | 'a10': [73.7, 104.88], | ||
358 | 'b0': [2834.65, 4008.19], | ||
359 | 'b1': [2004.09, 2834.65], | ||
360 | 'b2': [1417.32, 2004.09], | ||
361 | 'b3': [1000.63, 1417.32], | ||
362 | 'b4': [708.66, 1000.63], | ||
363 | 'b5': [498.9, 708.66], | ||
364 | 'b6': [354.33, 498.9], | ||
365 | 'b7': [249.45, 354.33], | ||
366 | 'b8': [175.75, 249.45], | ||
367 | 'b9': [124.72, 175.75], | ||
368 | 'b10': [87.87, 124.72], | ||
369 | 'c0': [2599.37, 3676.54], | ||
370 | 'c1': [1836.85, 2599.37], | ||
371 | 'c2': [1298.27, 1836.85], | ||
372 | 'c3': [918.43, 1298.27], | ||
373 | 'c4': [649.13, 918.43], | ||
374 | 'c5': [459.21, 649.13], | ||
375 | 'c6': [323.15, 459.21], | ||
376 | 'c7': [229.61, 323.15], | ||
377 | 'c8': [161.57, 229.61], | ||
378 | 'c9': [113.39, 161.57], | ||
379 | 'c10': [79.37, 113.39], | ||
380 | 'letter': [612, 792], | ||
381 | 'government-letter': [576, 756], | ||
382 | 'legal': [612, 1008], | ||
383 | 'junior-legal': [576, 360], | ||
384 | 'ledger': [1224, 792], | ||
385 | 'tabloid': [792, 1224] | ||
386 | }, | ||
387 | textColor = '0 g', | ||
388 | drawColor = '0 G', | ||
389 | page = 0, | ||
390 | pages = [], | ||
391 | objectNumber = 2, // 'n' Current object number | ||
392 | outToPages = false, // switches where out() prints. outToPages true = push to pages obj. outToPages false = doc builder content | ||
393 | offsets = [], // List of offsets. Activated and reset by buildDocument(). Pupulated by various calls buildDocument makes. | ||
394 | fonts = {}, // collection of font objects, where key is fontKey - a dynamically created label for a given font. | ||
395 | fontmap = {}, // mapping structure fontName > fontStyle > font key - performance layer. See addFont() | ||
396 | activeFontSize = 16, | ||
397 | activeFontKey, // will be string representing the KEY of the font as combination of fontName + fontStyle | ||
398 | lineWidth = 0.200025, // 2mm | ||
399 | lineHeightProportion = 1.15, | ||
400 | pageHeight, | ||
401 | pageWidth, | ||
402 | k, // Scale factor | ||
403 | documentProperties = {'title': '', 'subject': '', 'author': '', 'keywords': '', 'creator': ''}, | ||
404 | lineCapID = 0, | ||
405 | lineJoinID = 0, | ||
406 | API = {}, | ||
407 | events = new PubSub(API), | ||
408 | tmp, | ||
409 | plugin, | ||
410 | ///////////////////// | ||
411 | // Private functions | ||
412 | ///////////////////// | ||
413 | // simplified (speedier) replacement for sprintf's %.2f conversion | ||
414 | f2 = function (number) { | ||
415 | return number.toFixed(2); | ||
416 | }, | ||
417 | // simplified (speedier) replacement for sprintf's %.3f conversion | ||
418 | f3 = function (number) { | ||
419 | return number.toFixed(3); | ||
420 | }, | ||
421 | // simplified (speedier) replacement for sprintf's %02d | ||
422 | padd2 = function (number) { | ||
423 | var n = (number).toFixed(0); | ||
424 | if (number < 10) { | ||
425 | return '0' + n; | ||
426 | } else { | ||
427 | return n; | ||
428 | } | ||
429 | }, | ||
430 | // simplified (speedier) replacement for sprintf's %02d | ||
431 | padd10 = function (number) { | ||
432 | var n = (number).toFixed(0); | ||
433 | if (n.length < 10) { | ||
434 | return new Array( 11 - n.length ).join('0') + n; | ||
435 | } else { | ||
436 | return n; | ||
437 | } | ||
438 | }, | ||
439 | out = function (string) { | ||
440 | if (outToPages) { /* set by beginPage */ | ||
441 | pages[page].push(string); | ||
442 | } else { | ||
443 | content.push(string); | ||
444 | content_length += string.length + 1; // +1 is for '\n' that will be used to join contents of content | ||
445 | } | ||
446 | }, | ||
447 | newObject = function () { | ||
448 | // Begin a new object | ||
449 | objectNumber++; | ||
450 | offsets[objectNumber] = content_length; | ||
451 | out(objectNumber + ' 0 obj'); | ||
452 | return objectNumber; | ||
453 | }, | ||
454 | putStream = function (str) { | ||
455 | out('stream'); | ||
456 | out(str); | ||
457 | out('endstream'); | ||
458 | }, | ||
459 | wPt, | ||
460 | hPt, | ||
461 | kids, | ||
462 | i, | ||
463 | putPages = function () { | ||
464 | wPt = pageWidth * k; | ||
465 | hPt = pageHeight * k; | ||
466 | |||
467 | // outToPages = false as set in endDocument(). out() writes to content. | ||
468 | |||
469 | var n, p, arr, uint, i, deflater, adler32; | ||
470 | for (n = 1; n <= page; n++) { | ||
471 | newObject(); | ||
472 | out('<</Type /Page'); | ||
473 | out('/Parent 1 0 R'); | ||
474 | out('/Resources 2 0 R'); | ||
475 | out('/Contents ' + (objectNumber + 1) + ' 0 R>>'); | ||
476 | out('endobj'); | ||
477 | |||
478 | // Page content | ||
479 | p = pages[n].join('\n'); | ||
480 | newObject(); | ||
481 | if (compress) { | ||
482 | arr = []; | ||
483 | for (i = 0; i < p.length; ++i) { | ||
484 | arr[i] = p.charCodeAt(i); | ||
485 | } | ||
486 | adler32 = adler32cs.from(p); | ||
487 | deflater = new Deflater(6); | ||
488 | deflater.append(new Uint8Array(arr)); | ||
489 | p = deflater.flush(); | ||
490 | arr = [new Uint8Array([120, 156]), new Uint8Array(p), | ||
491 | new Uint8Array([adler32 & 0xFF, (adler32 >> 8) & 0xFF, (adler32 >> 16) & 0xFF, (adler32 >> 24) & 0xFF])]; | ||
492 | p = ''; | ||
493 | for (i in arr) { | ||
494 | if (arr.hasOwnProperty(i)) { | ||
495 | p += String.fromCharCode.apply(null, arr[i]); | ||
496 | } | ||
497 | } | ||
498 | out('<</Length ' + p.length + ' /Filter [/FlateDecode]>>'); | ||
499 | } else { | ||
500 | out('<</Length ' + p.length + '>>'); | ||
501 | } | ||
502 | putStream(p); | ||
503 | out('endobj'); | ||
504 | } | ||
505 | offsets[1] = content_length; | ||
506 | out('1 0 obj'); | ||
507 | out('<</Type /Pages'); | ||
508 | kids = '/Kids ['; | ||
509 | for (i = 0; i < page; i++) { | ||
510 | kids += (3 + 2 * i) + ' 0 R '; | ||
511 | } | ||
512 | out(kids + ']'); | ||
513 | out('/Count ' + page); | ||
514 | out('/MediaBox [0 0 ' + f2(wPt) + ' ' + f2(hPt) + ']'); | ||
515 | out('>>'); | ||
516 | out('endobj'); | ||
517 | }, | ||
518 | putFont = function (font) { | ||
519 | font.objectNumber = newObject(); | ||
520 | out('<</BaseFont/' + font.PostScriptName + '/Type/Font'); | ||
521 | if (typeof font.encoding === 'string') { | ||
522 | out('/Encoding/' + font.encoding); | ||
523 | } | ||
524 | out('/Subtype/Type1>>'); | ||
525 | out('endobj'); | ||
526 | }, | ||
527 | putFonts = function () { | ||
528 | var fontKey; | ||
529 | for (fontKey in fonts) { | ||
530 | if (fonts.hasOwnProperty(fontKey)) { | ||
531 | putFont(fonts[fontKey]); | ||
532 | } | ||
533 | } | ||
534 | }, | ||
535 | putXobjectDict = function () { | ||
536 | // Loop through images, or other data objects | ||
537 | events.publish('putXobjectDict'); | ||
538 | }, | ||
539 | putResourceDictionary = function () { | ||
540 | out('/ProcSet [/PDF /Text /ImageB /ImageC /ImageI]'); | ||
541 | out('/Font <<'); | ||
542 | // Do this for each font, the '1' bit is the index of the font | ||
543 | var fontKey; | ||
544 | for (fontKey in fonts) { | ||
545 | if (fonts.hasOwnProperty(fontKey)) { | ||
546 | out('/' + fontKey + ' ' + fonts[fontKey].objectNumber + ' 0 R'); | ||
547 | } | ||
548 | } | ||
549 | out('>>'); | ||
550 | out('/XObject <<'); | ||
551 | putXobjectDict(); | ||
552 | out('>>'); | ||
553 | }, | ||
554 | putResources = function () { | ||
555 | putFonts(); | ||
556 | events.publish('putResources'); | ||
557 | // Resource dictionary | ||
558 | offsets[2] = content_length; | ||
559 | out('2 0 obj'); | ||
560 | out('<<'); | ||
561 | putResourceDictionary(); | ||
562 | out('>>'); | ||
563 | out('endobj'); | ||
564 | events.publish('postPutResources'); | ||
565 | }, | ||
566 | addToFontDictionary = function (fontKey, fontName, fontStyle) { | ||
567 | // this is mapping structure for quick font key lookup. | ||
568 | // returns the KEY of the font (ex: "F1") for a given pair of font name and type (ex: "Arial". "Italic") | ||
569 | var undef; | ||
570 | if (fontmap[fontName] === undef) { | ||
571 | fontmap[fontName] = {}; // fontStyle is a var interpreted and converted to appropriate string. don't wrap in quotes. | ||
572 | } | ||
573 | fontmap[fontName][fontStyle] = fontKey; | ||
574 | }, | ||
575 | /** | ||
576 | FontObject describes a particular font as member of an instnace of jsPDF | ||
577 | |||
578 | It's a collection of properties like 'id' (to be used in PDF stream), | ||
579 | 'fontName' (font's family name), 'fontStyle' (font's style variant label) | ||
580 | |||
581 | @class | ||
582 | @public | ||
583 | @property id {String} PDF-document-instance-specific label assinged to the font. | ||
584 | @property PostScriptName {String} PDF specification full name for the font | ||
585 | @property encoding {Object} Encoding_name-to-Font_metrics_object mapping. | ||
586 | @name FontObject | ||
587 | */ | ||
588 | FontObject = {}, | ||
589 | addFont = function (PostScriptName, fontName, fontStyle, encoding) { | ||
590 | var fontKey = 'F' + (getObjectLength(fonts) + 1).toString(10), | ||
591 | // This is FontObject | ||
592 | font = fonts[fontKey] = { | ||
593 | 'id': fontKey, | ||
594 | // , 'objectNumber': will be set by putFont() | ||
595 | 'PostScriptName': PostScriptName, | ||
596 | 'fontName': fontName, | ||
597 | 'fontStyle': fontStyle, | ||
598 | 'encoding': encoding, | ||
599 | 'metadata': {} | ||
600 | }; | ||
601 | |||
602 | addToFontDictionary(fontKey, fontName, fontStyle); | ||
603 | |||
604 | events.publish('addFont', font); | ||
605 | |||
606 | return fontKey; | ||
607 | }, | ||
608 | addFonts = function () { | ||
609 | |||
610 | var HELVETICA = "helvetica", | ||
611 | TIMES = "times", | ||
612 | COURIER = "courier", | ||
613 | NORMAL = "normal", | ||
614 | BOLD = "bold", | ||
615 | ITALIC = "italic", | ||
616 | BOLD_ITALIC = "bolditalic", | ||
617 | encoding = 'StandardEncoding', | ||
618 | standardFonts = [ | ||
619 | ['Helvetica', HELVETICA, NORMAL], | ||
620 | ['Helvetica-Bold', HELVETICA, BOLD], | ||
621 | ['Helvetica-Oblique', HELVETICA, ITALIC], | ||
622 | ['Helvetica-BoldOblique', HELVETICA, BOLD_ITALIC], | ||
623 | ['Courier', COURIER, NORMAL], | ||
624 | ['Courier-Bold', COURIER, BOLD], | ||
625 | ['Courier-Oblique', COURIER, ITALIC], | ||
626 | ['Courier-BoldOblique', COURIER, BOLD_ITALIC], | ||
627 | ['Times-Roman', TIMES, NORMAL], | ||
628 | ['Times-Bold', TIMES, BOLD], | ||
629 | ['Times-Italic', TIMES, ITALIC], | ||
630 | ['Times-BoldItalic', TIMES, BOLD_ITALIC] | ||
631 | ], | ||
632 | i, | ||
633 | l, | ||
634 | fontKey, | ||
635 | parts; | ||
636 | for (i = 0, l = standardFonts.length; i < l; i++) { | ||
637 | fontKey = addFont( | ||
638 | standardFonts[i][0], | ||
639 | standardFonts[i][1], | ||
640 | standardFonts[i][2], | ||
641 | encoding | ||
642 | ); | ||
643 | |||
644 | // adding aliases for standard fonts, this time matching the capitalization | ||
645 | parts = standardFonts[i][0].split('-'); | ||
646 | addToFontDictionary(fontKey, parts[0], parts[1] || ''); | ||
647 | } | ||
648 | |||
649 | events.publish('addFonts', {'fonts': fonts, 'dictionary': fontmap}); | ||
650 | }, | ||
651 | /** | ||
652 | |||
653 | @public | ||
654 | @function | ||
655 | @param text {String} | ||
656 | @param flags {Object} Encoding flags. | ||
657 | @returns {String} Encoded string | ||
658 | */ | ||
659 | to8bitStream = function (text, flags) { | ||
660 | /* PDF 1.3 spec: | ||
661 | "For text strings encoded in Unicode, the first two bytes must be 254 followed by | ||
662 | 255, representing the Unicode byte order marker, U+FEFF. (This sequence conflicts | ||
663 | with the PDFDocEncoding character sequence thorn ydieresis, which is unlikely | ||
664 | to be a meaningful beginning of a word or phrase.) The remainder of the | ||
665 | string consists of Unicode character codes, according to the UTF-16 encoding | ||
666 | specified in the Unicode standard, version 2.0. Commonly used Unicode values | ||
667 | are represented as 2 bytes per character, with the high-order byte appearing first | ||
668 | in the string." | ||
669 | |||
670 | In other words, if there are chars in a string with char code above 255, we | ||
671 | recode the string to UCS2 BE - string doubles in length and BOM is prepended. | ||
672 | |||
673 | HOWEVER! | ||
674 | Actual *content* (body) text (as opposed to strings used in document properties etc) | ||
675 | does NOT expect BOM. There, it is treated as a literal GID (Glyph ID) | ||
676 | |||
677 | Because of Adobe's focus on "you subset your fonts!" you are not supposed to have | ||
678 | a font that maps directly Unicode (UCS2 / UTF16BE) code to font GID, but you could | ||
679 | fudge it with "Identity-H" encoding and custom CIDtoGID map that mimics Unicode | ||
680 | code page. There, however, all characters in the stream are treated as GIDs, | ||
681 | including BOM, which is the reason we need to skip BOM in content text (i.e. that | ||
682 | that is tied to a font). | ||
683 | |||
684 | To signal this "special" PDFEscape / to8bitStream handling mode, | ||
685 | API.text() function sets (unless you overwrite it with manual values | ||
686 | given to API.text(.., flags) ) | ||
687 | flags.autoencode = true | ||
688 | flags.noBOM = true | ||
689 | |||
690 | */ | ||
691 | |||
692 | /* | ||
693 | `flags` properties relied upon: | ||
694 | .sourceEncoding = string with encoding label. | ||
695 | "Unicode" by default. = encoding of the incoming text. | ||
696 | pass some non-existing encoding name | ||
697 | (ex: 'Do not touch my strings! I know what I am doing.') | ||
698 | to make encoding code skip the encoding step. | ||
699 | .outputEncoding = Either valid PDF encoding name | ||
700 | (must be supported by jsPDF font metrics, otherwise no encoding) | ||
701 | or a JS object, where key = sourceCharCode, value = outputCharCode | ||
702 | missing keys will be treated as: sourceCharCode === outputCharCode | ||
703 | .noBOM | ||
704 | See comment higher above for explanation for why this is important | ||
705 | .autoencode | ||
706 | See comment higher above for explanation for why this is important | ||
707 | */ | ||
708 | |||
709 | var i, l, undef, sourceEncoding, encodingBlock, outputEncoding, newtext, isUnicode, ch, bch; | ||
710 | |||
711 | if (flags === undef) { | ||
712 | flags = {}; | ||
713 | } | ||
714 | |||
715 | sourceEncoding = flags.sourceEncoding ? sourceEncoding : 'Unicode'; | ||
716 | |||
717 | outputEncoding = flags.outputEncoding; | ||
718 | |||
719 | // This 'encoding' section relies on font metrics format | ||
720 | // attached to font objects by, among others, | ||
721 | // "Willow Systems' standard_font_metrics plugin" | ||
722 | // see jspdf.plugin.standard_font_metrics.js for format | ||
723 | // of the font.metadata.encoding Object. | ||
724 | // It should be something like | ||
725 | // .encoding = {'codePages':['WinANSI....'], 'WinANSI...':{code:code, ...}} | ||
726 | // .widths = {0:width, code:width, ..., 'fof':divisor} | ||
727 | // .kerning = {code:{previous_char_code:shift, ..., 'fof':-divisor},...} | ||
728 | if ((flags.autoencode || outputEncoding) && | ||
729 | fonts[activeFontKey].metadata && | ||
730 | fonts[activeFontKey].metadata[sourceEncoding] && | ||
731 | fonts[activeFontKey].metadata[sourceEncoding].encoding | ||
732 | ) { | ||
733 | encodingBlock = fonts[activeFontKey].metadata[sourceEncoding].encoding; | ||
734 | |||
735 | // each font has default encoding. Some have it clearly defined. | ||
736 | if (!outputEncoding && fonts[activeFontKey].encoding) { | ||
737 | outputEncoding = fonts[activeFontKey].encoding; | ||
738 | } | ||
739 | |||
740 | // Hmmm, the above did not work? Let's try again, in different place. | ||
741 | if (!outputEncoding && encodingBlock.codePages) { | ||
742 | outputEncoding = encodingBlock.codePages[0]; // let's say, first one is the default | ||
743 | } | ||
744 | |||
745 | if (typeof outputEncoding === 'string') { | ||
746 | outputEncoding = encodingBlock[outputEncoding]; | ||
747 | } | ||
748 | // we want output encoding to be a JS Object, where | ||
749 | // key = sourceEncoding's character code and | ||
750 | // value = outputEncoding's character code. | ||
751 | if (outputEncoding) { | ||
752 | isUnicode = false; | ||
753 | newtext = []; | ||
754 | for (i = 0, l = text.length; i < l; i++) { | ||
755 | ch = outputEncoding[text.charCodeAt(i)]; | ||
756 | if (ch) { | ||
757 | newtext.push( | ||
758 | String.fromCharCode(ch) | ||
759 | ); | ||
760 | } else { | ||
761 | newtext.push( | ||
762 | text[i] | ||
763 | ); | ||
764 | } | ||
765 | |||
766 | // since we are looping over chars anyway, might as well | ||
767 | // check for residual unicodeness | ||
768 | if (newtext[i].charCodeAt(0) >> 8) { /* more than 255 */ | ||
769 | isUnicode = true; | ||
770 | } | ||
771 | } | ||
772 | text = newtext.join(''); | ||
773 | } | ||
774 | } | ||
775 | |||
776 | i = text.length; | ||
777 | // isUnicode may be set to false above. Hence the triple-equal to undefined | ||
778 | while (isUnicode === undef && i !== 0) { | ||
779 | if (text.charCodeAt(i - 1) >> 8) { /* more than 255 */ | ||
780 | isUnicode = true; | ||
781 | } | ||
782 | i--; | ||
783 | } | ||
784 | if (!isUnicode) { | ||
785 | return text; | ||
786 | } else { | ||
787 | newtext = flags.noBOM ? [] : [254, 255]; | ||
788 | for (i = 0, l = text.length; i < l; i++) { | ||
789 | ch = text.charCodeAt(i); | ||
790 | bch = ch >> 8; // divide by 256 | ||
791 | if (bch >> 8) { /* something left after dividing by 256 second time */ | ||
792 | throw new Error("Character at position " + i.toString(10) + " of string '" + text + "' exceeds 16bits. Cannot be encoded into UCS-2 BE"); | ||
793 | } | ||
794 | newtext.push(bch); | ||
795 | newtext.push(ch - (bch << 8)); | ||
796 | } | ||
797 | return String.fromCharCode.apply(undef, newtext); | ||
798 | } | ||
799 | }, | ||
800 | // Replace '/', '(', and ')' with pdf-safe versions | ||
801 | pdfEscape = function (text, flags) { | ||
802 | // doing to8bitStream does NOT make this PDF display unicode text. For that | ||
803 | // we also need to reference a unicode font and embed it - royal pain in the rear. | ||
804 | |||
805 | // There is still a benefit to to8bitStream - PDF simply cannot handle 16bit chars, | ||
806 | // which JavaScript Strings are happy to provide. So, while we still cannot display | ||
807 | // 2-byte characters property, at least CONDITIONALLY converting (entire string containing) | ||
808 | // 16bit chars to (USC-2-BE) 2-bytes per char + BOM streams we ensure that entire PDF | ||
809 | // is still parseable. | ||
810 | // This will allow immediate support for unicode in document properties strings. | ||
811 | return to8bitStream(text, flags).replace(/\\/g, '\\\\').replace(/\(/g, '\\(').replace(/\)/g, '\\)'); | ||
812 | }, | ||
813 | putInfo = function () { | ||
814 | out('/Producer (jsPDF ' + version + ')'); | ||
815 | if (documentProperties.title) { | ||
816 | out('/Title (' + pdfEscape(documentProperties.title) + ')'); | ||
817 | } | ||
818 | if (documentProperties.subject) { | ||
819 | out('/Subject (' + pdfEscape(documentProperties.subject) + ')'); | ||
820 | } | ||
821 | if (documentProperties.author) { | ||
822 | out('/Author (' + pdfEscape(documentProperties.author) + ')'); | ||
823 | } | ||
824 | if (documentProperties.keywords) { | ||
825 | out('/Keywords (' + pdfEscape(documentProperties.keywords) + ')'); | ||
826 | } | ||
827 | if (documentProperties.creator) { | ||
828 | out('/Creator (' + pdfEscape(documentProperties.creator) + ')'); | ||
829 | } | ||
830 | var created = new Date(); | ||
831 | out('/CreationDate (D:' + | ||
832 | [ | ||
833 | created.getFullYear(), | ||
834 | padd2(created.getMonth() + 1), | ||
835 | padd2(created.getDate()), | ||
836 | padd2(created.getHours()), | ||
837 | padd2(created.getMinutes()), | ||
838 | padd2(created.getSeconds()) | ||
839 | ].join('') + | ||
840 | ')' | ||
841 | ); | ||
842 | }, | ||
843 | putCatalog = function () { | ||
844 | out('/Type /Catalog'); | ||
845 | out('/Pages 1 0 R'); | ||
846 | // @TODO: Add zoom and layout modes | ||
847 | out('/OpenAction [3 0 R /FitH null]'); | ||
848 | out('/PageLayout /OneColumn'); | ||
849 | events.publish('putCatalog'); | ||
850 | }, | ||
851 | putTrailer = function () { | ||
852 | out('/Size ' + (objectNumber + 1)); | ||
853 | out('/Root ' + objectNumber + ' 0 R'); | ||
854 | out('/Info ' + (objectNumber - 1) + ' 0 R'); | ||
855 | }, | ||
856 | beginPage = function () { | ||
857 | page++; | ||
858 | // Do dimension stuff | ||
859 | outToPages = true; | ||
860 | pages[page] = []; | ||
861 | }, | ||
862 | _addPage = function () { | ||
863 | beginPage(); | ||
864 | // Set line width | ||
865 | out(f2(lineWidth * k) + ' w'); | ||
866 | // Set draw color | ||
867 | out(drawColor); | ||
868 | // resurrecting non-default line caps, joins | ||
869 | if (lineCapID !== 0) { | ||
870 | out(lineCapID.toString(10) + ' J'); | ||
871 | } | ||
872 | if (lineJoinID !== 0) { | ||
873 | out(lineJoinID.toString(10) + ' j'); | ||
874 | } | ||
875 | events.publish('addPage', {'pageNumber': page}); | ||
876 | }, | ||
877 | /** | ||
878 | Returns a document-specific font key - a label assigned to a | ||
879 | font name + font type combination at the time the font was added | ||
880 | to the font inventory. | ||
881 | |||
882 | Font key is used as label for the desired font for a block of text | ||
883 | to be added to the PDF document stream. | ||
884 | @private | ||
885 | @function | ||
886 | @param fontName {String} can be undefined on "falthy" to indicate "use current" | ||
887 | @param fontStyle {String} can be undefined on "falthy" to indicate "use current" | ||
888 | @returns {String} Font key. | ||
889 | */ | ||
890 | getFont = function (fontName, fontStyle) { | ||
891 | var key, undef; | ||
892 | |||
893 | if (fontName === undef) { | ||
894 | fontName = fonts[activeFontKey].fontName; | ||
895 | } | ||
896 | if (fontStyle === undef) { | ||
897 | fontStyle = fonts[activeFontKey].fontStyle; | ||
898 | } | ||
899 | |||
900 | try { | ||
901 | key = fontmap[fontName][fontStyle]; // returns a string like 'F3' - the KEY corresponding tot he font + type combination. | ||
902 | } catch (e) { | ||
903 | key = undef; | ||
904 | } | ||
905 | if (!key) { | ||
906 | throw new Error("Unable to look up font label for font '" + fontName + "', '" + fontStyle + "'. Refer to getFontList() for available fonts."); | ||
907 | } | ||
908 | |||
909 | return key; | ||
910 | }, | ||
911 | buildDocument = function () { | ||
912 | |||
913 | outToPages = false; // switches out() to content | ||
914 | content = []; | ||
915 | offsets = []; | ||
916 | |||
917 | // putHeader() | ||
918 | out('%PDF-' + pdfVersion); | ||
919 | |||
920 | putPages(); | ||
921 | |||
922 | putResources(); | ||
923 | |||
924 | // Info | ||
925 | newObject(); | ||
926 | out('<<'); | ||
927 | putInfo(); | ||
928 | out('>>'); | ||
929 | out('endobj'); | ||
930 | |||
931 | // Catalog | ||
932 | newObject(); | ||
933 | out('<<'); | ||
934 | putCatalog(); | ||
935 | out('>>'); | ||
936 | out('endobj'); | ||
937 | |||
938 | // Cross-ref | ||
939 | var o = content_length, i; | ||
940 | out('xref'); | ||
941 | out('0 ' + (objectNumber + 1)); | ||
942 | out('0000000000 65535 f '); | ||
943 | for (i = 1; i <= objectNumber; i++) { | ||
944 | out(padd10(offsets[i]) + ' 00000 n '); | ||
945 | } | ||
946 | // Trailer | ||
947 | out('trailer'); | ||
948 | out('<<'); | ||
949 | putTrailer(); | ||
950 | out('>>'); | ||
951 | out('startxref'); | ||
952 | out(o); | ||
953 | out('%%EOF'); | ||
954 | |||
955 | outToPages = true; | ||
956 | |||
957 | return content.join('\n'); | ||
958 | }, | ||
959 | getStyle = function (style) { | ||
960 | // see Path-Painting Operators of PDF spec | ||
961 | var op = 'S'; // stroke | ||
962 | if (style === 'F') { | ||
963 | op = 'f'; // fill | ||
964 | } else if (style === 'FD' || style === 'DF') { | ||
965 | op = 'B'; // both | ||
966 | } | ||
967 | return op; | ||
968 | }, | ||
969 | |||
970 | /** | ||
971 | Generates the PDF document. | ||
972 | Possible values: | ||
973 | datauristring (alias dataurlstring) - Data-Url-formatted data returned as string. | ||
974 | datauri (alias datauri) - Data-Url-formatted data pushed into current window's location (effectively reloading the window with contents of the PDF). | ||
975 | |||
976 | If `type` argument is undefined, output is raw body of resulting PDF returned as a string. | ||
977 | |||
978 | @param {String} type A string identifying one of the possible output types. | ||
979 | @param {Object} options An object providing some additional signalling to PDF generator. | ||
980 | @function | ||
981 | @returns {jsPDF} | ||
982 | @methodOf jsPDF# | ||
983 | @name output | ||
984 | */ | ||
985 | output = function (type, options) { | ||
986 | var undef, data, length, array, i, blob; | ||
987 | switch (type) { | ||
988 | case undef: | ||
989 | return buildDocument(); | ||
990 | case 'save': | ||
991 | if (navigator.getUserMedia) { | ||
992 | if (window.URL === undefined) { | ||
993 | return API.output('dataurlnewwindow'); | ||
994 | } else if (window.URL.createObjectURL === undefined) { | ||
995 | return API.output('dataurlnewwindow'); | ||
996 | } | ||
997 | } | ||
998 | data = buildDocument(); | ||
999 | |||
1000 | // Need to add the file to BlobBuilder as a Uint8Array | ||
1001 | length = data.length; | ||
1002 | array = new Uint8Array(new ArrayBuffer(length)); | ||
1003 | |||
1004 | for (i = 0; i < length; i++) { | ||
1005 | array[i] = data.charCodeAt(i); | ||
1006 | } | ||
1007 | |||
1008 | blob = new Blob([array], {type: "application/pdf"}); | ||
1009 | |||
1010 | saveAs(blob, options); | ||
1011 | break; | ||
1012 | case 'datauristring': | ||
1013 | case 'dataurlstring': | ||
1014 | return 'data:application/pdf;base64,' + btoa(buildDocument()); | ||
1015 | case 'datauri': | ||
1016 | case 'dataurl': | ||
1017 | document.location.href = 'data:application/pdf;base64,' + btoa(buildDocument()); | ||
1018 | break; | ||
1019 | case 'dataurlnewwindow': | ||
1020 | window.open('data:application/pdf;base64,' + btoa(buildDocument())); | ||
1021 | break; | ||
1022 | default: | ||
1023 | throw new Error('Output type "' + type + '" is not supported.'); | ||
1024 | } | ||
1025 | // @TODO: Add different output options | ||
1026 | }; | ||
1027 | |||
1028 | if (unit === 'pt') { | ||
1029 | k = 1; | ||
1030 | } else if (unit === 'mm') { | ||
1031 | k = 72 / 25.4; | ||
1032 | } else if (unit === 'cm') { | ||
1033 | k = 72 / 2.54; | ||
1034 | } else if (unit === 'in') { | ||
1035 | k = 72; | ||
1036 | } else { | ||
1037 | throw ('Invalid unit: ' + unit); | ||
1038 | } | ||
1039 | |||
1040 | // Dimensions are stored as user units and converted to points on output | ||
1041 | if (pageFormats.hasOwnProperty(format_as_string)) { | ||
1042 | pageHeight = pageFormats[format_as_string][1] / k; | ||
1043 | pageWidth = pageFormats[format_as_string][0] / k; | ||
1044 | } else { | ||
1045 | try { | ||
1046 | pageHeight = format[1]; | ||
1047 | pageWidth = format[0]; | ||
1048 | } catch (err) { | ||
1049 | throw ('Invalid format: ' + format); | ||
1050 | } | ||
1051 | } | ||
1052 | |||
1053 | if (orientation === 'p' || orientation === 'portrait') { | ||
1054 | orientation = 'p'; | ||
1055 | if (pageWidth > pageHeight) { | ||
1056 | tmp = pageWidth; | ||
1057 | pageWidth = pageHeight; | ||
1058 | pageHeight = tmp; | ||
1059 | } | ||
1060 | } else if (orientation === 'l' || orientation === 'landscape') { | ||
1061 | orientation = 'l'; | ||
1062 | if (pageHeight > pageWidth) { | ||
1063 | tmp = pageWidth; | ||
1064 | pageWidth = pageHeight; | ||
1065 | pageHeight = tmp; | ||
1066 | } | ||
1067 | } else { | ||
1068 | throw ('Invalid orientation: ' + orientation); | ||
1069 | } | ||
1070 | |||
1071 | |||
1072 | |||
1073 | //--------------------------------------- | ||
1074 | // Public API | ||
1075 | |||
1076 | /* | ||
1077 | Object exposing internal API to plugins | ||
1078 | @public | ||
1079 | */ | ||
1080 | API.internal = { | ||
1081 | 'pdfEscape': pdfEscape, | ||
1082 | 'getStyle': getStyle, | ||
1083 | /** | ||
1084 | Returns {FontObject} describing a particular font. | ||
1085 | @public | ||
1086 | @function | ||
1087 | @param fontName {String} (Optional) Font's family name | ||
1088 | @param fontStyle {String} (Optional) Font's style variation name (Example:"Italic") | ||
1089 | @returns {FontObject} | ||
1090 | */ | ||
1091 | 'getFont': function () { return fonts[getFont.apply(API, arguments)]; }, | ||
1092 | 'getFontSize': function () { return activeFontSize; }, | ||
1093 | 'getLineHeight': function () { return activeFontSize * lineHeightProportion; }, | ||
1094 | 'btoa': btoa, | ||
1095 | 'write': function (string1, string2, string3, etc) { | ||
1096 | out( | ||
1097 | arguments.length === 1 ? string1 : Array.prototype.join.call(arguments, ' ') | ||
1098 | ); | ||
1099 | }, | ||
1100 | 'getCoordinateString': function (value) { | ||
1101 | return f2(value * k); | ||
1102 | }, | ||
1103 | 'getVerticalCoordinateString': function (value) { | ||
1104 | return f2((pageHeight - value) * k); | ||
1105 | }, | ||
1106 | 'collections': {}, | ||
1107 | 'newObject': newObject, | ||
1108 | 'putStream': putStream, | ||
1109 | 'events': events, | ||
1110 | // ratio that you use in multiplication of a given "size" number to arrive to 'point' | ||
1111 | // units of measurement. | ||
1112 | // scaleFactor is set at initialization of the document and calculated against the stated | ||
1113 | // default measurement units for the document. | ||
1114 | // If default is "mm", k is the number that will turn number in 'mm' into 'points' number. | ||
1115 | // through multiplication. | ||
1116 | 'scaleFactor': k, | ||
1117 | 'pageSize': {'width': pageWidth, 'height': pageHeight}, | ||
1118 | 'output': function (type, options) { | ||
1119 | return output(type, options); | ||
1120 | }, | ||
1121 | 'getNumberOfPages': function () {return pages.length - 1; }, | ||
1122 | 'pages': pages | ||
1123 | }; | ||
1124 | |||
1125 | /** | ||
1126 | Adds (and transfers the focus to) new page to the PDF document. | ||
1127 | @function | ||
1128 | @returns {jsPDF} | ||
1129 | |||
1130 | @methodOf jsPDF# | ||
1131 | @name addPage | ||
1132 | */ | ||
1133 | API.addPage = function () { | ||
1134 | _addPage(); | ||
1135 | return this; | ||
1136 | }; | ||
1137 | |||
1138 | /** | ||
1139 | Adds text to page. Supports adding multiline text when 'text' argument is an Array of Strings. | ||
1140 | @function | ||
1141 | @param {String|Array} text String or array of strings to be added to the page. Each line is shifted one line down per font, spacing settings declared before this call. | ||
1142 | @param {Number} x Coordinate (in units declared at inception of PDF document) against left edge of the page | ||
1143 | @param {Number} y Coordinate (in units declared at inception of PDF document) against upper edge of the page | ||
1144 | @param {Object} flags Collection of settings signalling how the text must be encoded. Defaults are sane. If you think you want to pass some flags, you likely can read the source. | ||
1145 | @returns {jsPDF} | ||
1146 | @methodOf jsPDF# | ||
1147 | @name text | ||
1148 | */ | ||
1149 | API.text = function (text, x, y, flags) { | ||
1150 | /** | ||
1151 | * Inserts something like this into PDF | ||
1152 | BT | ||
1153 | /F1 16 Tf % Font name + size | ||
1154 | 16 TL % How many units down for next line in multiline text | ||
1155 | 0 g % color | ||
1156 | 28.35 813.54 Td % position | ||
1157 | (line one) Tj | ||
1158 | T* (line two) Tj | ||
1159 | T* (line three) Tj | ||
1160 | ET | ||
1161 | */ | ||
1162 | |||
1163 | var undef, _first, _second, _third, newtext, str, i; | ||
1164 | // Pre-August-2012 the order of arguments was function(x, y, text, flags) | ||
1165 | // in effort to make all calls have similar signature like | ||
1166 | // function(data, coordinates... , miscellaneous) | ||
1167 | // this method had its args flipped. | ||
1168 | // code below allows backward compatibility with old arg order. | ||
1169 | if (typeof text === 'number') { | ||
1170 | _first = y; | ||
1171 | _second = text; | ||
1172 | _third = x; | ||
1173 | |||
1174 | text = _first; | ||
1175 | x = _second; | ||
1176 | y = _third; | ||
1177 | } | ||
1178 | |||
1179 | // If there are any newlines in text, we assume | ||
1180 | // the user wanted to print multiple lines, so break the | ||
1181 | // text up into an array. If the text is already an array, | ||
1182 | // we assume the user knows what they are doing. | ||
1183 | if (typeof text === 'string' && text.match(/[\n\r]/)) { | ||
1184 | text = text.split(/\r\n|\r|\n/g); | ||
1185 | } | ||
1186 | |||
1187 | if (typeof flags === 'undefined') { | ||
1188 | flags = {'noBOM': true, 'autoencode': true}; | ||
1189 | } else { | ||
1190 | |||
1191 | if (flags.noBOM === undef) { | ||
1192 | flags.noBOM = true; | ||
1193 | } | ||
1194 | |||
1195 | if (flags.autoencode === undef) { | ||
1196 | flags.autoencode = true; | ||
1197 | } | ||
1198 | |||
1199 | } | ||
1200 | |||
1201 | if (typeof text === 'string') { | ||
1202 | str = pdfEscape(text, flags); | ||
1203 | } else if (text instanceof Array) { /* Array */ | ||
1204 | // we don't want to destroy original text array, so cloning it | ||
1205 | newtext = text.concat(); | ||
1206 | // we do array.join('text that must not be PDFescaped") | ||
1207 | // thus, pdfEscape each component separately | ||
1208 | for (i = newtext.length - 1; i !== -1; i--) { | ||
1209 | newtext[i] = pdfEscape(newtext[i], flags); | ||
1210 | } | ||
1211 | str = newtext.join(") Tj\nT* ("); | ||
1212 | } else { | ||
1213 | throw new Error('Type of text must be string or Array. "' + text + '" is not recognized.'); | ||
1214 | } | ||
1215 | // Using "'" ("go next line and render text" mark) would save space but would complicate our rendering code, templates | ||
1216 | |||
1217 | // BT .. ET does NOT have default settings for Tf. You must state that explicitely every time for BT .. ET | ||
1218 | // if you want text transformation matrix (+ multiline) to work reliably (which reads sizes of things from font declarations) | ||
1219 | // Thus, there is NO useful, *reliable* concept of "default" font for a page. | ||
1220 | // The fact that "default" (reuse font used before) font worked before in basic cases is an accident | ||
1221 | // - readers dealing smartly with brokenness of jsPDF's markup. | ||
1222 | out( | ||
1223 | 'BT\n/' + | ||
1224 | activeFontKey + ' ' + activeFontSize + ' Tf\n' + // font face, style, size | ||
1225 | (activeFontSize * lineHeightProportion) + ' TL\n' + // line spacing | ||
1226 | textColor + | ||
1227 | '\n' + f2(x * k) + ' ' + f2((pageHeight - y) * k) + ' Td\n(' + | ||
1228 | str + | ||
1229 | ') Tj\nET' | ||
1230 | ); | ||
1231 | return this; | ||
1232 | }; | ||
1233 | |||
1234 | API.line = function (x1, y1, x2, y2) { | ||
1235 | out( | ||
1236 | f2(x1 * k) + ' ' + f2((pageHeight - y1) * k) + ' m ' + | ||
1237 | f2(x2 * k) + ' ' + f2((pageHeight - y2) * k) + ' l S' | ||
1238 | ); | ||
1239 | return this; | ||
1240 | }; | ||
1241 | |||
1242 | /** | ||
1243 | Adds series of curves (straight lines or cubic bezier curves) to canvas, starting at `x`, `y` coordinates. | ||
1244 | All data points in `lines` are relative to last line origin. | ||
1245 | `x`, `y` become x1,y1 for first line / curve in the set. | ||
1246 | For lines you only need to specify [x2, y2] - (ending point) vector against x1, y1 starting point. | ||
1247 | For bezier curves you need to specify [x2,y2,x3,y3,x4,y4] - vectors to control points 1, 2, ending point. All vectors are against the start of the curve - x1,y1. | ||
1248 | |||
1249 | @example .lines([[2,2],[-2,2],[1,1,2,2,3,3],[2,1]], 212,110, 10) // line, line, bezier curve, line | ||
1250 | @param {Array} lines Array of *vector* shifts as pairs (lines) or sextets (cubic bezier curves). | ||
1251 | @param {Number} x Coordinate (in units declared at inception of PDF document) against left edge of the page | ||
1252 | @param {Number} y Coordinate (in units declared at inception of PDF document) against upper edge of the page | ||
1253 | @param {Number} scale (Defaults to [1.0,1.0]) x,y Scaling factor for all vectors. Elements can be any floating number Sub-one makes drawing smaller. Over-one grows the drawing. Negative flips the direction. | ||
1254 | @param {String} style One of 'S' (the default), 'F', 'FD' or 'DF'. 'S' draws just the curve. 'F' fills the region defined by the curves. 'DF' or 'FD' draws the curves and fills the region. | ||
1255 | @param {Boolean} closed If true, the path is closed with a straight line from the end of the last curve to the starting point. | ||
1256 | @function | ||
1257 | @returns {jsPDF} | ||
1258 | @methodOf jsPDF# | ||
1259 | @name lines | ||
1260 | */ | ||
1261 | API.lines = function (lines, x, y, scale, style, closed) { | ||
1262 | var undef, _first, _second, _third, scalex, scaley, i, l, leg, x2, y2, x3, y3, x4, y4; | ||
1263 | |||
1264 | // Pre-August-2012 the order of arguments was function(x, y, lines, scale, style) | ||
1265 | // in effort to make all calls have similar signature like | ||
1266 | // function(content, coordinateX, coordinateY , miscellaneous) | ||
1267 | // this method had its args flipped. | ||
1268 | // code below allows backward compatibility with old arg order. | ||
1269 | if (typeof lines === 'number') { | ||
1270 | _first = y; | ||
1271 | _second = lines; | ||
1272 | _third = x; | ||
1273 | |||
1274 | lines = _first; | ||
1275 | x = _second; | ||
1276 | y = _third; | ||
1277 | } | ||
1278 | |||
1279 | style = getStyle(style); | ||
1280 | scale = scale === undef ? [1, 1] : scale; | ||
1281 | |||
1282 | // starting point | ||
1283 | out(f3(x * k) + ' ' + f3((pageHeight - y) * k) + ' m '); | ||
1284 | |||
1285 | scalex = scale[0]; | ||
1286 | scaley = scale[1]; | ||
1287 | l = lines.length; | ||
1288 | //, x2, y2 // bezier only. In page default measurement "units", *after* scaling | ||
1289 | //, x3, y3 // bezier only. In page default measurement "units", *after* scaling | ||
1290 | // ending point for all, lines and bezier. . In page default measurement "units", *after* scaling | ||
1291 | x4 = x; // last / ending point = starting point for first item. | ||
1292 | y4 = y; // last / ending point = starting point for first item. | ||
1293 | |||
1294 | for (i = 0; i < l; i++) { | ||
1295 | leg = lines[i]; | ||
1296 | if (leg.length === 2) { | ||
1297 | // simple line | ||
1298 | x4 = leg[0] * scalex + x4; // here last x4 was prior ending point | ||
1299 | y4 = leg[1] * scaley + y4; // here last y4 was prior ending point | ||
1300 | out(f3(x4 * k) + ' ' + f3((pageHeight - y4) * k) + ' l'); | ||
1301 | } else { | ||
1302 | // bezier curve | ||
1303 | x2 = leg[0] * scalex + x4; // here last x4 is prior ending point | ||
1304 | y2 = leg[1] * scaley + y4; // here last y4 is prior ending point | ||
1305 | x3 = leg[2] * scalex + x4; // here last x4 is prior ending point | ||
1306 | y3 = leg[3] * scaley + y4; // here last y4 is prior ending point | ||
1307 | x4 = leg[4] * scalex + x4; // here last x4 was prior ending point | ||
1308 | y4 = leg[5] * scaley + y4; // here last y4 was prior ending point | ||
1309 | out( | ||
1310 | f3(x2 * k) + ' ' + | ||
1311 | f3((pageHeight - y2) * k) + ' ' + | ||
1312 | f3(x3 * k) + ' ' + | ||
1313 | f3((pageHeight - y3) * k) + ' ' + | ||
1314 | f3(x4 * k) + ' ' + | ||
1315 | f3((pageHeight - y4) * k) + ' c' | ||
1316 | ); | ||
1317 | } | ||
1318 | } | ||
1319 | |||
1320 | if (closed == true) { | ||
1321 | out(' h'); | ||
1322 | } | ||
1323 | |||
1324 | // stroking / filling / both the path | ||
1325 | out(style); | ||
1326 | return this; | ||
1327 | }; | ||
1328 | |||
1329 | /** | ||
1330 | Adds a rectangle to PDF | ||
1331 | |||
1332 | @param {Number} x Coordinate (in units declared at inception of PDF document) against left edge of the page | ||
1333 | @param {Number} y Coordinate (in units declared at inception of PDF document) against upper edge of the page | ||
1334 | @param {Number} w Width (in units declared at inception of PDF document) | ||
1335 | @param {Number} h Height (in units declared at inception of PDF document) | ||
1336 | @param {String} style (Defaults to active fill/stroke style) A string signalling if stroke, fill or both are to be applied. | ||
1337 | @function | ||
1338 | @returns {jsPDF} | ||
1339 | @methodOf jsPDF# | ||
1340 | @name rect | ||
1341 | */ | ||
1342 | API.rect = function (x, y, w, h, style) { | ||
1343 | var op = getStyle(style); | ||
1344 | out([ | ||
1345 | f2(x * k), | ||
1346 | f2((pageHeight - y) * k), | ||
1347 | f2(w * k), | ||
1348 | f2(-h * k), | ||
1349 | 're', | ||
1350 | op | ||
1351 | ].join(' ')); | ||
1352 | return this; | ||
1353 | }; | ||
1354 | |||
1355 | /** | ||
1356 | Adds a triangle to PDF | ||
1357 | |||
1358 | @param {Number} x1 Coordinate (in units declared at inception of PDF document) against left edge of the page | ||
1359 | @param {Number} y1 Coordinate (in units declared at inception of PDF document) against upper edge of the page | ||
1360 | @param {Number} x2 Coordinate (in units declared at inception of PDF document) against left edge of the page | ||
1361 | @param {Number} y2 Coordinate (in units declared at inception of PDF document) against upper edge of the page | ||
1362 | @param {Number} x3 Coordinate (in units declared at inception of PDF document) against left edge of the page | ||
1363 | @param {Number} y3 Coordinate (in units declared at inception of PDF document) against upper edge of the page | ||
1364 | @param {String} style (Defaults to active fill/stroke style) A string signalling if stroke, fill or both are to be applied. | ||
1365 | @function | ||
1366 | @returns {jsPDF} | ||
1367 | @methodOf jsPDF# | ||
1368 | @name triangle | ||
1369 | */ | ||
1370 | API.triangle = function (x1, y1, x2, y2, x3, y3, style) { | ||
1371 | this.lines( | ||
1372 | [ | ||
1373 | [ x2 - x1, y2 - y1 ], // vector to point 2 | ||
1374 | [ x3 - x2, y3 - y2 ], // vector to point 3 | ||
1375 | [ x1 - x3, y1 - y3 ] // closing vector back to point 1 | ||
1376 | ], | ||
1377 | x1, | ||
1378 | y1, // start of path | ||
1379 | [1, 1], | ||
1380 | style, | ||
1381 | true | ||
1382 | ); | ||
1383 | return this; | ||
1384 | }; | ||
1385 | |||
1386 | /** | ||
1387 | Adds a rectangle with rounded corners to PDF | ||
1388 | |||
1389 | @param {Number} x Coordinate (in units declared at inception of PDF document) against left edge of the page | ||
1390 | @param {Number} y Coordinate (in units declared at inception of PDF document) against upper edge of the page | ||
1391 | @param {Number} w Width (in units declared at inception of PDF document) | ||
1392 | @param {Number} h Height (in units declared at inception of PDF document) | ||
1393 | @param {Number} rx Radius along x axis (in units declared at inception of PDF document) | ||
1394 | @param {Number} rx Radius along y axis (in units declared at inception of PDF document) | ||
1395 | @param {String} style (Defaults to active fill/stroke style) A string signalling if stroke, fill or both are to be applied. | ||
1396 | @function | ||
1397 | @returns {jsPDF} | ||
1398 | @methodOf jsPDF# | ||
1399 | @name roundedRect | ||
1400 | */ | ||
1401 | API.roundedRect = function (x, y, w, h, rx, ry, style) { | ||
1402 | var MyArc = 4 / 3 * (Math.SQRT2 - 1); | ||
1403 | this.lines( | ||
1404 | [ | ||
1405 | [ (w - 2 * rx), 0 ], | ||
1406 | [ (rx * MyArc), 0, rx, ry - (ry * MyArc), rx, ry ], | ||
1407 | [ 0, (h - 2 * ry) ], | ||
1408 | [ 0, (ry * MyArc), -(rx * MyArc), ry, -rx, ry], | ||
1409 | [ (-w + 2 * rx), 0], | ||
1410 | [ -(rx * MyArc), 0, -rx, -(ry * MyArc), -rx, -ry], | ||
1411 | [ 0, (-h + 2 * ry)], | ||
1412 | [ 0, -(ry * MyArc), (rx * MyArc), -ry, rx, -ry] | ||
1413 | ], | ||
1414 | x + rx, | ||
1415 | y, // start of path | ||
1416 | [1, 1], | ||
1417 | style | ||
1418 | ); | ||
1419 | return this; | ||
1420 | }; | ||
1421 | |||
1422 | /** | ||
1423 | Adds an ellipse to PDF | ||
1424 | |||
1425 | @param {Number} x Coordinate (in units declared at inception of PDF document) against left edge of the page | ||
1426 | @param {Number} y Coordinate (in units declared at inception of PDF document) against upper edge of the page | ||
1427 | @param {Number} rx Radius along x axis (in units declared at inception of PDF document) | ||
1428 | @param {Number} rx Radius along y axis (in units declared at inception of PDF document) | ||
1429 | @param {String} style (Defaults to active fill/stroke style) A string signalling if stroke, fill or both are to be applied. | ||
1430 | @function | ||
1431 | @returns {jsPDF} | ||
1432 | @methodOf jsPDF# | ||
1433 | @name ellipse | ||
1434 | */ | ||
1435 | API.ellipse = function (x, y, rx, ry, style) { | ||
1436 | var op = getStyle(style), | ||
1437 | lx = 4 / 3 * (Math.SQRT2 - 1) * rx, | ||
1438 | ly = 4 / 3 * (Math.SQRT2 - 1) * ry; | ||
1439 | |||
1440 | out([ | ||
1441 | f2((x + rx) * k), | ||
1442 | f2((pageHeight - y) * k), | ||
1443 | 'm', | ||
1444 | f2((x + rx) * k), | ||
1445 | f2((pageHeight - (y - ly)) * k), | ||
1446 | f2((x + lx) * k), | ||
1447 | f2((pageHeight - (y - ry)) * k), | ||
1448 | f2(x * k), | ||
1449 | f2((pageHeight - (y - ry)) * k), | ||
1450 | 'c' | ||
1451 | ].join(' ')); | ||
1452 | out([ | ||
1453 | f2((x - lx) * k), | ||
1454 | f2((pageHeight - (y - ry)) * k), | ||
1455 | f2((x - rx) * k), | ||
1456 | f2((pageHeight - (y - ly)) * k), | ||
1457 | f2((x - rx) * k), | ||
1458 | f2((pageHeight - y) * k), | ||
1459 | 'c' | ||
1460 | ].join(' ')); | ||
1461 | out([ | ||
1462 | f2((x - rx) * k), | ||
1463 | f2((pageHeight - (y + ly)) * k), | ||
1464 | f2((x - lx) * k), | ||
1465 | f2((pageHeight - (y + ry)) * k), | ||
1466 | f2(x * k), | ||
1467 | f2((pageHeight - (y + ry)) * k), | ||
1468 | 'c' | ||
1469 | ].join(' ')); | ||
1470 | out([ | ||
1471 | f2((x + lx) * k), | ||
1472 | f2((pageHeight - (y + ry)) * k), | ||
1473 | f2((x + rx) * k), | ||
1474 | f2((pageHeight - (y + ly)) * k), | ||
1475 | f2((x + rx) * k), | ||
1476 | f2((pageHeight - y) * k), | ||
1477 | 'c', | ||
1478 | op | ||
1479 | ].join(' ')); | ||
1480 | return this; | ||
1481 | }; | ||
1482 | |||
1483 | /** | ||
1484 | Adds an circle to PDF | ||
1485 | |||
1486 | @param {Number} x Coordinate (in units declared at inception of PDF document) against left edge of the page | ||
1487 | @param {Number} y Coordinate (in units declared at inception of PDF document) against upper edge of the page | ||
1488 | @param {Number} r Radius (in units declared at inception of PDF document) | ||
1489 | @param {String} style (Defaults to active fill/stroke style) A string signalling if stroke, fill or both are to be applied. | ||
1490 | @function | ||
1491 | @returns {jsPDF} | ||
1492 | @methodOf jsPDF# | ||
1493 | @name circle | ||
1494 | */ | ||
1495 | API.circle = function (x, y, r, style) { | ||
1496 | return this.ellipse(x, y, r, r, style); | ||
1497 | }; | ||
1498 | |||
1499 | /** | ||
1500 | Adds a properties to the PDF document | ||
1501 | |||
1502 | @param {Object} A property_name-to-property_value object structure. | ||
1503 | @function | ||
1504 | @returns {jsPDF} | ||
1505 | @methodOf jsPDF# | ||
1506 | @name setProperties | ||
1507 | */ | ||
1508 | API.setProperties = function (properties) { | ||
1509 | // copying only those properties we can render. | ||
1510 | var property; | ||
1511 | for (property in documentProperties) { | ||
1512 | if (documentProperties.hasOwnProperty(property) && properties[property]) { | ||
1513 | documentProperties[property] = properties[property]; | ||
1514 | } | ||
1515 | } | ||
1516 | return this; | ||
1517 | }; | ||
1518 | |||
1519 | /** | ||
1520 | Sets font size for upcoming text elements. | ||
1521 | |||
1522 | @param {Number} size Font size in points. | ||
1523 | @function | ||
1524 | @returns {jsPDF} | ||
1525 | @methodOf jsPDF# | ||
1526 | @name setFontSize | ||
1527 | */ | ||
1528 | API.setFontSize = function (size) { | ||
1529 | activeFontSize = size; | ||
1530 | return this; | ||
1531 | }; | ||
1532 | |||
1533 | /** | ||
1534 | Sets text font face, variant for upcoming text elements. | ||
1535 | See output of jsPDF.getFontList() for possible font names, styles. | ||
1536 | |||
1537 | @param {String} fontName Font name or family. Example: "times" | ||
1538 | @param {String} fontStyle Font style or variant. Example: "italic" | ||
1539 | @function | ||
1540 | @returns {jsPDF} | ||
1541 | @methodOf jsPDF# | ||
1542 | @name setFont | ||
1543 | */ | ||
1544 | API.setFont = function (fontName, fontStyle) { | ||
1545 | activeFontKey = getFont(fontName, fontStyle); | ||
1546 | // if font is not found, the above line blows up and we never go further | ||
1547 | return this; | ||
1548 | }; | ||
1549 | |||
1550 | /** | ||
1551 | Switches font style or variant for upcoming text elements, | ||
1552 | while keeping the font face or family same. | ||
1553 | See output of jsPDF.getFontList() for possible font names, styles. | ||
1554 | |||
1555 | @param {String} style Font style or variant. Example: "italic" | ||
1556 | @function | ||
1557 | @returns {jsPDF} | ||
1558 | @methodOf jsPDF# | ||
1559 | @name setFontStyle | ||
1560 | */ | ||
1561 | API.setFontStyle = API.setFontType = function (style) { | ||
1562 | var undef; | ||
1563 | activeFontKey = getFont(undef, style); | ||
1564 | // if font is not found, the above line blows up and we never go further | ||
1565 | return this; | ||
1566 | }; | ||
1567 | |||
1568 | /** | ||
1569 | Returns an object - a tree of fontName to fontStyle relationships available to | ||
1570 | active PDF document. | ||
1571 | |||
1572 | @public | ||
1573 | @function | ||
1574 | @returns {Object} Like {'times':['normal', 'italic', ... ], 'arial':['normal', 'bold', ... ], ... } | ||
1575 | @methodOf jsPDF# | ||
1576 | @name getFontList | ||
1577 | */ | ||
1578 | API.getFontList = function () { | ||
1579 | // TODO: iterate over fonts array or return copy of fontmap instead in case more are ever added. | ||
1580 | var list = {}, | ||
1581 | fontName, | ||
1582 | fontStyle, | ||
1583 | tmp; | ||
1584 | |||
1585 | for (fontName in fontmap) { | ||
1586 | if (fontmap.hasOwnProperty(fontName)) { | ||
1587 | list[fontName] = tmp = []; | ||
1588 | for (fontStyle in fontmap[fontName]) { | ||
1589 | if (fontmap[fontName].hasOwnProperty(fontStyle)) { | ||
1590 | tmp.push(fontStyle); | ||
1591 | } | ||
1592 | } | ||
1593 | } | ||
1594 | } | ||
1595 | |||
1596 | return list; | ||
1597 | }; | ||
1598 | |||
1599 | /** | ||
1600 | Sets line width for upcoming lines. | ||
1601 | |||
1602 | @param {Number} width Line width (in units declared at inception of PDF document) | ||
1603 | @function | ||
1604 | @returns {jsPDF} | ||
1605 | @methodOf jsPDF# | ||
1606 | @name setLineWidth | ||
1607 | */ | ||
1608 | API.setLineWidth = function (width) { | ||
1609 | out((width * k).toFixed(2) + ' w'); | ||
1610 | return this; | ||
1611 | }; | ||
1612 | |||
1613 | /** | ||
1614 | Sets the stroke color for upcoming elements. | ||
1615 | |||
1616 | Depending on the number of arguments given, Gray, RGB, or CMYK | ||
1617 | color space is implied. | ||
1618 | |||
1619 | When only ch1 is given, "Gray" color space is implied and it | ||
1620 | must be a value in the range from 0.00 (solid black) to to 1.00 (white) | ||
1621 | if values are communicated as String types, or in range from 0 (black) | ||
1622 | to 255 (white) if communicated as Number type. | ||
1623 | The RGB-like 0-255 range is provided for backward compatibility. | ||
1624 | |||
1625 | When only ch1,ch2,ch3 are given, "RGB" color space is implied and each | ||
1626 | value must be in the range from 0.00 (minimum intensity) to to 1.00 | ||
1627 | (max intensity) if values are communicated as String types, or | ||
1628 | from 0 (min intensity) to to 255 (max intensity) if values are communicated | ||
1629 | as Number types. | ||
1630 | The RGB-like 0-255 range is provided for backward compatibility. | ||
1631 | |||
1632 | When ch1,ch2,ch3,ch4 are given, "CMYK" color space is implied and each | ||
1633 | value must be a in the range from 0.00 (0% concentration) to to | ||
1634 | 1.00 (100% concentration) | ||
1635 | |||
1636 | Because JavaScript treats fixed point numbers badly (rounds to | ||
1637 | floating point nearest to binary representation) it is highly advised to | ||
1638 | communicate the fractional numbers as String types, not JavaScript Number type. | ||
1639 | |||
1640 | @param {Number|String} ch1 Color channel value | ||
1641 | @param {Number|String} ch2 Color channel value | ||
1642 | @param {Number|String} ch3 Color channel value | ||
1643 | @param {Number|String} ch4 Color channel value | ||
1644 | |||
1645 | @function | ||
1646 | @returns {jsPDF} | ||
1647 | @methodOf jsPDF# | ||
1648 | @name setDrawColor | ||
1649 | */ | ||
1650 | API.setDrawColor = function (ch1, ch2, ch3, ch4) { | ||
1651 | var color; | ||
1652 | if (ch2 === undefined || (ch4 === undefined && ch1 === ch2 === ch3)) { | ||
1653 | // Gray color space. | ||
1654 | if (typeof ch1 === 'string') { | ||
1655 | color = ch1 + ' G'; | ||
1656 | } else { | ||
1657 | color = f2(ch1 / 255) + ' G'; | ||
1658 | } | ||
1659 | } else if (ch4 === undefined) { | ||
1660 | // RGB | ||
1661 | if (typeof ch1 === 'string') { | ||
1662 | color = [ch1, ch2, ch3, 'RG'].join(' '); | ||
1663 | } else { | ||
1664 | color = [f2(ch1 / 255), f2(ch2 / 255), f2(ch3 / 255), 'RG'].join(' '); | ||
1665 | } | ||
1666 | } else { | ||
1667 | // CMYK | ||
1668 | if (typeof ch1 === 'string') { | ||
1669 | color = [ch1, ch2, ch3, ch4, 'K'].join(' '); | ||
1670 | } else { | ||
1671 | color = [f2(ch1), f2(ch2), f2(ch3), f2(ch4), 'K'].join(' '); | ||
1672 | } | ||
1673 | } | ||
1674 | |||
1675 | out(color); | ||
1676 | return this; | ||
1677 | }; | ||
1678 | |||
1679 | /** | ||
1680 | Sets the fill color for upcoming elements. | ||
1681 | |||
1682 | Depending on the number of arguments given, Gray, RGB, or CMYK | ||
1683 | color space is implied. | ||
1684 | |||
1685 | When only ch1 is given, "Gray" color space is implied and it | ||
1686 | must be a value in the range from 0.00 (solid black) to to 1.00 (white) | ||
1687 | if values are communicated as String types, or in range from 0 (black) | ||
1688 | to 255 (white) if communicated as Number type. | ||
1689 | The RGB-like 0-255 range is provided for backward compatibility. | ||
1690 | |||
1691 | When only ch1,ch2,ch3 are given, "RGB" color space is implied and each | ||
1692 | value must be in the range from 0.00 (minimum intensity) to to 1.00 | ||
1693 | (max intensity) if values are communicated as String types, or | ||
1694 | from 0 (min intensity) to to 255 (max intensity) if values are communicated | ||
1695 | as Number types. | ||
1696 | The RGB-like 0-255 range is provided for backward compatibility. | ||
1697 | |||
1698 | When ch1,ch2,ch3,ch4 are given, "CMYK" color space is implied and each | ||
1699 | value must be a in the range from 0.00 (0% concentration) to to | ||
1700 | 1.00 (100% concentration) | ||
1701 | |||
1702 | Because JavaScript treats fixed point numbers badly (rounds to | ||
1703 | floating point nearest to binary representation) it is highly advised to | ||
1704 | communicate the fractional numbers as String types, not JavaScript Number type. | ||
1705 | |||
1706 | @param {Number|String} ch1 Color channel value | ||
1707 | @param {Number|String} ch2 Color channel value | ||
1708 | @param {Number|String} ch3 Color channel value | ||
1709 | @param {Number|String} ch4 Color channel value | ||
1710 | |||
1711 | @function | ||
1712 | @returns {jsPDF} | ||
1713 | @methodOf jsPDF# | ||
1714 | @name setFillColor | ||
1715 | */ | ||
1716 | API.setFillColor = function (ch1, ch2, ch3, ch4) { | ||
1717 | var color; | ||
1718 | |||
1719 | if (ch2 === undefined || (ch4 === undefined && ch1 === ch2 === ch3)) { | ||
1720 | // Gray color space. | ||
1721 | if (typeof ch1 === 'string') { | ||
1722 | color = ch1 + ' g'; | ||
1723 | } else { | ||
1724 | color = f2(ch1 / 255) + ' g'; | ||
1725 | } | ||
1726 | } else if (ch4 === undefined) { | ||
1727 | // RGB | ||
1728 | if (typeof ch1 === 'string') { | ||
1729 | color = [ch1, ch2, ch3, 'rg'].join(' '); | ||
1730 | } else { | ||
1731 | color = [f2(ch1 / 255), f2(ch2 / 255), f2(ch3 / 255), 'rg'].join(' '); | ||
1732 | } | ||
1733 | } else { | ||
1734 | // CMYK | ||
1735 | if (typeof ch1 === 'string') { | ||
1736 | color = [ch1, ch2, ch3, ch4, 'k'].join(' '); | ||
1737 | } else { | ||
1738 | color = [f2(ch1), f2(ch2), f2(ch3), f2(ch4), 'k'].join(' '); | ||
1739 | } | ||
1740 | } | ||
1741 | |||
1742 | out(color); | ||
1743 | return this; | ||
1744 | }; | ||
1745 | |||
1746 | /** | ||
1747 | Sets the text color for upcoming elements. | ||
1748 | If only one, first argument is given, | ||
1749 | treats the value as gray-scale color value. | ||
1750 | |||
1751 | @param {Number} r Red channel color value in range 0-255 or {String} r color value in hexadecimal, example: '#FFFFFF' | ||
1752 | @param {Number} g Green channel color value in range 0-255 | ||
1753 | @param {Number} b Blue channel color value in range 0-255 | ||
1754 | @function | ||
1755 | @returns {jsPDF} | ||
1756 | @methodOf jsPDF# | ||
1757 | @name setTextColor | ||
1758 | */ | ||
1759 | API.setTextColor = function (r, g, b) { | ||
1760 | var patt = /#[0-9A-Fa-f]{6}/; | ||
1761 | if ((typeof r == 'string') && patt.test(r)) { | ||
1762 | var hex = r.replace('#',''); | ||
1763 | var bigint = parseInt(hex, 16); | ||
1764 | r = (bigint >> 16) & 255; | ||
1765 | g = (bigint >> 8) & 255; | ||
1766 | b = bigint & 255; | ||
1767 | } | ||
1768 | |||
1769 | if ((r === 0 && g === 0 && b === 0) || (typeof g === 'undefined')) { | ||
1770 | textColor = f3(r / 255) + ' g'; | ||
1771 | } else { | ||
1772 | textColor = [f3(r / 255), f3(g / 255), f3(b / 255), 'rg'].join(' '); | ||
1773 | } | ||
1774 | return this; | ||
1775 | }; | ||
1776 | |||
1777 | /** | ||
1778 | Is an Object providing a mapping from human-readable to | ||
1779 | integer flag values designating the varieties of line cap | ||
1780 | and join styles. | ||
1781 | |||
1782 | @returns {Object} | ||
1783 | @fieldOf jsPDF# | ||
1784 | @name CapJoinStyles | ||
1785 | */ | ||
1786 | API.CapJoinStyles = { | ||
1787 | 0: 0, | ||
1788 | 'butt': 0, | ||
1789 | 'but': 0, | ||
1790 | 'miter': 0, | ||
1791 | 1: 1, | ||
1792 | 'round': 1, | ||
1793 | 'rounded': 1, | ||
1794 | 'circle': 1, | ||
1795 | 2: 2, | ||
1796 | 'projecting': 2, | ||
1797 | 'project': 2, | ||
1798 | 'square': 2, | ||
1799 | 'bevel': 2 | ||
1800 | }; | ||
1801 | |||
1802 | /** | ||
1803 | Sets the line cap styles | ||
1804 | See {jsPDF.CapJoinStyles} for variants | ||
1805 | |||
1806 | @param {String|Number} style A string or number identifying the type of line cap | ||
1807 | @function | ||
1808 | @returns {jsPDF} | ||
1809 | @methodOf jsPDF# | ||
1810 | @name setLineCap | ||
1811 | */ | ||
1812 | API.setLineCap = function (style) { | ||
1813 | var id = this.CapJoinStyles[style]; | ||
1814 | if (id === undefined) { | ||
1815 | throw new Error("Line cap style of '" + style + "' is not recognized. See or extend .CapJoinStyles property for valid styles"); | ||
1816 | } | ||
1817 | lineCapID = id; | ||
1818 | out(id.toString(10) + ' J'); | ||
1819 | |||
1820 | return this; | ||
1821 | }; | ||
1822 | |||
1823 | /** | ||
1824 | Sets the line join styles | ||
1825 | See {jsPDF.CapJoinStyles} for variants | ||
1826 | |||
1827 | @param {String|Number} style A string or number identifying the type of line join | ||
1828 | @function | ||
1829 | @returns {jsPDF} | ||
1830 | @methodOf jsPDF# | ||
1831 | @name setLineJoin | ||
1832 | */ | ||
1833 | API.setLineJoin = function (style) { | ||
1834 | var id = this.CapJoinStyles[style]; | ||
1835 | if (id === undefined) { | ||
1836 | throw new Error("Line join style of '" + style + "' is not recognized. See or extend .CapJoinStyles property for valid styles"); | ||
1837 | } | ||
1838 | lineJoinID = id; | ||
1839 | out(id.toString(10) + ' j'); | ||
1840 | |||
1841 | return this; | ||
1842 | }; | ||
1843 | |||
1844 | // Output is both an internal (for plugins) and external function | ||
1845 | API.output = output; | ||
1846 | |||
1847 | /** | ||
1848 | * Saves as PDF document. An alias of jsPDF.output('save', 'filename.pdf') | ||
1849 | * @param {String} filename The filename including extension. | ||
1850 | * | ||
1851 | * @function | ||
1852 | * @returns {jsPDF} | ||
1853 | * @methodOf jsPDF# | ||
1854 | * @name save | ||
1855 | */ | ||
1856 | API.save = function (filename) { | ||
1857 | API.output('save', filename); | ||
1858 | }; | ||
1859 | |||
1860 | // applying plugins (more methods) ON TOP of built-in API. | ||
1861 | // this is intentional as we allow plugins to override | ||
1862 | // built-ins | ||
1863 | for (plugin in jsPDF.API) { | ||
1864 | if (jsPDF.API.hasOwnProperty(plugin)) { | ||
1865 | if (plugin === 'events' && jsPDF.API.events.length) { | ||
1866 | (function (events, newEvents) { | ||
1867 | |||
1868 | // jsPDF.API.events is a JS Array of Arrays | ||
1869 | // where each Array is a pair of event name, handler | ||
1870 | // Events were added by plugins to the jsPDF instantiator. | ||
1871 | // These are always added to the new instance and some ran | ||
1872 | // during instantiation. | ||
1873 | |||
1874 | var eventname, handler_and_args, i; | ||
1875 | |||
1876 | for (i = newEvents.length - 1; i !== -1; i--) { | ||
1877 | // subscribe takes 3 args: 'topic', function, runonce_flag | ||
1878 | // if undefined, runonce is false. | ||
1879 | // users can attach callback directly, | ||
1880 | // or they can attach an array with [callback, runonce_flag] | ||
1881 | // that's what the "apply" magic is for below. | ||
1882 | eventname = newEvents[i][0]; | ||
1883 | handler_and_args = newEvents[i][1]; | ||
1884 | events.subscribe.apply( | ||
1885 | events, | ||
1886 | [eventname].concat( | ||
1887 | typeof handler_and_args === 'function' ? | ||
1888 | [ handler_and_args ] : | ||
1889 | handler_and_args | ||
1890 | ) | ||
1891 | ); | ||
1892 | } | ||
1893 | }(events, jsPDF.API.events)); | ||
1894 | } else { | ||
1895 | API[plugin] = jsPDF.API[plugin]; | ||
1896 | } | ||
1897 | } | ||
1898 | } | ||
1899 | |||
1900 | ///////////////////////////////////////// | ||
1901 | // continuing initilisation of jsPDF Document object | ||
1902 | ///////////////////////////////////////// | ||
1903 | |||
1904 | |||
1905 | // Add the first page automatically | ||
1906 | addFonts(); | ||
1907 | activeFontKey = 'F1'; | ||
1908 | _addPage(); | ||
1909 | |||
1910 | events.publish('initialized'); | ||
1911 | |||
1912 | return API; | ||
1913 | } | ||
1914 | |||
1915 | /** | ||
1916 | jsPDF.API is a STATIC property of jsPDF class. | ||
1917 | jsPDF.API is an object you can add methods and properties to. | ||
1918 | The methods / properties you add will show up in new jsPDF objects. | ||
1919 | |||
1920 | One property is prepopulated. It is the 'events' Object. Plugin authors can add topics, callbacks to this object. These will be reassigned to all new instances of jsPDF. | ||
1921 | Examples: | ||
1922 | jsPDF.API.events['initialized'] = function(){ 'this' is API object } | ||
1923 | jsPDF.API.events['addFont'] = function(added_font_object){ 'this' is API object } | ||
1924 | |||
1925 | @static | ||
1926 | @public | ||
1927 | @memberOf jsPDF | ||
1928 | @name API | ||
1929 | |||
1930 | @example | ||
1931 | jsPDF.API.mymethod = function(){ | ||
1932 | // 'this' will be ref to internal API object. see jsPDF source | ||
1933 | // , so you can refer to built-in methods like so: | ||
1934 | // this.line(....) | ||
1935 | // this.text(....) | ||
1936 | } | ||
1937 | var pdfdoc = new jsPDF() | ||
1938 | pdfdoc.mymethod() // <- !!!!!! | ||
1939 | */ | ||
1940 | jsPDF.API = {'events': []}; | ||
1941 | |||
1942 | return jsPDF; | ||
1943 | }()); |
amcharts/exporting/jspdf.plugin.addimage.js
File was created | 1 | /** @preserve | |
2 | jsPDF addImage plugin (JPEG only at this time) | ||
3 | Copyright (c) 2012 https://github.com/siefkenj/ | ||
4 | */ | ||
5 | |||
6 | /** | ||
7 | * Permission is hereby granted, free of charge, to any person obtaining | ||
8 | * a copy of this software and associated documentation files (the | ||
9 | * "Software"), to deal in the Software without restriction, including | ||
10 | * without limitation the rights to use, copy, modify, merge, publish, | ||
11 | * distribute, sublicense, and/or sell copies of the Software, and to | ||
12 | * permit persons to whom the Software is furnished to do so, subject to | ||
13 | * the following conditions: | ||
14 | * | ||
15 | * The above copyright notice and this permission notice shall be | ||
16 | * included in all copies or substantial portions of the Software. | ||
17 | * | ||
18 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | ||
19 | * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | ||
20 | * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND | ||
21 | * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE | ||
22 | * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION | ||
23 | * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION | ||
24 | * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||
25 | * ==================================================================== | ||
26 | */ | ||
27 | |||
28 | ;(function(jsPDFAPI) { | ||
29 | 'use strict' | ||
30 | |||
31 | var namespace = 'addImage_' | ||
32 | |||
33 | // takes a string imgData containing the raw bytes of | ||
34 | // a jpeg image and returns [width, height] | ||
35 | // Algorithm from: http://www.64lines.com/jpeg-width-height | ||
36 | var getJpegSize = function(imgData) { | ||
37 | 'use strict' | ||
38 | var width, height; | ||
39 | // Verify we have a valid jpeg header 0xff,0xd8,0xff,0xe0,?,?,'J','F','I','F',0x00 | ||
40 | if (!imgData.charCodeAt(0) === 0xff || | ||
41 | !imgData.charCodeAt(1) === 0xd8 || | ||
42 | !imgData.charCodeAt(2) === 0xff || | ||
43 | !imgData.charCodeAt(3) === 0xe0 || | ||
44 | !imgData.charCodeAt(6) === 'J'.charCodeAt(0) || | ||
45 | !imgData.charCodeAt(7) === 'F'.charCodeAt(0) || | ||
46 | !imgData.charCodeAt(8) === 'I'.charCodeAt(0) || | ||
47 | !imgData.charCodeAt(9) === 'F'.charCodeAt(0) || | ||
48 | !imgData.charCodeAt(10) === 0x00) { | ||
49 | throw new Error('getJpegSize requires a binary jpeg file') | ||
50 | } | ||
51 | var blockLength = imgData.charCodeAt(4)*256 + imgData.charCodeAt(5); | ||
52 | var i = 4, len = imgData.length; | ||
53 | while ( i < len ) { | ||
54 | i += blockLength; | ||
55 | if (imgData.charCodeAt(i) !== 0xff) { | ||
56 | throw new Error('getJpegSize could not find the size of the image'); | ||
57 | } | ||
58 | if (imgData.charCodeAt(i+1) === 0xc0 || //(SOF) Huffman - Baseline DCT | ||
59 | imgData.charCodeAt(i+1) === 0xc1 || //(SOF) Huffman - Extended sequential DCT | ||
60 | imgData.charCodeAt(i+1) === 0xc2 || // Progressive DCT (SOF2) | ||
61 | imgData.charCodeAt(i+1) === 0xc3 || // Spatial (sequential) lossless (SOF3) | ||
62 | imgData.charCodeAt(i+1) === 0xc4 || // Differential sequential DCT (SOF5) | ||
63 | imgData.charCodeAt(i+1) === 0xc5 || // Differential progressive DCT (SOF6) | ||
64 | imgData.charCodeAt(i+1) === 0xc6 || // Differential spatial (SOF7) | ||
65 | imgData.charCodeAt(i+1) === 0xc7) { | ||
66 | height = imgData.charCodeAt(i+5)*256 + imgData.charCodeAt(i+6); | ||
67 | width = imgData.charCodeAt(i+7)*256 + imgData.charCodeAt(i+8); | ||
68 | return [width, height]; | ||
69 | } else { | ||
70 | i += 2; | ||
71 | blockLength = imgData.charCodeAt(i)*256 + imgData.charCodeAt(i+1) | ||
72 | } | ||
73 | } | ||
74 | } | ||
75 | // Image functionality ported from pdf.js | ||
76 | , putImage = function(img) { | ||
77 | var objectNumber = this.internal.newObject() | ||
78 | , out = this.internal.write | ||
79 | , putStream = this.internal.putStream | ||
80 | |||
81 | img['n'] = objectNumber | ||
82 | |||
83 | out('<</Type /XObject') | ||
84 | out('/Subtype /Image') | ||
85 | out('/Width ' + img['w']) | ||
86 | out('/Height ' + img['h']) | ||
87 | if (img['cs'] === 'Indexed') { | ||
88 | out('/ColorSpace [/Indexed /DeviceRGB ' | ||
89 | + (img['pal'].length / 3 - 1) + ' ' + (objectNumber + 1) | ||
90 | + ' 0 R]'); | ||
91 | } else { | ||
92 | out('/ColorSpace /' + img['cs']); | ||
93 | if (img['cs'] === 'DeviceCMYK') { | ||
94 | out('/Decode [1 0 1 0 1 0 1 0]'); | ||
95 | } | ||
96 | } | ||
97 | out('/BitsPerComponent ' + img['bpc']); | ||
98 | if ('f' in img) { | ||
99 | out('/Filter /' + img['f']); | ||
100 | } | ||
101 | if ('dp' in img) { | ||
102 | out('/DecodeParms <<' + img['dp'] + '>>'); | ||
103 | } | ||
104 | if ('trns' in img && img['trns'].constructor == Array) { | ||
105 | var trns = ''; | ||
106 | for ( var i = 0; i < img['trns'].length; i++) { | ||
107 | trns += (img[trns][i] + ' ' + img['trns'][i] + ' '); | ||
108 | out('/Mask [' + trns + ']'); | ||
109 | } | ||
110 | } | ||
111 | if ('smask' in img) { | ||
112 | out('/SMask ' + (objectNumber + 1) + ' 0 R'); | ||
113 | } | ||
114 | out('/Length ' + img['data'].length + '>>'); | ||
115 | |||
116 | putStream(img['data']); | ||
117 | |||
118 | out('endobj'); | ||
119 | } | ||
120 | , putResourcesCallback = function() { | ||
121 | var images = this.internal.collections[namespace + 'images'] | ||
122 | for ( var i in images ) { | ||
123 | putImage.call(this, images[i]) | ||
124 | } | ||
125 | } | ||
126 | , putXObjectsDictCallback = function(){ | ||
127 | var images = this.internal.collections[namespace + 'images'] | ||
128 | , out = this.internal.write | ||
129 | , image | ||
130 | for (var i in images) { | ||
131 | image = images[i] | ||
132 | out( | ||
133 | '/I' + image['i'] | ||
134 | , image['n'] | ||
135 | , '0' | ||
136 | , 'R' | ||
137 | ) | ||
138 | } | ||
139 | } | ||
140 | |||
141 | jsPDFAPI.addImage = function(imageData, format, x, y, w, h) { | ||
142 | 'use strict' | ||
143 | if (typeof imageData === 'object' && imageData.nodeType === 1) { | ||
144 | var canvas = document.createElement('canvas'); | ||
145 | canvas.width = imageData.clientWidth; | ||
146 | canvas.height = imageData.clientHeight; | ||
147 | |||
148 | var ctx = canvas.getContext('2d'); | ||
149 | if (!ctx) { | ||
150 | throw ('addImage requires canvas to be supported by browser.'); | ||
151 | } | ||
152 | ctx.drawImage(imageData, 0, 0, canvas.width, canvas.height); | ||
153 | imageData = canvas.toDataURL('image/jpeg'); | ||
154 | format = "JPEG"; | ||
155 | } | ||
156 | if (format.toUpperCase() !== 'JPEG') { | ||
157 | throw new Error('addImage currently only supports format \'JPEG\', not \''+format+'\''); | ||
158 | } | ||
159 | |||
160 | var imageIndex | ||
161 | , images = this.internal.collections[namespace + 'images'] | ||
162 | , coord = this.internal.getCoordinateString | ||
163 | , vcoord = this.internal.getVerticalCoordinateString; | ||
164 | |||
165 | // Detect if the imageData is raw binary or Data URL | ||
166 | if (imageData.substring(0, 23) === 'data:image/jpeg;base64,') { | ||
167 | imageData = atob(imageData.replace('data:image/jpeg;base64,', '')); | ||
168 | } | ||
169 | |||
170 | if (images){ | ||
171 | // this is NOT the first time this method is ran on this instance of jsPDF object. | ||
172 | imageIndex = Object.keys ? | ||
173 | Object.keys(images).length : | ||
174 | (function(o){ | ||
175 | var i = 0 | ||
176 | for (var e in o){if(o.hasOwnProperty(e)){ i++ }} | ||
177 | return i | ||
178 | })(images) | ||
179 | } else { | ||
180 | // this is the first time this method is ran on this instance of jsPDF object. | ||
181 | imageIndex = 0 | ||
182 | this.internal.collections[namespace + 'images'] = images = {} | ||
183 | this.internal.events.subscribe('putResources', putResourcesCallback) | ||
184 | this.internal.events.subscribe('putXobjectDict', putXObjectsDictCallback) | ||
185 | } | ||
186 | |||
187 | var dims = getJpegSize(imageData); | ||
188 | var info = { | ||
189 | w : dims[0], | ||
190 | h : dims[1], | ||
191 | cs : 'DeviceRGB', | ||
192 | bpc : 8, | ||
193 | f : 'DCTDecode', | ||
194 | i : imageIndex, | ||
195 | data : imageData | ||
196 | // n: objectNumber will be added by putImage code | ||
197 | |||
198 | }; | ||
199 | images[imageIndex] = info | ||
200 | if (!w && !h) { | ||
201 | w = -96; | ||
202 | h = -96; | ||
203 | } | ||
204 | if (w < 0) { | ||
205 | w = (-1) * info['w'] * 72 / w / this.internal.scaleFactor; | ||
206 | } | ||
207 | if (h < 0) { | ||
208 | h = (-1) * info['h'] * 72 / h / this.internal.scaleFactor; | ||
209 | } | ||
210 | if (w === 0) { | ||
211 | w = h * info['w'] / info['h']; | ||
212 | } | ||
213 | if (h === 0) { | ||
214 | h = w * info['h'] / info['w']; | ||
215 | } | ||
216 | |||
217 | this.internal.write( | ||
218 | 'q' | ||
219 | , coord(w) | ||
220 | , '0 0' | ||
221 | , coord(h) // TODO: check if this should be shifted by vcoord | ||
222 | , coord(x) | ||
223 | , vcoord(y + h) | ||
224 | , 'cm /I'+info['i'] | ||
225 | , 'Do Q' | ||
226 | ) | ||
227 | |||
228 | return this | ||
229 | } | ||
230 | })(jsPDF.API) |
amcharts/exporting/rgbcolor.js
File was created | 1 | /** | |
2 | * A class to parse color values | ||
3 | * @author Stoyan Stefanov <sstoo@gmail.com> | ||
4 | * @link http://www.phpied.com/rgb-color-parser-in-javascript/ | ||
5 | * @license Use it if you like it | ||
6 | */ | ||
7 | function RGBColor(color_string) | ||
8 | { | ||
9 | this.ok = false; | ||
10 | |||
11 | // strip any leading # | ||
12 | if (color_string.charAt(0) == '#') { // remove # if any | ||
13 | color_string = color_string.substr(1,6); | ||
14 | } | ||
15 | |||
16 | color_string = color_string.replace(/ /g,''); | ||
17 | color_string = color_string.toLowerCase(); | ||
18 | |||
19 | // before getting into regexps, try simple matches | ||
20 | // and overwrite the input | ||
21 | var simple_colors = { | ||
22 | aliceblue: 'f0f8ff', | ||
23 | antiquewhite: 'faebd7', | ||
24 | aqua: '00ffff', | ||
25 | aquamarine: '7fffd4', | ||
26 | azure: 'f0ffff', | ||
27 | beige: 'f5f5dc', | ||
28 | bisque: 'ffe4c4', | ||
29 | black: '000000', | ||
30 | blanchedalmond: 'ffebcd', | ||
31 | blue: '0000ff', | ||
32 | blueviolet: '8a2be2', | ||
33 | brown: 'a52a2a', | ||
34 | burlywood: 'deb887', | ||
35 | cadetblue: '5f9ea0', | ||
36 | chartreuse: '7fff00', | ||
37 | chocolate: 'd2691e', | ||
38 | coral: 'ff7f50', | ||
39 | cornflowerblue: '6495ed', | ||
40 | cornsilk: 'fff8dc', | ||
41 | crimson: 'dc143c', | ||
42 | cyan: '00ffff', | ||
43 | darkblue: '00008b', | ||
44 | darkcyan: '008b8b', | ||
45 | darkgoldenrod: 'b8860b', | ||
46 | darkgray: 'a9a9a9', | ||
47 | darkgreen: '006400', | ||
48 | darkkhaki: 'bdb76b', | ||
49 | darkmagenta: '8b008b', | ||
50 | darkolivegreen: '556b2f', | ||
51 | darkorange: 'ff8c00', | ||
52 | darkorchid: '9932cc', | ||
53 | darkred: '8b0000', | ||
54 | darksalmon: 'e9967a', | ||
55 | darkseagreen: '8fbc8f', | ||
56 | darkslateblue: '483d8b', | ||
57 | darkslategray: '2f4f4f', | ||
58 | darkturquoise: '00ced1', | ||
59 | darkviolet: '9400d3', | ||
60 | deeppink: 'ff1493', | ||
61 | deepskyblue: '00bfff', | ||
62 | dimgray: '696969', | ||
63 | dodgerblue: '1e90ff', | ||
64 | feldspar: 'd19275', | ||
65 | firebrick: 'b22222', | ||
66 | floralwhite: 'fffaf0', | ||
67 | forestgreen: '228b22', | ||
68 | fuchsia: 'ff00ff', | ||
69 | gainsboro: 'dcdcdc', | ||
70 | ghostwhite: 'f8f8ff', | ||
71 | gold: 'ffd700', | ||
72 | goldenrod: 'daa520', | ||
73 | gray: '808080', | ||
74 | green: '008000', | ||
75 | greenyellow: 'adff2f', | ||
76 | honeydew: 'f0fff0', | ||
77 | hotpink: 'ff69b4', | ||
78 | indianred : 'cd5c5c', | ||
79 | indigo : '4b0082', | ||
80 | ivory: 'fffff0', | ||
81 | khaki: 'f0e68c', | ||
82 | lavender: 'e6e6fa', | ||
83 | lavenderblush: 'fff0f5', | ||
84 | lawngreen: '7cfc00', | ||
85 | lemonchiffon: 'fffacd', | ||
86 | lightblue: 'add8e6', | ||
87 | lightcoral: 'f08080', | ||
88 | lightcyan: 'e0ffff', | ||
89 | lightgoldenrodyellow: 'fafad2', | ||
90 | lightgrey: 'd3d3d3', | ||
91 | lightgreen: '90ee90', | ||
92 | lightpink: 'ffb6c1', | ||
93 | lightsalmon: 'ffa07a', | ||
94 | lightseagreen: '20b2aa', | ||
95 | lightskyblue: '87cefa', | ||
96 | lightslateblue: '8470ff', | ||
97 | lightslategray: '778899', | ||
98 | lightsteelblue: 'b0c4de', | ||
99 | lightyellow: 'ffffe0', | ||
100 | lime: '00ff00', | ||
101 | limegreen: '32cd32', | ||
102 | linen: 'faf0e6', | ||
103 | magenta: 'ff00ff', | ||
104 | maroon: '800000', | ||
105 | mediumaquamarine: '66cdaa', | ||
106 | mediumblue: '0000cd', | ||
107 | mediumorchid: 'ba55d3', | ||
108 | mediumpurple: '9370d8', | ||
109 | mediumseagreen: '3cb371', | ||
110 | mediumslateblue: '7b68ee', | ||
111 | mediumspringgreen: '00fa9a', | ||
112 | mediumturquoise: '48d1cc', | ||
113 | mediumvioletred: 'c71585', | ||
114 | midnightblue: '191970', | ||
115 | mintcream: 'f5fffa', | ||
116 | mistyrose: 'ffe4e1', | ||
117 | moccasin: 'ffe4b5', | ||
118 | navajowhite: 'ffdead', | ||
119 | navy: '000080', | ||
120 | oldlace: 'fdf5e6', | ||
121 | olive: '808000', | ||
122 | olivedrab: '6b8e23', | ||
123 | orange: 'ffa500', | ||
124 | orangered: 'ff4500', | ||
125 | orchid: 'da70d6', | ||
126 | palegoldenrod: 'eee8aa', | ||
127 | palegreen: '98fb98', | ||
128 | paleturquoise: 'afeeee', | ||
129 | palevioletred: 'd87093', | ||
130 | papayawhip: 'ffefd5', | ||
131 | peachpuff: 'ffdab9', | ||
132 | peru: 'cd853f', | ||
133 | pink: 'ffc0cb', | ||
134 | plum: 'dda0dd', | ||
135 | powderblue: 'b0e0e6', | ||
136 | purple: '800080', | ||
137 | red: 'ff0000', | ||
138 | rosybrown: 'bc8f8f', | ||
139 | royalblue: '4169e1', | ||
140 | saddlebrown: '8b4513', | ||
141 | salmon: 'fa8072', | ||
142 | sandybrown: 'f4a460', | ||
143 | seagreen: '2e8b57', | ||
144 | seashell: 'fff5ee', | ||
145 | sienna: 'a0522d', | ||
146 | silver: 'c0c0c0', | ||
147 | skyblue: '87ceeb', | ||
148 | slateblue: '6a5acd', | ||
149 | slategray: '708090', | ||
150 | snow: 'fffafa', | ||
151 | springgreen: '00ff7f', | ||
152 | steelblue: '4682b4', | ||
153 | tan: 'd2b48c', | ||
154 | teal: '008080', | ||
155 | thistle: 'd8bfd8', | ||
156 | tomato: 'ff6347', | ||
157 | turquoise: '40e0d0', | ||
158 | violet: 'ee82ee', | ||
159 | violetred: 'd02090', | ||
160 | wheat: 'f5deb3', | ||
161 | white: 'ffffff', | ||
162 | whitesmoke: 'f5f5f5', | ||
163 | yellow: 'ffff00', | ||
164 | yellowgreen: '9acd32' | ||
165 | }; | ||
166 | for (var key in simple_colors) { | ||
167 | if (color_string == key) { | ||
168 | color_string = simple_colors[key]; | ||
169 | } | ||
170 | } | ||
171 | // emd of simple type-in colors | ||
172 | |||
173 | // array of color definition objects | ||
174 | var color_defs = [ | ||
175 | { | ||
176 | re: /^rgb\((\d{1,3}),\s*(\d{1,3}),\s*(\d{1,3})\)$/, | ||
177 | example: ['rgb(123, 234, 45)', 'rgb(255,234,245)'], | ||
178 | process: function (bits){ | ||
179 | return [ | ||
180 | parseInt(bits[1]), | ||
181 | parseInt(bits[2]), | ||
182 | parseInt(bits[3]) | ||
183 | ]; | ||
184 | } | ||
185 | }, | ||
186 | { | ||
187 | re: /^(\w{2})(\w{2})(\w{2})$/, | ||
188 | example: ['#00ff00', '336699'], | ||
189 | process: function (bits){ | ||
190 | return [ | ||
191 | parseInt(bits[1], 16), | ||
192 | parseInt(bits[2], 16), | ||
193 | parseInt(bits[3], 16) | ||
194 | ]; | ||
195 | } | ||
196 | }, | ||
197 | { | ||
198 | re: /^(\w{1})(\w{1})(\w{1})$/, | ||
199 | example: ['#fb0', 'f0f'], | ||
200 | process: function (bits){ | ||
201 | return [ | ||
202 | parseInt(bits[1] + bits[1], 16), | ||
203 | parseInt(bits[2] + bits[2], 16), | ||
204 | parseInt(bits[3] + bits[3], 16) | ||
205 | ]; | ||
206 | } | ||
207 | } | ||
208 | ]; | ||
209 | |||
210 | // search through the definitions to find a match | ||
211 | for (var i = 0; i < color_defs.length; i++) { | ||
212 | var re = color_defs[i].re; | ||
213 | var processor = color_defs[i].process; | ||
214 | var bits = re.exec(color_string); | ||
215 | if (bits) { | ||
216 | channels = processor(bits); | ||
217 | this.r = channels[0]; | ||
218 | this.g = channels[1]; | ||
219 | this.b = channels[2]; | ||
220 | this.ok = true; | ||
221 | } | ||
222 | |||
223 | } | ||
224 | |||
225 | // validate/cleanup values | ||
226 | this.r = (this.r < 0 || isNaN(this.r)) ? 0 : ((this.r > 255) ? 255 : this.r); | ||
227 | this.g = (this.g < 0 || isNaN(this.g)) ? 0 : ((this.g > 255) ? 255 : this.g); | ||
228 | this.b = (this.b < 0 || isNaN(this.b)) ? 0 : ((this.b > 255) ? 255 : this.b); | ||
229 | |||
230 | // some getters | ||
231 | this.toRGB = function () { | ||
232 | return 'rgb(' + this.r + ', ' + this.g + ', ' + this.b + ')'; | ||
233 | } | ||
234 | this.toHex = function () { | ||
235 | var r = this.r.toString(16); | ||
236 | var g = this.g.toString(16); | ||
237 | var b = this.b.toString(16); | ||
238 | if (r.length == 1) r = '0' + r; | ||
239 | if (g.length == 1) g = '0' + g; | ||
240 | if (b.length == 1) b = '0' + b; | ||
241 | return '#' + r + g + b; | ||
242 | } | ||
243 | |||
244 | // help | ||
245 | this.getHelpXML = function () { | ||
246 | |||
247 | var examples = new Array(); | ||
248 | // add regexps | ||
249 | for (var i = 0; i < color_defs.length; i++) { | ||
250 | var example = color_defs[i].example; | ||
251 | for (var j = 0; j < example.length; j++) { | ||
252 | examples[examples.length] = example[j]; | ||
253 | } | ||
254 | } | ||
255 | // add type-in colors | ||
256 | for (var sc in simple_colors) { | ||
257 | examples[examples.length] = sc; | ||
258 | } | ||
259 | |||
260 | var xml = document.createElement('ul'); | ||
261 | xml.setAttribute('id', 'rgbcolor-examples'); | ||
262 | for (var i = 0; i < examples.length; i++) { | ||
263 | try { | ||
264 | var list_item = document.createElement('li'); | ||
265 | var list_color = new RGBColor(examples[i]); | ||
266 | var example_div = document.createElement('div'); | ||
267 | example_div.style.cssText = | ||
268 | 'margin: 3px; ' | ||
269 | + 'border: 1px solid black; ' | ||
270 | + 'background:' + list_color.toHex() + '; ' | ||
271 | + 'color:' + list_color.toHex() | ||
272 | ; | ||
273 | example_div.appendChild(document.createTextNode('test')); | ||
274 | var list_item_value = document.createTextNode( | ||
275 | ' ' + examples[i] + ' -> ' + list_color.toRGB() + ' -> ' + list_color.toHex() | ||
276 | ); | ||
277 | list_item.appendChild(example_div); | ||
278 | list_item.appendChild(list_item_value); | ||
279 | xml.appendChild(list_item); | ||
280 | |||
281 | } catch(e){} | ||
282 | } | ||
283 | return xml; | ||
284 | |||
285 | } | ||
286 | |||
287 | } | ||
288 | |||
289 |
amcharts/funnel.js
File was created | 1 | AmCharts.AmFunnelChart=AmCharts.Class({inherits:AmCharts.AmSlicedChart,construct:function(u){this.type="funnel";AmCharts.AmFunnelChart.base.construct.call(this,u);this.cname="AmFunnelChart";this.startX=this.startY=0;this.baseWidth="100%";this.neckHeight=this.neckWidth=0;this.rotate=!1;this.valueRepresents="height";this.pullDistance=30;this.labelPosition="center";this.labelText="[[title]]: [[value]]";this.balloonText="[[title]]: [[value]]\n[[description]]";AmCharts.applyTheme(this,u,this.cname)},drawChart:function(){AmCharts.AmFunnelChart.base.drawChart.call(this); | |
2 | var u=this.chartData;if(AmCharts.ifArray(u))if(0<this.realWidth&&0<this.realHeight){var t=this.container,D=this.startDuration,k=this.rotate,x=this.updateWidth();this.realWidth=x;var g=this.updateHeight();this.realHeight=g;var q=AmCharts.toCoordinate,A=q(this.marginLeft,x),v=q(this.marginRight,x),a=q(this.marginTop,g)+this.getTitleHeight(),q=q(this.marginBottom,g),v=x-A-v,y=AmCharts.toCoordinate(this.baseWidth,v),l=AmCharts.toCoordinate(this.neckWidth,v),z=g-q-a,w=AmCharts.toCoordinate(this.neckHeight, | ||
3 | z),r=a+z-w;k&&(a=g-q,r=a-z+w);this.firstSliceY=a;AmCharts.VML&&(this.startAlpha=1);for(var h=v/2+A,E=(z-w)/((y-l)/2),m=y/2,y=(z-w)*(y+l)/2+l*w,B=a,F=0,w=0;w<u.length;w++){var c=u[w],d;if(!0!==c.hidden){var n=[],e=[],b;if("height"==this.valueRepresents)b=z*c.percents/100;else{var p=-y*c.percents/100/2,C=m;d=-1/(2*E);b=Math.pow(C,2)-4*d*p;0>b&&(b=0);b=(Math.sqrt(b)-C)/(2*d);if(!k&&a>=r||k&&a<=r)b=2*-p/l;else if(!k&&a+b>r||k&&a-b<r)d=k?Math.round(b+(a-b-r)):Math.round(b-(a+b-r)),b=d/E,b=d+2*(-p-(C-b/ | ||
4 | 2)*d)/l}p=m-b/E;C=!1;!k&&a+b>r||k&&a-b<r?(p=l/2,n.push(h-m,h+m,h+p,h+p,h-p,h-p),k?(d=b+(a-b-r),a<r&&(d=0),e.push(a,a,a-d,a-b,a-b,a-d,a)):(d=b-(a+b-r),a>r&&(d=0),e.push(a,a,a+d,a+b,a+b,a+d,a)),C=!0):(n.push(h-m,h+m,h+p,h-p),k?e.push(a,a,a-b,a-b):e.push(a,a,a+b,a+b));t.set();d=t.set();n=AmCharts.polygon(t,n,e,c.color,c.alpha,this.outlineThickness,this.outlineColor,this.outlineAlpha);d.push(n);this.graphsSet.push(d);c.wedge=d;c.index=w;if(e=this.gradientRatio){var s=[],f;for(f=0;f<e.length;f++)s.push(AmCharts.adjustLuminosity(c.color, | ||
5 | e[f]));0<s.length&&n.gradient("linearGradient",s);c.pattern&&n.pattern(c.pattern)}0<D&&(this.chartCreated||d.setAttr("opacity",this.startAlpha));this.addEventListeners(d,c);c.ty0=a-b/2;this.labelsEnabled&&this.labelText&&c.percents>=this.hideLabelsPercent&&(e=this.formatString(this.labelText,c),(n=this.labelFunction)&&(e=n(c,e)),s=c.labelColor,s||(s=this.color),n=this.labelPosition,f="left","center"==n&&(f="middle"),"left"==n&&(f="right"),e=AmCharts.wrappedText(t,e,s,this.fontFamily,this.fontSize, | ||
6 | f,!1,this.maxLabelWidth),e.node.style.pointerEvents="none",d.push(e),s=h,k?(f=a-b/2,c.ty0=f):(f=a+b/2,c.ty0=f,f<B+F+5&&(f=B+F+5),f>g-q&&(f=g-q)),"right"==n&&(s=v+10+A,c.tx0=h+(m-b/2/E),C&&(c.tx0=h+p)),"left"==n&&(c.tx0=h-(m-b/2/E),C&&(c.tx0=h-p),s=A),c.label=e,c.labelX=s,c.labelY=f,c.labelHeight=e.getBBox().height,e.translate(s,f),m=e.getBBox(),B=AmCharts.rect(t,m.width+5,m.height+5,"#ffffff",.005),B.translate(s+m.x,f+m.y),d.push(B),c.hitRect=B,F=e.getBBox().height,B=f);(0===c.alpha||0<D&&!this.chartCreated)&& | ||
7 | d.hide();a=k?a-b:a+b;m=p;c.startX=AmCharts.toCoordinate(this.startX,x);c.startY=AmCharts.toCoordinate(this.startY,g);c.pullX=AmCharts.toCoordinate(this.pullDistance,x);c.pullY=0;c.balloonX=h;c.balloonY=c.ty0}}this.arrangeLabels();this.initialStart();(u=this.legend)&&u.invalidateSize()}else this.cleanChart();this.dispDUpd();this.chartCreated=!0},arrangeLabels:function(){var u=this.rotate,t;t=u?0:this.realHeight;for(var D=0,k=this.chartData,x=k.length,g,q=0;q<x;q++){g=k[x-q-1];var A=g.label,v=g.labelY, | ||
8 | a=g.labelX,y=g.labelHeight,l=v;u?t+D+5>v&&(l=t+D+5):v+y+5>t&&(l=t-5-y);t=l;D=y;if(A){A.translate(a,l);var z=A.getBBox()}g.hitRect.translate(a+z.x,l+z.y);g.labelY=l;g.tx=a;g.ty=l;g.tx2=a}"center"!=this.labelPosition&&this.drawTicks()}}); |
amcharts/gauge.js
File was created | 1 | AmCharts.GaugeAxis=AmCharts.Class({construct:function(a){this.cname="GaugeAxis";this.radius="95%";this.startAngle=-120;this.endAngle=120;this.startValue=0;this.endValue=200;this.gridCount=5;this.tickLength=10;this.minorTickLength=5;this.tickColor="#555555";this.labelFrequency=this.tickThickness=this.tickAlpha=1;this.inside=!0;this.labelOffset=10;this.showLastLabel=this.showFirstLabel=!0;this.axisThickness=1;this.axisColor="#000000";this.axisAlpha=1;this.gridInside=!0;this.topTextYOffset=0;this.topTextBold= | |
2 | !0;this.bottomTextYOffset=0;this.bottomTextBold=!0;this.centerY=this.centerX="0%";this.bandOutlineAlpha=this.bandOutlineThickness=0;this.bandOutlineColor="#000000";this.bandAlpha=1;AmCharts.applyTheme(this,a,"GaugeAxis")},value2angle:function(a){return(a-this.startValue)/(this.endValue-this.startValue)*(this.endAngle-this.startAngle)+this.startAngle},setTopText:function(a){if(void 0!==a){this.topText=a;var b=this.chart;if(this.axisCreated){this.topTF&&this.topTF.remove();var c=this.topTextFontSize; | ||
3 | c||(c=b.fontSize);var d=this.topTextColor;d||(d=b.color);a=AmCharts.text(b.container,a,d,b.fontFamily,c,void 0,this.topTextBold);a.translate(this.centerXReal,this.centerYReal-this.radiusReal/2+this.topTextYOffset);this.chart.graphsSet.push(a);this.topTF=a}}},setBottomText:function(a){if(void 0!==a){this.bottomText=a;var b=this.chart;if(this.axisCreated){this.bottomTF&&this.bottomTF.remove();var c=this.bottomTextFontSize;c||(c=b.fontSize);var d=this.bottomTextColor;d||(d=b.color);a=AmCharts.text(b.container, | ||
4 | a,d,b.fontFamily,c,void 0,this.bottomTextBold);a.translate(this.centerXReal,this.centerYReal+this.radiusReal/2+this.bottomTextYOffset);this.bottomTF=a;this.chart.graphsSet.push(a)}}},draw:function(){var a=this.chart,b=a.graphsSet,c=this.startValue,d=this.endValue,f=this.valueInterval;isNaN(f)&&(f=(d-c)/this.gridCount);var m=this.minorTickInterval;isNaN(m)&&(m=f/5);var p=this.startAngle,k=this.endAngle,e=this.tickLength,l=(d-c)/f+1,g=(k-p)/(l-1);this.singleValueAngle=d=g/f;var h=a.container,q=this.tickColor, | ||
5 | u=this.tickAlpha,C=this.tickThickness,D=f/m,F=g/D,m=this.minorTickLength,I=this.labelFrequency,s=this.radiusReal;this.inside||(s-=15);var y=a.centerX+AmCharts.toCoordinate(this.centerX,a.realWidth),z=a.centerY+AmCharts.toCoordinate(this.centerY,a.realHeight);this.centerXReal=y;this.centerYReal=z;var J={fill:this.axisColor,"fill-opacity":this.axisAlpha,"stroke-width":0,"stroke-opacity":0},n,A;this.gridInside?A=n=s:(n=s-e,A=n+m);var r=this.axisThickness/2,k=AmCharts.wedge(h,y,z,p,k-p,n+r,n+r,n-r,0, | ||
6 | J);b.push(k);k=AmCharts.doNothing;AmCharts.isModern||(k=Math.round);J=AmCharts.getDecimals(f);for(n=0;n<l;n++){var w=c+n*f,r=p+n*g,v=k(y+s*Math.sin(r/180*Math.PI)),B=k(z-s*Math.cos(r/180*Math.PI)),x=k(y+(s-e)*Math.sin(r/180*Math.PI)),t=k(z-(s-e)*Math.cos(r/180*Math.PI)),v=AmCharts.line(h,[v,x],[B,t],q,u,C,0,!1,!1,!0);b.push(v);v=-1;x=this.labelOffset;this.inside||(x=-x-e,v=1);var B=Math.sin(r/180*Math.PI),t=Math.cos(r/180*Math.PI),B=y+(s-e-x)*B,x=z-(s-e-x)*t,E=this.fontSize;isNaN(E)&&(E=a.fontSize); | ||
7 | var t=Math.sin((r-90)/180*Math.PI),K=Math.cos((r-90)/180*Math.PI);if(0<I&&n/I==Math.round(n/I)&&(this.showLastLabel||n!=l-1)&&(this.showFirstLabel||0!==n)){var G=AmCharts.formatNumber(w,a.nf,J),H=this.unit;H&&(G="left"==this.unitPosition?H+G:G+H);(H=this.labelFunction)&&(G=H(w));w=AmCharts.text(h,G,a.color,a.fontFamily,E);E=w.getBBox();w.translate(B+v*E.width/2*K,x+v*E.height/2*t);b.push(w)}if(n<l-1)for(w=1;w<D;w++)t=r+F*w,v=k(y+A*Math.sin(t/180*Math.PI)),B=k(z-A*Math.cos(t/180*Math.PI)),x=k(y+(A- | ||
8 | m)*Math.sin(t/180*Math.PI)),t=k(z-(A-m)*Math.cos(t/180*Math.PI)),v=AmCharts.line(h,[v,x],[B,t],q,u,C,0,!1,!1,!0),b.push(v)}if(b=this.bands)for(c=0;c<b.length;c++)if(f=b[c])q=f.startValue,u=f.endValue,e=AmCharts.toCoordinate(f.radius,s),isNaN(e)&&(e=A),l=AmCharts.toCoordinate(f.innerRadius,s),isNaN(l)&&(l=e-m),g=p+d*(q-this.startValue),u=d*(u-q),C=f.outlineColor,void 0==C&&(C=this.bandOutlineColor),D=f.outlineThickness,isNaN(D)&&(D=this.bandOutlineThickness),F=f.outlineAlpha,isNaN(F)&&(F=this.bandOutlineAlpha), | ||
9 | q=f.alpha,isNaN(q)&&(q=this.bandAlpha),e=AmCharts.wedge(h,y,z,g,u,e,e,l,0,{fill:f.color,stroke:C,"stroke-width":D,"stroke-opacity":F}),e.setAttr("opacity",q),a.gridSet.push(e),this.addEventListeners(e,f);this.axisCreated=!0;this.setTopText(this.topText);this.setBottomText(this.bottomText);a=a.graphsSet.getBBox();this.width=a.width;this.height=a.height},addEventListeners:function(a,b){var c=this.chart;a.mouseover(function(a){c.showBalloon(b.balloonText,b.color,!0)}).mouseout(function(a){c.hideBalloon()})}});AmCharts.GaugeArrow=AmCharts.Class({construct:function(a){this.cname="GaugeArrow";this.color="#000000";this.nailAlpha=this.alpha=1;this.startWidth=this.nailRadius=8;this.endWidth=0;this.borderAlpha=1;this.radius="90%";this.nailBorderAlpha=this.innerRadius=0;this.nailBorderThickness=1;this.frame=0;AmCharts.applyTheme(this,a,"GaugeArrow")},setValue:function(a){var b=this.chart;b?b.setValue?b.setValue(this,a):this.previousValue=this.value=a:this.previousValue=this.value=a}}); | ||
10 | AmCharts.GaugeBand=AmCharts.Class({construct:function(){this.cname="GaugeBand"}});AmCharts.AmAngularGauge=AmCharts.Class({inherits:AmCharts.AmChart,construct:function(a){this.cname="AmAngularGauge";AmCharts.AmAngularGauge.base.construct.call(this,a);this.theme=a;this.type="gauge";this.minRadius=this.marginRight=this.marginBottom=this.marginTop=this.marginLeft=10;this.faceColor="#FAFAFA";this.faceAlpha=0;this.faceBorderWidth=1;this.faceBorderColor="#555555";this.faceBorderAlpha=0;this.arrows=[];this.axes=[];this.startDuration=1;this.startEffect="easeOutSine";this.adjustSize=!0; | ||
11 | this.extraHeight=this.extraWidth=0;AmCharts.applyTheme(this,a,this.cname)},addAxis:function(a){this.axes.push(a)},formatString:function(a,b){return a=AmCharts.formatValue(a,b,["value"],this.nf,"",this.usePrefixes,this.prefixesOfSmallNumbers,this.prefixesOfBigNumbers)},initChart:function(){AmCharts.AmAngularGauge.base.initChart.call(this);var a;0===this.axes.length&&(a=new AmCharts.GaugeAxis(this.theme),this.addAxis(a));var b;for(b=0;b<this.axes.length;b++)a=this.axes[b],a=AmCharts.processObject(a, | ||
12 | AmCharts.GaugeAxis,this.theme),a.chart=this,this.axes[b]=a;var c=this.arrows;for(b=0;b<c.length;b++){a=c[b];a=AmCharts.processObject(a,AmCharts.GaugeArrow,this.theme);a.chart=this;c[b]=a;var d=a.axis;AmCharts.isString(d)&&(a.axis=AmCharts.getObjById(this.axes,d));a.axis||(a.axis=this.axes[0]);isNaN(a.value)&&a.setValue(a.axis.startValue);isNaN(a.previousValue)&&(a.previousValue=a.axis.startValue)}this.setLegendData(c);this.drawChart();this.totalFrames=1E3*this.startDuration/AmCharts.updateRate},drawChart:function(){AmCharts.AmAngularGauge.base.drawChart.call(this); | ||
13 | var a=this.container,b=this.updateWidth();this.realWidth=b;var c=this.updateHeight();this.realHeight=c;var d=AmCharts.toCoordinate,f=d(this.marginLeft,b),m=d(this.marginRight,b),p=d(this.marginTop,c)+this.getTitleHeight(),k=d(this.marginBottom,c),e=d(this.radius,b,c),d=b-f-m,l=c-p-k+this.extraHeight;e||(e=Math.min(d,l)/2);e<this.minRadius&&(e=this.minRadius);this.radiusReal=e;this.centerX=(b-f-m)/2+f;this.centerY=(c-p-k)/2+p+this.extraHeight/2;isNaN(this.gaugeX)||(this.centerX=this.gaugeX);isNaN(this.gaugeY)|| | ||
14 | (this.centerY=this.gaugeY);var b=this.faceAlpha,c=this.faceBorderAlpha,g;if(0<b||0<c)g=AmCharts.circle(a,e,this.faceColor,b,this.faceBorderWidth,this.faceBorderColor,c,!1),g.translate(this.centerX,this.centerY),g.toBack(),(a=this.facePattern)&&g.pattern(a);for(b=e=a=0;b<this.axes.length;b++){c=this.axes[b];f=c.radius;c.radiusReal=AmCharts.toCoordinate(f,this.radiusReal);c.draw();if(-1!==f.indexOf("%"))var h=1+(100-Number(f.substr(0,f.length-1)))/100;c.width*h>a&&(a=c.width*h);c.height*h>e&&(e=c.height* | ||
15 | h)}(h=this.legend)&&h.invalidateSize();if(this.adjustSize&&!this.chartCreated){g&&(g=g.getBBox(),g.width>a&&(a=g.width),g.height>e&&(e=g.height));g=0;if(l>e||d>a)g=Math.min(l-e,d-a);0<g&&(this.extraHeight=l-e,this.chartCreated=!0,this.validateNow())}this.dispDUpd();this.chartCreated=!0},validateSize:function(){this.extraHeight=this.extraWidth=0;this.chartCreated=!1;AmCharts.AmAngularGauge.base.validateSize.call(this)},addArrow:function(a){this.arrows.push(a)},removeArrow:function(a){AmCharts.removeFromArray(this.arrows, | ||
16 | a);this.validateNow()},removeAxis:function(a){AmCharts.removeFromArray(this.axes,a);this.validateNow()},drawArrow:function(a,b){a.set&&a.set.remove();var c=this.container;a.set=c.set();if(!a.hidden){var d=a.axis,f=d.radiusReal,m=d.centerXReal,p=d.centerYReal,k=a.startWidth,e=a.endWidth,l=AmCharts.toCoordinate(a.innerRadius,d.radiusReal),g=AmCharts.toCoordinate(a.radius,d.radiusReal);d.inside||(g-=15);var h=a.nailColor;h||(h=a.color);var q=a.nailColor;q||(q=a.color);h=AmCharts.circle(c,a.nailRadius, | ||
17 | h,a.nailAlpha,a.nailBorderThickness,h,a.nailBorderAlpha);a.set.push(h);h.translate(m,p);isNaN(g)&&(g=f-d.tickLength);var d=Math.sin(b/180*Math.PI),f=Math.cos(b/180*Math.PI),h=Math.sin((b+90)/180*Math.PI),u=Math.cos((b+90)/180*Math.PI),c=AmCharts.polygon(c,[m-k/2*h+l*d,m+g*d-e/2*h,m+g*d+e/2*h,m+k/2*h+l*d],[p+k/2*u-l*f,p-g*f+e/2*u,p-g*f-e/2*u,p-k/2*u-l*f],a.color,a.alpha,1,q,a.borderAlpha,void 0,!0);a.set.push(c);this.graphsSet.push(a.set)}},setValue:function(a,b){a.axis&&a.axis.value2angle&&(a.axis.value2angle(b), | ||
18 | a.frame=0,a.previousValue=a.value);a.value=b;var c=this.legend;c&&c.updateValues()},handleLegendEvent:function(a){var b=a.type;a=a.dataItem;if(!this.legend.data&&a)switch(b){case "hideItem":this.hideArrow(a);break;case "showItem":this.showArrow(a)}},hideArrow:function(a){a.set.hide();a.hidden=!0},showArrow:function(a){a.set.show();a.hidden=!1},updateAnimations:function(){AmCharts.AmAngularGauge.base.updateAnimations.call(this);for(var a=this.arrows.length,b,c=0;c<a;c++){b=this.arrows[c];var d;b.frame>= | ||
19 | this.totalFrames?d=b.value:(b.frame++,b.clockWiseOnly&&b.value<b.previousValue&&(d=b.axis,b.previousValue-=d.endValue-d.startValue),d=AmCharts.getEffect(this.startEffect),d=AmCharts[d](0,b.frame,b.previousValue,b.value-b.previousValue,this.totalFrames),isNaN(d)&&(d=b.value));d=b.axis.value2angle(d);this.drawArrow(b,d)}}}); |
amcharts/images/dragIcon.gif
122 Bytes
amcharts/images/dragIconBlack.gif
122 Bytes
amcharts/images/dragIconH.gif
111 Bytes
amcharts/images/dragIconHBlack.gif
111 Bytes
amcharts/images/export.png
216 Bytes
amcharts/images/exportWhite.png
213 Bytes
amcharts/images/lens.png
257 Bytes
amcharts/images/lensWhite.png
262 Bytes
amcharts/lang/az.js
File was created | 1 | AmCharts.translations.az = {"monthNames":["Yanvar","Fevral","Mart","Aprel","May","Iyun","Iyul","Avqust","Sentyabr","Oktyabr","Noyabr","Dekabr"],"shortMonthNames":["Yan","Fev","Mar","Apr","May","Iyn","Iyl","Avq","Sen","Okt","Noy","Dek"],"dayNames":["Bazar ertษsi","รษrลษnbษ axลamฤฑ","รษrลษnbษ","Cรผmษ axลamฤฑ","Cรผmษ","ลษnbษ","Bazar gรผnรผ"],"shortDayNames":["Ber","รax","รษr","Cax","Cรผm","ลnb","Baz"],"zoomOutText":"Bรผtรผn gรถstษr"} |
amcharts/lang/bg.js
File was created | 1 | AmCharts.translations.bg = {"monthNames":["ะฏะฝัะฐัะธ","ะคะตะฒััะฐัะธ","ะะฐัั","ะะฟัะธะป","ะะฐะน","ะฎะฝะธ","ะฎะปะธ","ะะฒะณััั","ะกะตะฟัะตะผะฒัะธ","ะะบัะพะผะฒัะธ","ะะพะตะผะฒัะธ","ะะตะบะตะผะฒัะธ"],"shortMonthNames":["ะฏะฝั","ะคะตะฒ","ะะฐั","ะะฟั","ะะฐะน","ะฎะฝะธ","ะฎะปะธ","ะะฒะณ","ะกะตะฟ","ะะบั","ะะพะต","ะะตะบ"],"dayNames":["ะะพะฝะตะดะตะปะฝะธะบ","ะัะพัะฝะธะบ","ะกััะดะฐ","ะงะตัะฒััััะบ","ะะตััะบ","ะกัะฑะพัะฐ","ะะตะดะตะปั"],"shortDayNames":["ะะฝ","ะั","ะกั","ะงั","ะั","ะกะฑ","ะะด"],"zoomOutText":"ะะพะบะฐะถะธ ะฒัะธัะบะธ"} |
amcharts/lang/de.js
File was created | 1 | AmCharts.translations.de = { | |
2 | "monthNames": ["Januar", "Februar", "Mรคrz", "April", "Mai", "Juni", "Juli", "August", "September", "Oktober", "November", "Dezember"], | ||
3 | "shortMonthNames": ["Jan", "Feb", "Mรคr", "Apr", "Mai", "Jun", "Jul", "Aug", "Sep", "Okt", "Nov", "Dez"], | ||
4 | "dayNames": ["Montag", "Dienstag", "Mittwoch", "Donnerstag", "Freitag", "Samstag", "Sonntag"], | ||
5 | "shortDayNames": ["Mo", "Di", "Mi", "Do", "Fr", "Sa", "So"], | ||
6 | "zoomOutText": "Alle anzeigen", | ||
7 | "fromText": "Von:", | ||
8 | "toText":"Bis:", | ||
9 | "periodsText":"Ansicht:", | ||
10 | "selectText":"Auswahl:", | ||
11 | "comboBoxSelectText":"Auswahl...", | ||
12 | "compareText":"Vergleichen mit:" | ||
13 | } |
amcharts/lang/es.js
File was created | 1 | AmCharts.translations.es = {"monthNames":["Enero","Febrero","Marzo","Abril","Mayo","Junio","Julio","Agosto","Septiembre","Octubre","Noviembre","Diciembre"],"shortMonthNames":["Ene","Feb","Mar","Abr","May","Jun","Jul","Ago","Sep","Oct","Nov","Dic"],"dayNames":["Lunes","Martes","Miรฉrcoles","Jueves","Viernes","Sรกbado","Domingo"],"shortDayNames":["Lun","Mar","Miรฉ","Jue","Vie","Sรกb","Dom"],"zoomOutText":"Mostrar todos"} |
amcharts/lang/fi.js
File was created | 1 | AmCharts.translations.fi = {"monthNames":["Tammikuu","Helmikuu","Maaliskuu","Huhtikuu","Toukokuu","Kesรคkuu","Heinรคkuu","Elokuu","Syyskuu","Lokakuu","Marraskuu","Joulukuu"],"shortMonthNames":["Tammiย ","Helmiย ","Maalis","Huhtiย ","Toukoย ","Kesรคย ย ","Heinรคย ","Eloย ย ย ","Syysย ย ","Lokaย ย ","Marras","Jouluย "],"dayNames":["Maanantai","Tiistai","Keskiviikko","Torstai","Perjantai","Lauantai","Sunnuntai"],"shortDayNames":["Ma","Ti","Ke","To","Pe","La","Su"],"zoomOutText":"Nรคytรค kaikki"} |
amcharts/lang/fo.js
File was created | 1 | AmCharts.translations.fo = {"monthNames":["Januar","Februar","Mars","Aprรญl","Mai","Juni","Juli","August","September","Oktober","November","Desember"],"shortMonthNames":["Jan","Feb","Mar","Apr","Mai","Jun","Jul","Aug","Sep","Okt","Nov","Des"],"dayNames":["Mรกnadagur","Tรฝsdagur","Mikudagur","Hรณsdagur","Frรญggjadagur","Leygardagur","Sunnudagur"],"shortDayNames":["Mรกn","Tรฝs","Mik","Hรณs","Frรญ","Ley","Sun"],"zoomOutText":"Show all"} |
amcharts/lang/fr.js
File was created | 1 | AmCharts.translations.fr = {"monthNames":["Janvier","Fรฉvrier","Mars","Avril","Mai","Juin","Juillet","Aoรปt","Septembre","Octobre","Novembre","Dรฉcembre"],"shortMonthNames":["Janv.","Fรฉvr.","Mars","Avril","Mai","Juin","Juil.","Aoรปt","Sept.","Oct.","Nov.","Dรฉc."],"dayNames":["Lundi","Mardi","Mercredi","Jeudi","Vendredi","Samedi","Dimanche"],"shortDayNames":["Lun.","Mar.","Mer.","Jeu.","Ven.","Sam.","Dim."],"zoomOutText":"Voir tous"} |
amcharts/lang/hr.js
File was created | 1 | AmCharts.translations.hr = {"monthNames":["Sijeฤanj","Veljaฤa","Oลพujak","Travanj","Svibanj","Lipanj","Srpanj","Kolovoz","Rujan","Listopad","Studeni","Prosinac"],"shortMonthNames":["Sij","Vel","Oลพu","Tra","Svi","Lip","Srp","Kol","Ruj","Lis","Stu","Pro"],"dayNames":["Ponedjeljak","Utorak","Srijeda","ฤetvrtak","Petak","Subota","Nedjelja"],"shortDayNames":["Pon","Uto","Sri","ฤet","Pet","Sub","Ned"],"zoomOutText":"Prikaลพi sve"} |
amcharts/lang/hu.js
File was created | 1 | AmCharts.translations.hu = {"monthNames":["Januรกr","Februรกr","Mรกrcius","รprilis","Mรกjus","Jรบnius","Jรบlius","Augusztus","Szeptember","Oktรณber","November","December"],"shortMonthNames":["Jan","Febr","Mรกrc","รpr","Mรกj","Jรบn","Jรบl","Aug","Szept","Okt","Nov","Dec"],"dayNames":["Hรฉtfล","Kedd","Szerda","Csรผtรถrtรถk","Pรฉntek","Szombat","Vasรกrnap"],"shortDayNames":["H","K","Sze","Cs","P","Szo","V"],"zoomOutText":"รsszes"} |
amcharts/lang/id.js
File was created | 1 | AmCharts.translations.id = {"monthNames":["Januari","Pebruari","Maret","April","Mei","Juni","Juli","Agustus","September","Oktober","November","Desember"],"shortMonthNames":["Jan","Peb","Mar","Apr","Mei","Jun","Jul","Agu","Sep","Okt","Nov","Des"],"dayNames":["Senin","Selasa","Rabu","Kamis","Jumat","Sabtu","Minggu"],"shortDayNames":["Sen","Sel","Rab","Kam","Jum","Sab","Min"],"zoomOutText":"Tampilkan semua"} |
amcharts/lang/is.js
File was created | 1 | AmCharts.translations.is = {"monthNames":["Janรบar","Febrรบar","Mars","Aprรญl","Maรญ","Jรบnรญ","Jรบlรญ","รgรบst","September","Oktรณber","Nรณvember","Desember"],"shortMonthNames":["Jan","Feb","Mar","Apr","Maรญ","Jรบn","Jรบl","รgรบ","Sep","Okt","Nรณv","Des"],"dayNames":["Mรกnudagur","รriรฐjudagur","Miรฐvikudagur","Fimmtudagur","Fรถstudagur","Laugardagur","Sunnudagur"],"shortDayNames":["Mรกn","รri","Miรฐ","Fim","Fรถs","Lau","Sun"],"zoomOutText":"Sรฝna allt"} |
amcharts/lang/it.js
File was created | 1 | AmCharts.translations.it = {"monthNames":["Gennaio","Febbraio","Marzo","Aprile","Maggio","Giugno","Luglio","Agosto","Settembre","Ottobre","Novembre","Dicembre"],"shortMonthNames":["Gen","Feb","Mar","Apr","Mag","Giu","Lug","Ago","Set","Ott","Nov","Dic"],"dayNames":["Lunedรฌ","Martedรฌ","Mercoledรฌ","Giovedรฌ","Venerdรฌ","Sabato","Domenica"],"shortDayNames":["Lun","Mar","Mer","Gio","Ven","Sab","Dom"],"zoomOutText":"Mostra tutti"} |
amcharts/lang/lt.js
File was created | 1 | AmCharts.translations.lt = {"monthNames":["Sausio","Vasario","Kovo","Balandลพio","Geguลพฤs","Birลพelio","Liepos","Rugpjลซฤio","Rugsฤjo","Spalio","Lapkriฤio","Gruodลพio"],"shortMonthNames":["Sau","Vas","Kov","Bal","Geg","Bir","Lie","Rgp","Rgs","Spa","Lap","Grd"],"dayNames":["Pirmadienis","Antradienis","Treฤiadienis","Ketvirtadienis","Penktadienis","ล eลกtadienis","Sekmadienis"],"shortDayNames":["Pr","An","Tr","Kt","Pn","ล t","Sk"],"zoomOutText":"Rodyti viskฤ "} |
amcharts/lang/lv.js
File was created | 1 | AmCharts.translations.lv = {"monthNames":["Janvฤris","Februฤris","Marts","Aprฤซlis","Maijs","Jลซnijs","Jลซlijs","Augusts","Septembris","Oktobris","Novembris","Decembris"],"shortMonthNames":["Jan","Feb","Mar","Apr","Mai","Jลซn","Jลซl","Aug","Sep","Okt","Nov","Dec"],"dayNames":["Pirmdiena","Otrdiena","Treลกdiena","Ceturtdiena","Piektdiena","Sestdiena","Svฤtdiena"],"shortDayNames":["Pย ","Oย ","Tย ","Cย ","Pk","Sย ","Sv"],"zoomOutText":"Parฤdฤซt visu"} |
amcharts/lang/mk.js
File was created | 1 | AmCharts.translations.mk = {"monthNames":["ะะฐะฝัะฐัะธ","ะคะตะฒััะฐัะธ","ะะฐัั","ะะฟัะธะป","ะะฐั","ะัะฝะธ","ะัะปะธ","ะะฒะณััั","ะกะตะฟัะตะผะฒัะธ","ะะบัะพะผะฒัะธ","ะะพะตะผะฒัะธ","ะะตะบะตะผะฒัะธ"],"shortMonthNames":["ะะฐะฝ","ะคะตะฒ","ะะฐั","ะะฟั","ะะฐั","ะัะฝ","ะัะป","ะะฒะณ","ะกะตะฟ","ะะบั","ะะพะต","ะะตะบ"],"dayNames":["ะะพะฝะตะดะตะปะฝะธะบ","ะัะพัะฝะธะบ","ะกัะตะดะฐ","ะงะตัะฒััะพะบ","ะะตัะพะบ","ะกะฐะฑะพัะฐ","ะะตะดะตะปะฐ"],"shortDayNames":["ะะพะฝ","ะัะพ","ะกัะต","ะงะตั","ะะตั","ะกะฐะฑ","ะะตะด"],"zoomOutText":"ะัะธะบะฐะถะธ ะณะธ ัะธัะต"} |
amcharts/lang/mn.js
File was created | 1 | AmCharts.translations.mn = {"monthNames":["ะฅัะปะณะฐะฝะฐ ัะฐััะฝ","าฎั ัั ัะฐััะฝ","ะะฐั ัะฐััะฝ","ะขััะปะฐะน ัะฐััะฝ","ะัั ัะฐััะฝ","ะะพะณะพะน ัะฐััะฝ","ะะพัั ัะฐััะฝ","ะฅะพะฝั ัะฐััะฝ","ะะธั ัะฐััะฝ","ะขะฐั ะธะฐ ัะฐััะฝ","ะะพั ะพะน ัะฐััะฝ","ะะฐั ะฐะน ัะฐััะฝ"],"shortMonthNames":["ะฅัะป","าฎั ั","ะะฐั","ะขัั","ะัั","ะะพะณ","ะะพั","ะฅะพะฝ","ะะธั","ะขะฐั ","ะะพั ","ะะฐั "],"dayNames":["ะะฐะฒะฐะฐ","ะัะณะผะฐั","ะั ะฐะณะฒะฐ","ะาฏััะฒ","ะะฐะฐัะฐะฝ","ะัะผะฑะฐ","ะัะผ"],"shortDayNames":["ะะฐ","ะั","ะั ","ะาฏ","ะะฐ","ะั","ะั"],"zoomOutText":"ะาฏั ั ะฐัััะปะฐั "} |
amcharts/lang/mt.js
File was created | 1 | AmCharts.translations.mt = {"monthNames":["Jannar","Frar","Marzu","April","Mejju","ฤ unju","Lulju","Awwissu","Settembru","Ottubru","Novembru","Diฤembru "],"shortMonthNames":["Jan","Fra","Mar","Apr","Mej","ฤ un","Lul","Aww","Set","Ott","Nov","Diฤ"],"dayNames":["It-tnejn","It-tlieta","L-erbgฤงa","Il-ฤงamis","Il-ฤกimgฤงa","Is-sibt","Il-ฤงadd"],"shortDayNames":["Tne","Tli","Erb","ฤฆam","ฤ im","Sib","ฤฆad"],"zoomOutText":"Turi kollha"} |
amcharts/lang/nl.js
File was created | 1 | AmCharts.translations.nl = {"monthNames":["Januari","Februari","Maart","April","Mei","Juni","Juli","Augustus","September","Oktober","November","December"],"shortMonthNames":["Jan","Feb","Mrt","Apr","Mei","Jun","Jul","Aug","Sep","Okt","Nov","Dec"],"dayNames":["Maandag","Dinsdag","Woensdag","Donderdag","Vrijdag","Zaterdag","Zondag"],"shortDayNames":["Ma","Di","Wo","Do","Vr","Za","Zo"],"zoomOutText":"Alles weergeven"} |
amcharts/lang/no.js
File was created | 1 | AmCharts.translations.no = {"monthNames":["Januar","Februar","Mars","April","Mai","Juni","Juli","August","September","Oktober","November","Desember"],"shortMonthNames":["Jan.","Feb.","Mars","April","Mai","Juni","Juli","Aug.","Sep.","Okt.","Nov.","Des."],"dayNames":["Mandag","Tirsdag","Onsdag","Torsdag","Fredag","Lรธrdag","Sรธndag"],"shortDayNames":["Ma.","Ti.","On.","To.","Fr.","Lรธ.","Sรธ."],"zoomOutText":"Vis alle"} |
amcharts/lang/pl.js
File was created | 1 | AmCharts.translations.pl = {"monthNames":["Styczeล","Luty","Marzec","Kwiecieล","Maj","Czerwiec","Lipiec","Sierpieล","Wrzesieล","Paลบdziernik","Listopad","Grudzieล"],"shortMonthNames":["Sty","Lut","Mar","Kwi","Maj","Cze","Lip","Sie","Wrz","Paลบ","Lis","Gru"],"dayNames":["Poniedziaลek","Wtorek","ลroda","Czwartek","Piฤ tek","Sobota","Niedziela"],"shortDayNames":["Pon","Wto","ลro","Czw","Piฤ ","Sob","Nie"],"zoomOutText":"Pokaลผ wszystko"} |
amcharts/lang/pt.js
File was created | 1 | AmCharts.translations.pt = {"monthNames":["Janeiro","Fevereiro","Marรงo","Abril","Maio","Junho","Julho","Agosto","Setembro","Outubro","Novembro","Dezembro"],"shortMonthNames":["Jan","Fev","Mar","Abr","Mai","Jun","Jul","Ago","Set","Out","Nov","Dez"],"dayNames":["Segunda","Terรงa","Quarta","Quinta","Sexta","Sรกbado","Domingo"],"shortDayNames":["Seg","Ter","Qua","Qui","Sex","Sรกb","Dom"],"zoomOutText":"Mostrar todos"} |
amcharts/lang/ro.js
File was created | 1 | AmCharts.translations.ro = {"monthNames":["Ianuarie","Februarie","Martie","Aprilie","Mai","Iunie","Iulie","August","Septembrie","Octombrie","Noiembrie","Decembrie"],"shortMonthNames":["Ian","Feb","Mar","Apr","Mai","Iun","Iul","Aug","Sep","Oct","Nov","Dec"],"dayNames":["Luni","Marลฃi","Miercuri","Joi","Vineri","Sรขmbฤtฤ","Duminicฤ"],"shortDayNames":["Lu","Ma","Mi","Jo","Vi","Sb","Du"],"zoomOutText":"Aratฤ tot"} |
amcharts/lang/ru.js
File was created | 1 | AmCharts.translations.ru = {"monthNames":["ะฏะฝะฒะฐัั","ะคะตะฒัะฐะปั","ะะฐัั","ะะฟัะตะปั","ะะฐะน","ะัะฝั","ะัะปั","ะะฒะณััั","ะกะตะฝััะฑัั","ะะบััะฑัั","ะะพัะฑัั","ะะตะบะฐะฑัั"],"shortMonthNames":["ะฏะฝะฒ","ะคะตะฒ","ะะฐั","ะะฟั","ะะฐะน","ะัะฝ","ะัะป","ะะฒะณ","ะกะตะฝ","ะะบั","ะะพั","ะะตะบ"],"dayNames":["ะะพะฝะตะดะตะปัะฝะธะบ","ะัะพัะฝะธะบ","ะกัะตะดะฐ","ะงะตัะฒะตัะณ","ะััะฝะธัะฐ","ะกัะฑะฑะพัะฐ","ะะพัะบัะตัะตะฝัะต"],"shortDayNames":["ะะฝะด","ะัั","ะกัะด","ะงัะฒ","ะัะฝ","ะกะฑั","ะัะบ"],"zoomOutText":"ะะพะบะฐะทะฐัั ะฒัะต"} |
amcharts/lang/rw.js
File was created | 1 | AmCharts.translations.rw = {"monthNames":["Mutarama","Gashyantare","Werurwe","Mata","Gicuransi","Kamena","Nyakanga","Kanama","Nzeli","Ukwakira","Ugushyingo","Ukuboza"],"shortMonthNames":["Mut","Gas","Wer","Mat","Gic","Kam","Nya","Kan","Nze","Ukw","Ugu","Uku"],"dayNames":["Kuwa mbere","Kuwa kabiri","Kuwa gatatu","Kuwa kane","Kuwa gatanu","Kuwa gatandatu","Ku cyumweru"],"shortDayNames":["Mbe","Kab","Gtu","Kan","Gnu","Gnd","Mwe"],"zoomOutText":"Show all"} |
amcharts/lang/sk.js
File was created | 1 | AmCharts.translations.sk = {"monthNames":["Januรกr","Februรกr","Marec","Aprรญl","Mรกj","Jรบn","Jรบl","August","September","Oktรณber","November","December"],"shortMonthNames":["Jan","Feb","Mar","Apr","Mรกj","Jรบn","Jรบl","Aug","Sep","Okt","Nov","Dec"],"dayNames":["Pondelok","Utorok","Streda","ล tvrtok","Piatok","Sobota","Nedeฤพa"],"shortDayNames":["Po","Ut","St","ล t","Pi","So","Ne"],"zoomOutText":"Zobraziลฅ vลกetky"} |
amcharts/lang/so.js
File was created | 1 | AmCharts.translations.so = {"monthNames":["Bisha koobaad","Bisha labaad","Bisha saddexaad","Bisha afraad","Bisha shanaad","Bisha lixaad","Bisha todobaad","Bisha sideedaad","Bisha sagaalaad","Bisha tobnaad","Bisha kow iyo tobnaad","Bisha laba iyo tobnaad"],"shortMonthNames":["Kob","Lab","Sad","Afr","Sha","Lix","Tod","Sid","Sag","Tob","Kit","Lit"],"dayNames":["Isniin","Salaaso","Arbaco","Khamiis","Jimco","Sabti","Axad"],"shortDayNames":["Isn","Sal","Arb","Kha","Jim","Sab","Axa"],"zoomOutText":"Tus dhammaan"} |
amcharts/lang/th.js
File was created | 1 | AmCharts.translations.th = {"monthNames":["เธกเธเธฃเธฒเธเธก","เธเธธเธกเธ เธฒเธเธฑเธเธเน","เธกเธตเธเธฒเธเธก","เนเธกเธฉเธฒเธขเธ","เธเธคเธฉเธ เธฒเธเธก","เธกเธดเธเธธเธเธฒเธขเธ","เธเธฃเธเธเธฒเธเธก","เธชเธดเธเธซเธฒเธเธก","เธเธฑเธเธขเธฒเธขเธ","เธเธธเธฅเธฒเธเธก","เธเธคเธจเธเธดเธเธฒเธขเธ","เธเธฑเธเธงเธฒเธเธก"],"shortMonthNames":["เธก.เธ.","เธ.เธ.","เธกเธต.เธ.","เนเธก.เธข.","เธ.เธ.","เธกเธด.เธข.","เธ.เธ.","เธช.เธ.","เธ.เธข.","เธ.เธ.","เธ.เธข.","เธ.เธ."],"dayNames":["เธเธฑเธเธเธฃเน","เธญเธฑเธเธเธฒเธฃ","เธเธธเธ","เธเธคเธซเธฑเธชเธเธเธต","เธจเธธเธเธฃเน","เนเธชเธฒเธฃเน","เธญเธฒเธเธดเธเธขเน"],"shortDayNames":["เธ.","เธญ.","เธ.","เธเธค.","เธจ.","เธช.","เธญเธฒ."],"zoomOutText":"เนเธชเธเธเธเธฑเนเธเธซเธกเธ"} |
amcharts/lang/tr.js
File was created | 1 | AmCharts.translations.tr = {"monthNames":["Ocak","ลubat","Mart","Nisan","Mayฤฑs","Haziran","Temmuz","Aฤustos","Eylรผl","Ekim","Kasฤฑm","Aralฤฑk"],"shortMonthNames":["Oca","ลub","Mar","Nis","May","Haz","Tem","Aฤu","Eyl","Eki","Kas","Ara"],"dayNames":["Pazartesi","Salฤฑ","รarลamba","Perลembe","Cuma","Cumartesi","Pazar"],"shortDayNames":["Pzt","Sal","รrล","Prล","Cum","Cts","Paz"],"zoomOutText":"Tรผmรผnรผ gรถster"} |
amcharts/patterns/black/pattern1.png
158 Bytes
amcharts/patterns/black/pattern10.png
155 Bytes
amcharts/patterns/black/pattern11.png
161 Bytes
amcharts/patterns/black/pattern12.png
161 Bytes
amcharts/patterns/black/pattern13.png
153 Bytes
amcharts/patterns/black/pattern14.png
160 Bytes
amcharts/patterns/black/pattern15.png
157 Bytes
amcharts/patterns/black/pattern16.png
160 Bytes
amcharts/patterns/black/pattern17.png
162 Bytes
amcharts/patterns/black/pattern18.png
155 Bytes
amcharts/patterns/black/pattern19.png
160 Bytes
amcharts/patterns/black/pattern2.png
161 Bytes
amcharts/patterns/black/pattern20.png
161 Bytes
amcharts/patterns/black/pattern21.png
158 Bytes
amcharts/patterns/black/pattern3.png
156 Bytes
amcharts/patterns/black/pattern4.png
154 Bytes
amcharts/patterns/black/pattern5.png
158 Bytes
amcharts/patterns/black/pattern6.png
155 Bytes
amcharts/patterns/black/pattern7.png
153 Bytes
amcharts/patterns/black/pattern8.png
160 Bytes
amcharts/patterns/black/pattern9.png
153 Bytes
amcharts/patterns/chalk/pattern1.jpg
113 KB
amcharts/patterns/chalk/pattern1r.jpg
111 KB
amcharts/patterns/chalk/pattern2.jpg
114 KB
amcharts/patterns/chalk/pattern3.jpg
160 KB
amcharts/patterns/chalk/pattern4.jpg
160 KB
amcharts/patterns/chalk/pattern5.jpg
173 KB
amcharts/patterns/chalk/pattern6.jpg
143 KB
amcharts/patterns/white/pattern1.png
156 Bytes
amcharts/patterns/white/pattern10.png
155 Bytes
amcharts/patterns/white/pattern11.png
159 Bytes
amcharts/patterns/white/pattern12.png
160 Bytes
amcharts/patterns/white/pattern13.png
154 Bytes
amcharts/patterns/white/pattern14.png
161 Bytes
amcharts/patterns/white/pattern15.png
155 Bytes
amcharts/patterns/white/pattern16.png
158 Bytes
amcharts/patterns/white/pattern17.png
158 Bytes
amcharts/patterns/white/pattern18.png
155 Bytes
amcharts/patterns/white/pattern19.png
159 Bytes
amcharts/patterns/white/pattern2.png
157 Bytes
amcharts/patterns/white/pattern20.png
158 Bytes
amcharts/patterns/white/pattern21.png
158 Bytes
amcharts/patterns/white/pattern3.png
146 Bytes
amcharts/patterns/white/pattern4.png
154 Bytes
amcharts/patterns/white/pattern5.png
159 Bytes
amcharts/patterns/white/pattern6.png
161 Bytes
amcharts/patterns/white/pattern7.png
154 Bytes
amcharts/patterns/white/pattern8.png
160 Bytes
amcharts/patterns/white/pattern9.png
155 Bytes
amcharts/pie.js
File was created | 1 | AmCharts.AmPieChart=AmCharts.Class({inherits:AmCharts.AmSlicedChart,construct:function(e){this.type="pie";AmCharts.AmPieChart.base.construct.call(this,e);this.cname="AmPieChart";this.pieBrightnessStep=30;this.minRadius=10;this.depth3D=0;this.startAngle=90;this.angle=this.innerRadius=0;this.startRadius="500%";this.pullOutRadius="20%";this.labelRadius=20;this.labelText="[[title]]: [[percents]]%";this.balloonText="[[title]]: [[percents]]% ([[value]])\n[[description]]";this.previousScale=1;AmCharts.applyTheme(this, | |
2 | e,this.cname)},drawChart:function(){AmCharts.AmPieChart.base.drawChart.call(this);var e=this.chartData;if(AmCharts.ifArray(e)){if(0<this.realWidth&&0<this.realHeight){AmCharts.VML&&(this.startAlpha=1);var f=this.startDuration,c=this.container,b=this.updateWidth();this.realWidth=b;var h=this.updateHeight();this.realHeight=h;var d=AmCharts.toCoordinate,k=d(this.marginLeft,b),a=d(this.marginRight,b),t=d(this.marginTop,h)+this.getTitleHeight(),m=d(this.marginBottom,h),w,x,g,v=AmCharts.toNumber(this.labelRadius), | ||
3 | q=this.measureMaxLabel();q>this.maxLabelWidth&&(q=this.maxLabelWidth);this.labelText&&this.labelsEnabled||(v=q=0);w=void 0===this.pieX?(b-k-a)/2+k:d(this.pieX,this.realWidth);x=void 0===this.pieY?(h-t-m)/2+t:d(this.pieY,h);g=d(this.radius,b,h);g||(b=0<=v?b-k-a-2*q:b-k-a,h=h-t-m,g=Math.min(b,h),h<b&&(g/=1-this.angle/90,g>b&&(g=b)),h=AmCharts.toCoordinate(this.pullOutRadius,g),g=(0<=v?g-1.8*(v+h):g-1.8*h)/2);g<this.minRadius&&(g=this.minRadius);h=d(this.pullOutRadius,g);t=AmCharts.toCoordinate(this.startRadius, | ||
4 | g);d=d(this.innerRadius,g);d>=g&&(d=g-1);m=AmCharts.fitToBounds(this.startAngle,0,360);0<this.depth3D&&(m=270<=m?270:90);m-=90;b=g-g*this.angle/90;for(k=0;k<e.length;k++)if(a=e[k],!0!==a.hidden&&0<a.percents){var n=360*a.percents/100,q=Math.sin((m+n/2)/180*Math.PI),y=-Math.cos((m+n/2)/180*Math.PI)*(b/g),p=this.outlineColor;p||(p=a.color);var z=this.alpha;isNaN(a.alpha)||(z=a.alpha);p={fill:a.color,stroke:p,"stroke-width":this.outlineThickness,"stroke-opacity":this.outlineAlpha,"fill-opacity":z};a.url&& | ||
5 | (p.cursor="pointer");p=AmCharts.wedge(c,w,x,m,n,g,b,d,this.depth3D,p,this.gradientRatio,a.pattern);this.addEventListeners(p,a);a.startAngle=m;e[k].wedge=p;0<f&&(this.chartCreated||p.setAttr("opacity",this.startAlpha));a.ix=q;a.iy=y;a.wedge=p;a.index=k;if(this.labelsEnabled&&this.labelText&&a.percents>=this.hideLabelsPercent){var l=m+n/2;360<l&&(l-=360);var r=v;isNaN(a.labelRadius)||(r=a.labelRadius);var n=w+q*(g+r),z=x+y*(g+r),A,u=0;if(0<=r){var B;90>=l&&0<=l?(B=0,A="start",u=8):90<=l&&180>l?(B=1, | ||
6 | A="start",u=8):180<=l&&270>l?(B=2,A="end",u=-8):270<=l&&360>l&&(B=3,A="end",u=-8);a.labelQuarter=B}else A="middle";var l=this.formatString(this.labelText,a),s=this.labelFunction;s&&(l=s(a,l));s=a.labelColor;s||(s=this.color);l=AmCharts.wrappedText(c,l,s,this.fontFamily,this.fontSize,A,!1,this.maxLabelWidth);l.translate(n+1.5*u,z);l.node.style.pointerEvents="none";a.tx=n+1.5*u;a.ty=z;0<=r?(r=l.getBBox(),s=AmCharts.rect(c,r.width+5,r.height+5,"#FFFFFF",.005),s.translate(n+1.5*u+r.x,z+r.y),a.hitRect= | ||
7 | s,p.push(l),p.push(s)):this.freeLabelsSet.push(l);a.label=l;a.tx=n;a.tx2=n+u;a.tx0=w+q*g;a.ty0=x+y*g}n=d+(g-d)/2;a.pulled&&(n+=this.pullOutRadiusReal);a.balloonX=q*n+w;a.balloonY=y*n+x;a.startX=Math.round(q*t);a.startY=Math.round(y*t);a.pullX=Math.round(q*h);a.pullY=Math.round(y*h);this.graphsSet.push(p);(0===a.alpha||0<f&&!this.chartCreated)&&p.hide();m+=360*a.percents/100}0<v&&!this.labelRadiusField&&this.arrangeLabels();this.pieXReal=w;this.pieYReal=x;this.radiusReal=g;this.innerRadiusReal=d;0< | ||
8 | v&&this.drawTicks();this.initialStart();this.setDepths()}(e=this.legend)&&e.invalidateSize()}else this.cleanChart();this.dispDUpd();this.chartCreated=!0},setDepths:function(){var e=this.chartData,f;for(f=0;f<e.length;f++){var c=e[f],b=c.wedge,c=c.startAngle;0<=c&&180>c?b.toFront():180<=c&&b.toBack()}},arrangeLabels:function(){var e=this.chartData,f=e.length,c,b;for(b=f-1;0<=b;b--)c=e[b],0!==c.labelQuarter||c.hidden||this.checkOverlapping(b,c,0,!0,0);for(b=0;b<f;b++)c=e[b],1!=c.labelQuarter||c.hidden|| | ||
9 | this.checkOverlapping(b,c,1,!1,0);for(b=f-1;0<=b;b--)c=e[b],2!=c.labelQuarter||c.hidden||this.checkOverlapping(b,c,2,!0,0);for(b=0;b<f;b++)c=e[b],3!=c.labelQuarter||c.hidden||this.checkOverlapping(b,c,3,!1,0)},checkOverlapping:function(e,f,c,b,h){var d,k,a=this.chartData,t=a.length,m=f.label;if(m){if(!0===b)for(k=e+1;k<t;k++)a[k].labelQuarter==c&&(d=this.checkOverlappingReal(f,a[k],c))&&(k=t);else for(k=e-1;0<=k;k--)a[k].labelQuarter==c&&(d=this.checkOverlappingReal(f,a[k],c))&&(k=0);!0===d&&100> | ||
10 | h&&(d=f.ty+3*f.iy,f.ty=d,m.translate(f.tx2,d),f.hitRect&&(m=m.getBBox(),f.hitRect.translate(f.tx2+m.x,d+m.y)),this.checkOverlapping(e,f,c,b,h+1))}},checkOverlappingReal:function(e,f,c){var b=!1,h=e.label,d=f.label;e.labelQuarter!=c||e.hidden||f.hidden||!d||(h=h.getBBox(),c={},c.width=h.width,c.height=h.height,c.y=e.ty,c.x=e.tx,e=d.getBBox(),d={},d.width=e.width,d.height=e.height,d.y=f.ty,d.x=f.tx,AmCharts.hitTest(c,d)&&(b=!0));return b}}); |
amcharts/radar.js
File was created | 1 | AmCharts.AmRadarChart=AmCharts.Class({inherits:AmCharts.AmCoordinateChart,construct:function(a){this.type="radar";AmCharts.AmRadarChart.base.construct.call(this,a);this.cname="AmRadarChart";this.marginRight=this.marginBottom=this.marginTop=this.marginLeft=0;this.radius="35%";AmCharts.applyTheme(this,a,this.cname)},initChart:function(){AmCharts.AmRadarChart.base.initChart.call(this);this.dataChanged&&(this.updateData(),this.dataChanged=!1,this.dispatchDataUpdated=!0);this.drawChart()},updateData:function(){this.parseData(); | |
2 | var a=this.graphs,b;for(b=0;b<a.length;b++)a[b].data=this.chartData},updateGraphs:function(){var a=this.graphs,b;for(b=0;b<a.length;b++){var c=a[b];c.index=b;c.width=this.realRadius;c.height=this.realRadius;c.x=this.marginLeftReal;c.y=this.marginTopReal}},parseData:function(){AmCharts.AmRadarChart.base.parseData.call(this);this.parseSerialData()},updateValueAxes:function(){var a=this.valueAxes,b;for(b=0;b<a.length;b++){var c=a[b];c.axisRenderer=AmCharts.RadAxis;c.guideFillRenderer=AmCharts.RadarFill; | ||
3 | c.axisItemRenderer=AmCharts.RadItem;c.autoGridCount=!1;c.x=this.marginLeftReal;c.y=this.marginTopReal;c.width=this.realRadius;c.height=this.realRadius}},drawChart:function(){AmCharts.AmRadarChart.base.drawChart.call(this);var a=this.updateWidth(),b=this.updateHeight(),c=this.marginTop+this.getTitleHeight(),d=this.marginLeft,b=b-c-this.marginBottom;this.marginLeftReal=d+(a-d-this.marginRight)/2;this.marginTopReal=c+b/2;this.realRadius=AmCharts.toCoordinate(this.radius,a,b);this.updateValueAxes();this.updateGraphs(); | ||
4 | a=this.chartData;if(AmCharts.ifArray(a)){if(0<this.realWidth&&0<this.realHeight){a=a.length-1;d=this.valueAxes;for(c=0;c<d.length;c++)d[c].zoom(0,a);d=this.graphs;for(c=0;c<d.length;c++)d[c].zoom(0,a);(a=this.legend)&&a.invalidateSize()}}else this.cleanChart();this.dispDUpd();this.chartCreated=!0},formatString:function(a,b,c){var d=b.graph;-1!=a.indexOf("[[category]]")&&(a=a.replace(/\[\[category\]\]/g,String(b.serialDataItem.category)));d=d.numberFormatter;d||(d=this.nf);a=AmCharts.formatValue(a, | ||
5 | b.values,["value"],d,"",this.usePrefixes,this.prefixesOfSmallNumbers,this.prefixesOfBigNumbers);-1!=a.indexOf("[[")&&(a=AmCharts.formatDataContextValue(a,b.dataContext));return a=AmCharts.AmRadarChart.base.formatString.call(this,a,b,c)},cleanChart:function(){AmCharts.callMethod("destroy",[this.valueAxes,this.graphs])}});AmCharts.RadAxis=AmCharts.Class({construct:function(a){var b=a.chart,c=a.axisThickness,d=a.axisColor,m=a.axisAlpha,p=a.x,e=a.y;this.set=b.container.set();b.axesSet.push(this.set);var f=a.axisTitleOffset,n=a.radarCategoriesEnabled,l=a.chart.fontFamily,g=a.fontSize;void 0===g&&(g=a.chart.fontSize);var r=a.color;void 0===r&&(r=a.chart.color);if(b){this.axisWidth=a.height;a=b.chartData;var w=a.length,t;for(t=0;t<w;t++){var k=180-360/w*t,h=p+this.axisWidth*Math.sin(k/180*Math.PI),q=e+this.axisWidth*Math.cos(k/ | ||
6 | 180*Math.PI);0<m&&(h=AmCharts.line(b.container,[p,h],[e,q],d,m,c),this.set.push(h));if(n){var u="start",h=p+(this.axisWidth+f)*Math.sin(k/180*Math.PI),q=e+(this.axisWidth+f)*Math.cos(k/180*Math.PI);if(180==k||0===k)u="middle",h-=5;0>k&&(u="end",h-=10);180==k&&(q-=5);0===k&&(q+=5);k=AmCharts.text(b.container,a[t].category,r,l,g,u);k.translate(h+5,q);this.set.push(k);k.getBBox()}}}}});AmCharts.RadItem=AmCharts.Class({construct:function(a,b,c,d,m,p,e,f){void 0===c&&(c="");var n=a.chart.fontFamily,l=a.fontSize;void 0===l&&(l=a.chart.fontSize);var g=a.color;void 0===g&&(g=a.chart.color);var r=a.chart.container;this.set=d=r.set();var w=a.axisColor,t=a.axisAlpha,k=a.tickLength,h=a.gridAlpha,q=a.gridThickness,u=a.gridColor,A=a.dashLength,B=a.fillColor,y=a.fillAlpha,C=a.labelsEnabled;m=a.counter;var D=a.inside,E=a.gridType,s,H=a.labelOffset;b-=a.height;var x;p=a.x;var F=a.y;e?(C=!0,isNaN(e.tickLength)|| | ||
7 | (k=e.tickLength),void 0!=e.lineColor&&(u=e.lineColor),isNaN(e.lineAlpha)||(h=e.lineAlpha),isNaN(e.dashLength)||(A=e.dashLength),isNaN(e.lineThickness)||(q=e.lineThickness),!0===e.inside&&(D=!0),void 0!==e.boldLabel&&(f=e.boldLabel)):c||(h/=3,k/=2);var G="end",z=-1;D&&(G="start",z=1);var v;C&&(v=AmCharts.text(r,c,g,n,l,G,f),v.translate(p+(k+3+H)*z,b),d.push(v),this.label=v,x=AmCharts.line(r,[p,p+k*z],[b,b],w,t,q),d.push(x));b=Math.round(a.y-b);f=[];n=[];if(0<h){if("polygons"==E){s=a.data.length;for(l= | ||
8 | 0;l<s;l++)g=180-360/s*l,f.push(b*Math.sin(g/180*Math.PI)),n.push(b*Math.cos(g/180*Math.PI));f.push(f[0]);n.push(n[0]);h=AmCharts.line(r,f,n,u,h,q,A)}else h=AmCharts.circle(r,b,"#FFFFFF",0,q,u,h);h.translate(p,F);d.push(h)}if(1==m&&0<y&&!e&&""!==c){e=a.previousCoord;if("polygons"==E){for(l=s;0<=l;l--)g=180-360/s*l,f.push(e*Math.sin(g/180*Math.PI)),n.push(e*Math.cos(g/180*Math.PI));s=AmCharts.polygon(r,f,n,B,y)}else s=AmCharts.wedge(r,0,0,0,360,b,b,e,0,{fill:B,"fill-opacity":y,stroke:"#000","stroke-opacity":0, | ||
9 | "stroke-width":1});d.push(s);s.translate(p,F)}!1===a.visible&&(x&&x.hide(),v&&v.hide());""!==c&&(a.counter=0===m?1:0,a.previousCoord=b)},graphics:function(){return this.set},getLabel:function(){return this.label}});AmCharts.RadarFill=AmCharts.Class({construct:function(a,b,c,d){b-=a.axisWidth;c-=a.axisWidth;var m=Math.max(b,c);b=c=Math.min(b,c);c=a.chart.container;var p=d.fillAlpha,e=d.fillColor,m=Math.abs(m-a.y);b=Math.abs(b-a.y);var f=Math.max(m,b);b=Math.min(m,b);m=f;f=d.angle+90;d=d.toAngle+90;isNaN(f)&&(f=0);isNaN(d)&&(d=360);this.set=c.set();void 0===e&&(e="#000000");isNaN(p)&&(p=0);if("polygons"==a.gridType){d=[];var n=[],l=a.data.length,g;for(g=0;g<l;g++)f=180-360/l*g,d.push(m*Math.sin(f/180*Math.PI)), | ||
10 | n.push(m*Math.cos(f/180*Math.PI));d.push(d[0]);n.push(n[0]);for(g=l;0<=g;g--)f=180-360/l*g,d.push(b*Math.sin(f/180*Math.PI)),n.push(b*Math.cos(f/180*Math.PI));this.fill=AmCharts.polygon(c,d,n,e,p)}else this.fill=AmCharts.wedge(c,0,0,f,d-f,m,m,b,0,{fill:e,"fill-opacity":p,stroke:"#000","stroke-opacity":0,"stroke-width":1});this.set.push(this.fill);this.fill.translate(a.x,a.y)},graphics:function(){return this.set},getLabel:function(){}}); |
amcharts/serial.js
File was created | 1 | AmCharts.AmSerialChart=AmCharts.Class({inherits:AmCharts.AmRectangularChart,construct:function(a){this.type="serial";AmCharts.AmSerialChart.base.construct.call(this,a);this.cname="AmSerialChart";this.theme=a;this.createEvents("changed");this.columnSpacing=5;this.columnSpacing3D=0;this.columnWidth=.8;this.updateScrollbar=!0;var b=new AmCharts.CategoryAxis(a);b.chart=this;this.categoryAxis=b;this.zoomOutOnDataUpdate=!0;this.mouseWheelZoomEnabled=this.mouseWheelScrollEnabled=this.rotate=this.skipZoom= | |
2 | !1;this.minSelectedTime=0;AmCharts.applyTheme(this,a,this.cname)},initChart:function(){AmCharts.AmSerialChart.base.initChart.call(this);this.updateCategoryAxis(this.categoryAxis,this.rotate,"categoryAxis");this.dataChanged&&(this.updateData(),this.dataChanged=!1,this.dispatchDataUpdated=!0);var a=this.chartCursor;a&&(a.updateData(),a.fullWidth&&(a.fullRectSet=this.cursorLineSet));var a=this.countColumns(),b=this.graphs,c;for(c=0;c<b.length;c++)b[c].columnCount=a;this.updateScrollbar=!0;this.drawChart(); | ||
3 | this.autoMargins&&!this.marginsUpdated&&(this.marginsUpdated=!0,this.measureMargins());(this.mouseWheelScrollEnabled||this.mouseWheelZoomEnabled)&&this.addMouseWheel()},handleWheelReal:function(a,b){if(!this.wheelBusy){var c=this.categoryAxis,d=c.parseDates,c=c.minDuration(),e=1;this.mouseWheelZoomEnabled?b||(e=-1):b&&(e=-1);0>a?d?(d=this.startTime+e*c,c=this.endTime+1*c,this.zoomToDates(new Date(d),new Date(c))):(d=this.start+e,c=this.end+1,this.zoomToIndexes(d,c)):d?(d=this.startTime-e*c,c=this.endTime- | ||
4 | 1*c,this.zoomToDates(new Date(d),new Date(c))):(d=this.start-e,c=this.end-1,this.zoomToIndexes(d,c))}},validateData:function(a){this.marginsUpdated=!1;this.zoomOutOnDataUpdate&&!a&&(this.endTime=this.end=this.startTime=this.start=NaN);AmCharts.AmSerialChart.base.validateData.call(this)},drawChart:function(){AmCharts.AmSerialChart.base.drawChart.call(this);var a=this.chartData;if(AmCharts.ifArray(a)){var b=this.chartScrollbar;b&&b.draw();if(0<this.realWidth&&0<this.realHeight){var a=a.length-1,c,b= | ||
5 | this.categoryAxis;if(b.parseDates&&!b.equalSpacing){if(b=this.startTime,c=this.endTime,isNaN(b)||isNaN(c))b=this.firstTime,c=this.lastTime}else if(b=this.start,c=this.end,isNaN(b)||isNaN(c))b=0,c=a;this.endTime=this.startTime=this.end=this.start=void 0;this.zoom(b,c)}}else this.cleanChart();this.dispDUpd();this.chartCreated=!0},cleanChart:function(){AmCharts.callMethod("destroy",[this.valueAxes,this.graphs,this.categoryAxis,this.chartScrollbar,this.chartCursor])},updateCategoryAxis:function(a,b,c){a.chart= | ||
6 | this;a.id=c;a.rotate=b;a.axisRenderer=AmCharts.RecAxis;a.guideFillRenderer=AmCharts.RecFill;a.axisItemRenderer=AmCharts.RecItem;a.setOrientation(!this.rotate);a.x=this.marginLeftReal;a.y=this.marginTopReal;a.dx=this.dx;a.dy=this.dy;a.width=this.plotAreaWidth-1;a.height=this.plotAreaHeight-1;a.viW=this.plotAreaWidth-1;a.viH=this.plotAreaHeight-1;a.viX=this.marginLeftReal;a.viY=this.marginTopReal;a.marginsChanged=!0},updateValueAxes:function(){AmCharts.AmSerialChart.base.updateValueAxes.call(this); | ||
7 | var a=this.valueAxes,b;for(b=0;b<a.length;b++){var c=a[b],d=this.rotate;c.rotate=d;c.setOrientation(d);d=this.categoryAxis;if(!d.startOnAxis||d.parseDates)c.expandMinMax=!0}},updateData:function(){this.parseData();var a=this.graphs,b,c=this.chartData;for(b=0;b<a.length;b++)a[b].data=c;0<c.length&&(this.firstTime=this.getStartTime(c[0].time),this.lastTime=this.getEndTime(c[c.length-1].time))},getStartTime:function(a){var b=this.categoryAxis;return AmCharts.resetDateToMin(new Date(a),b.minPeriod,1, | ||
8 | b.firstDayOfWeek).getTime()},getEndTime:function(a){var b=AmCharts.extractPeriod(this.categoryAxis.minPeriod);return AmCharts.changeDate(new Date(a),b.period,b.count,!0).getTime()-1},updateMargins:function(){AmCharts.AmSerialChart.base.updateMargins.call(this);var a=this.chartScrollbar;a&&(this.getScrollbarPosition(a,this.rotate,this.categoryAxis.position),this.adjustMargins(a,this.rotate))},updateScrollbars:function(){AmCharts.AmSerialChart.base.updateScrollbars.call(this);this.updateChartScrollbar(this.chartScrollbar, | ||
9 | this.rotate)},zoom:function(a,b){var c=this.categoryAxis;c.parseDates&&!c.equalSpacing?this.timeZoom(a,b):this.indexZoom(a,b);this.updateLegendValues()},timeZoom:function(a,b){var c=this.maxSelectedTime;isNaN(c)||(b!=this.endTime&&b-a>c&&(a=b-c,this.updateScrollbar=!0),a!=this.startTime&&b-a>c&&(b=a+c,this.updateScrollbar=!0));var d=this.minSelectedTime;if(0<d&&b-a<d){var e=Math.round(a+(b-a)/2),d=Math.round(d/2);a=e-d;b=e+d}var f=this.chartData,e=this.categoryAxis;if(AmCharts.ifArray(f)&&(a!=this.startTime|| | ||
10 | b!=this.endTime)){var l=e.minDuration(),d=this.firstTime,n=this.lastTime;a||(a=d,isNaN(c)||(a=n-c));b||(b=n);a>n&&(a=n);b<d&&(b=d);a<d&&(a=d);b>n&&(b=n);b<a&&(b=a+l);b-a<l/5&&(b<n?b=a+l/5:a=b-l/5);this.startTime=a;this.endTime=b;c=f.length-1;l=this.getClosestIndex(f,"time",a,!0,0,c);f=this.getClosestIndex(f,"time",b,!1,l,c);e.timeZoom(a,b);e.zoom(l,f);this.start=AmCharts.fitToBounds(l,0,c);this.end=AmCharts.fitToBounds(f,0,c);this.zoomAxesAndGraphs();this.zoomScrollbar();a!=d||b!=n?this.showZB(!0): | ||
11 | this.showZB(!1);this.updateColumnsDepth();this.dispatchTimeZoomEvent()}},indexZoom:function(a,b){var c=this.maxSelectedSeries;isNaN(c)||(b!=this.end&&b-a>c&&(a=b-c,this.updateScrollbar=!0),a!=this.start&&b-a>c&&(b=a+c,this.updateScrollbar=!0));if(a!=this.start||b!=this.end){var d=this.chartData.length-1;isNaN(a)&&(a=0,isNaN(c)||(a=d-c));isNaN(b)&&(b=d);b<a&&(b=a);b>d&&(b=d);a>d&&(a=d-1);0>a&&(a=0);this.start=a;this.end=b;this.categoryAxis.zoom(a,b);this.zoomAxesAndGraphs();this.zoomScrollbar();0!== | ||
12 | a||b!=this.chartData.length-1?this.showZB(!0):this.showZB(!1);this.updateColumnsDepth();this.dispatchIndexZoomEvent()}},updateGraphs:function(){AmCharts.AmSerialChart.base.updateGraphs.call(this);var a=this.graphs,b;for(b=0;b<a.length;b++){var c=a[b];c.columnWidthReal=this.columnWidth;c.categoryAxis=this.categoryAxis;AmCharts.isString(c.fillToGraph)&&(c.fillToGraph=this.getGraphById(c.fillToGraph))}},updateColumnsDepth:function(){var a,b=this.graphs,c;AmCharts.remove(this.columnsSet);this.columnsArray= | ||
13 | [];for(a=0;a<b.length;a++){c=b[a];var d=c.columnsArray;if(d){var e;for(e=0;e<d.length;e++)this.columnsArray.push(d[e])}}this.columnsArray.sort(this.compareDepth);if(0<this.columnsArray.length){b=this.container.set();this.columnSet.push(b);for(a=0;a<this.columnsArray.length;a++)b.push(this.columnsArray[a].column.set);c&&b.translate(c.x,c.y);this.columnsSet=b}},compareDepth:function(a,b){return a.depth>b.depth?1:-1},zoomScrollbar:function(){var a=this.chartScrollbar,b=this.categoryAxis;a&&this.updateScrollbar&& | ||
14 | (b.parseDates&&!b.equalSpacing?a.timeZoom(this.startTime,this.endTime):a.zoom(this.start,this.end),this.updateScrollbar=!0)},updateTrendLines:function(){var a=this.trendLines,b;for(b=0;b<a.length;b++){var c=a[b],c=AmCharts.processObject(c,AmCharts.TrendLine,this.theme);a[b]=c;c.chart=this;AmCharts.isString(c.valueAxis)&&(c.valueAxis=this.getValueAxisById(c.valueAxis));c.valueAxis||(c.valueAxis=this.valueAxes[0]);c.categoryAxis=this.categoryAxis}},zoomAxesAndGraphs:function(){if(!this.scrollbarOnly){var a= | ||
15 | this.valueAxes,b;for(b=0;b<a.length;b++)a[b].zoom(this.start,this.end);a=this.graphs;for(b=0;b<a.length;b++)a[b].zoom(this.start,this.end);this.zoomTrendLines();(b=this.chartCursor)&&b.zoom(this.start,this.end,this.startTime,this.endTime)}},countColumns:function(){var a=0,b=this.valueAxes.length,c=this.graphs.length,d,e,f=!1,l,n;for(n=0;n<b;n++){e=this.valueAxes[n];var k=e.stackType;if("100%"==k||"regular"==k)for(f=!1,l=0;l<c;l++)d=this.graphs[l],d.tcc=1,d.valueAxis==e&&"column"==d.type&&(!f&&d.stackable&& | ||
16 | (a++,f=!0),(!d.stackable&&d.clustered||d.newStack)&&a++,d.columnIndex=a-1,d.clustered||(d.columnIndex=0));if("none"==k||"3d"==k)for(l=0;l<c;l++)d=this.graphs[l],d.valueAxis==e&&"column"==d.type&&d.clustered&&(d.tcc=1,d.newStack&&(a=0),d.hidden||(d.columnIndex=a,a++));if("3d"==k){e=1;for(n=0;n<c;n++)d=this.graphs[n],d.newStack&&e++,d.depthCount=e,d.tcc=a;a=e}}return a},parseData:function(){AmCharts.AmSerialChart.base.parseData.call(this);this.parseSerialData()},getCategoryIndexByValue:function(a){var b= | ||
17 | this.chartData,c,d;for(d=0;d<b.length;d++)b[d].category==a&&(c=d);return c},handleCursorChange:function(a){this.updateLegendValues(a.index)},handleCursorZoom:function(a){this.updateScrollbar=!0;this.zoom(a.start,a.end)},handleScrollbarZoom:function(a){this.updateScrollbar=!1;this.zoom(a.start,a.end)},dispatchTimeZoomEvent:function(){if(this.prevStartTime!=this.startTime||this.prevEndTime!=this.endTime){var a={type:"zoomed"};a.startDate=new Date(this.startTime);a.endDate=new Date(this.endTime);a.startIndex= | ||
18 | this.start;a.endIndex=this.end;this.startIndex=this.start;this.endIndex=this.end;this.startDate=a.startDate;this.endDate=a.endDate;this.prevStartTime=this.startTime;this.prevEndTime=this.endTime;var b=this.categoryAxis,c=AmCharts.extractPeriod(b.minPeriod).period,b=b.dateFormatsObject[c];a.startValue=AmCharts.formatDate(a.startDate,b);a.endValue=AmCharts.formatDate(a.endDate,b);a.chart=this;a.target=this;this.fire(a.type,a)}},dispatchIndexZoomEvent:function(){if(this.prevStartIndex!=this.start||this.prevEndIndex!= | ||
19 | this.end){this.startIndex=this.start;this.endIndex=this.end;var a=this.chartData;if(AmCharts.ifArray(a)&&!isNaN(this.start)&&!isNaN(this.end)){var b={chart:this,target:this,type:"zoomed"};b.startIndex=this.start;b.endIndex=this.end;b.startValue=a[this.start].category;b.endValue=a[this.end].category;this.categoryAxis.parseDates&&(this.startTime=a[this.start].time,this.endTime=a[this.end].time,b.startDate=new Date(this.startTime),b.endDate=new Date(this.endTime));this.prevStartIndex=this.start;this.prevEndIndex= | ||
20 | this.end;this.fire(b.type,b)}}},updateLegendValues:function(a){var b=this.graphs,c;for(c=0;c<b.length;c++){var d=b[c];isNaN(a)?d.currentDataItem=void 0:d.currentDataItem=this.chartData[a].axes[d.valueAxis.id].graphs[d.id]}this.legend&&this.legend.updateValues()},getClosestIndex:function(a,b,c,d,e,f){0>e&&(e=0);f>a.length-1&&(f=a.length-1);var l=e+Math.round((f-e)/2),n=a[l][b];if(1>=f-e){if(d)return e;d=a[f][b];return Math.abs(a[e][b]-c)<Math.abs(d-c)?e:f}return c==n?l:c<n?this.getClosestIndex(a,b, | ||
21 | c,d,e,l):this.getClosestIndex(a,b,c,d,l,f)},zoomToIndexes:function(a,b){this.updateScrollbar=!0;var c=this.chartData;if(c){var d=c.length;0<d&&(0>a&&(a=0),b>d-1&&(b=d-1),d=this.categoryAxis,d.parseDates&&!d.equalSpacing?this.zoom(c[a].time,this.getEndTime(c[b].time)):this.zoom(a,b))}},zoomToDates:function(a,b){this.updateScrollbar=!0;var c=this.chartData;if(this.categoryAxis.equalSpacing){var d=this.getClosestIndex(c,"time",a.getTime(),!0,0,c.length);b=AmCharts.resetDateToMin(b,this.categoryAxis.minPeriod, | ||
22 | 1);c=this.getClosestIndex(c,"time",b.getTime(),!1,0,c.length);this.zoom(d,c)}else this.zoom(a.getTime(),b.getTime())},zoomToCategoryValues:function(a,b){this.updateScrollbar=!0;this.zoom(this.getCategoryIndexByValue(a),this.getCategoryIndexByValue(b))},formatPeriodString:function(a,b){if(b){var c=["value","open","low","high","close"],d="value open low high close average sum count".split(" "),e=b.valueAxis,f=this.chartData,l=b.numberFormatter;l||(l=this.nf);for(var n=0;n<c.length;n++){for(var k=c[n], | ||
23 | g=0,h=0,m,u,r,s,p,v=0,q=0,x,t,y,w,C,B=this.start;B<=this.end;B++){var z=f[B];if(z&&(z=z.axes[e.id].graphs[b.id])){if(z.values){var A=z.values[k];if(!isNaN(A)){isNaN(m)&&(m=A);u=A;if(isNaN(r)||r>A)r=A;if(isNaN(s)||s<A)s=A;p=AmCharts.getDecimals(g);var D=AmCharts.getDecimals(A),g=g+A,g=AmCharts.roundTo(g,Math.max(p,D));h++;p=g/h}}if(z.percents&&(z=z.percents[k],!isNaN(z))){isNaN(x)&&(x=z);t=z;if(isNaN(y)||y>z)y=z;if(isNaN(w)||w<z)w=z;C=AmCharts.getDecimals(v);A=AmCharts.getDecimals(z);v+=z;v=AmCharts.roundTo(v, | ||
24 | Math.max(C,A));q++;C=v/q}}}v={open:x,close:t,high:w,low:y,average:C,sum:v,count:q};a=AmCharts.formatValue(a,{open:m,close:u,high:s,low:r,average:p,sum:g,count:h},d,l,k+"\\.",this.usePrefixes,this.prefixesOfSmallNumbers,this.prefixesOfBigNumbers);a=AmCharts.formatValue(a,v,d,this.pf,"percents\\."+k+"\\.")}}return a},formatString:function(a,b,c){var d=b.graph;if(-1!=a.indexOf("[[category]]")){var e=b.serialDataItem.category;if(this.categoryAxis.parseDates){var f=this.balloonDateFormat,l=this.chartCursor; | ||
25 | l&&(f=l.categoryBalloonDateFormat);-1!=a.indexOf("[[category]]")&&(f=AmCharts.formatDate(e,f),-1!=f.indexOf("fff")&&(f=AmCharts.formatMilliseconds(f,e)),e=f)}a=a.replace(/\[\[category\]\]/g,String(e))}d=d.numberFormatter;d||(d=this.nf);e=b.graph.valueAxis;(f=e.duration)&&!isNaN(b.values.value)&&(e=AmCharts.formatDuration(b.values.value,f,"",e.durationUnits,e.maxInterval,d),a=a.replace(RegExp("\\[\\[value\\]\\]","g"),e));e="value open low high close total".split(" ");f=this.pf;a=AmCharts.formatValue(a, | ||
26 | b.percents,e,f,"percents\\.");a=AmCharts.formatValue(a,b.values,e,d,"",this.usePrefixes,this.prefixesOfSmallNumbers,this.prefixesOfBigNumbers);a=AmCharts.formatValue(a,b.values,["percents"],f);-1!=a.indexOf("[[")&&(a=AmCharts.formatDataContextValue(a,b.dataContext));return a=AmCharts.AmSerialChart.base.formatString.call(this,a,b,c)},addChartScrollbar:function(a){AmCharts.callMethod("destroy",[this.chartScrollbar]);a&&(a.chart=this,this.listenTo(a,"zoomed",this.handleScrollbarZoom));this.rotate?void 0=== | ||
27 | a.width&&(a.width=a.scrollbarHeight):void 0===a.height&&(a.height=a.scrollbarHeight);this.chartScrollbar=a},removeChartScrollbar:function(){AmCharts.callMethod("destroy",[this.chartScrollbar]);this.chartScrollbar=null},handleReleaseOutside:function(a){AmCharts.AmSerialChart.base.handleReleaseOutside.call(this,a);AmCharts.callMethod("handleReleaseOutside",[this.chartScrollbar])}});AmCharts.Cuboid=AmCharts.Class({construct:function(a,b,c,d,e,f,l,n,k,g,h,m,u,r,s){this.set=a.set();this.container=a;this.h=Math.round(c);this.w=Math.round(b);this.dx=d;this.dy=e;this.colors=f;this.alpha=l;this.bwidth=n;this.bcolor=k;this.balpha=g;this.colors=f;this.dashLength=r;this.pattern=s;u?0>b&&0===h&&(h=180):0>c&&270==h&&(h=90);this.gradientRotation=h;0===d&&0===e&&(this.cornerRadius=m);this.draw()},draw:function(){var a=this.set;a.clear();var b=this.container,c=this.w,d=this.h,e=this.dx,f= | ||
28 | this.dy,l=this.colors,n=this.alpha,k=this.bwidth,g=this.bcolor,h=this.balpha,m=this.gradientRotation,u=this.cornerRadius,r=this.dashLength,s=this.pattern,p=l,v=l;"object"==typeof l&&(p=l[0],v=l[l.length-1]);var q,x,t,y,w,C,B,z,A,D=n;s&&(n=0);if(0<e||0<f)B=v,v=AmCharts.adjustLuminosity(p,-.2),v=AmCharts.adjustLuminosity(p,-.2),q=AmCharts.polygon(b,[0,e,c+e,c,0],[0,f,f,0,0],v,n,1,g,0,m),0<h&&(A=AmCharts.line(b,[0,e,c+e],[0,f,f],g,h,k,r)),x=AmCharts.polygon(b,[0,0,c,c,0],[0,d,d,0,0],v,n,1,g,0,m),x.translate(e, | ||
29 | f),0<h&&(t=AmCharts.line(b,[e,e],[f,f+d],g,h,k,r)),y=AmCharts.polygon(b,[0,0,e,e,0],[0,d,d+f,f,0],v,n,1,g,0,m),w=AmCharts.polygon(b,[c,c,c+e,c+e,c],[0,d,d+f,f,0],v,n,1,g,0,m),0<h&&(C=AmCharts.line(b,[c,c+e,c+e,c],[0,f,d+f,d],g,h,k,r)),v=AmCharts.adjustLuminosity(B,.2),B=AmCharts.polygon(b,[0,e,c+e,c,0],[d,d+f,d+f,d,d],v,n,1,g,0,m),0<h&&(z=AmCharts.line(b,[0,e,c+e],[d,d+f,d+f],g,h,k,r));n=D;1>Math.abs(d)&&(d=0);1>Math.abs(c)&&(c=0);b=0===d?AmCharts.line(b,[0,c],[0,0],g,h,k,r):0===c?AmCharts.line(b, | ||
30 | [0,0],[0,d],g,h,k,r):0<u?AmCharts.rect(b,c,d,l,n,k,g,h,u,m,r):AmCharts.polygon(b,[0,0,c,c,0],[0,d,d,0,0],l,n,k,g,h,m,!1,r);d=0>d?[q,A,x,t,y,w,C,B,z,b]:[B,z,x,t,y,w,q,A,C,b];for(q=0;q<d.length;q++)(x=d[q])&&a.push(x);s&&b.pattern(s)},width:function(a){this.w=a;this.draw()},height:function(a){this.h=a;this.draw()},animateHeight:function(a,b){var c=this;c.easing=b;c.totalFrames=Math.round(1E3*a/AmCharts.updateRate);c.rh=c.h;c.frame=0;c.height(1);setTimeout(function(){c.updateHeight.call(c)},AmCharts.updateRate)}, | ||
31 | updateHeight:function(){var a=this;a.frame++;var b=a.totalFrames;a.frame<=b&&(b=a.easing(0,a.frame,1,a.rh-1,b),a.height(b),setTimeout(function(){a.updateHeight.call(a)},AmCharts.updateRate))},animateWidth:function(a,b){var c=this;c.easing=b;c.totalFrames=Math.round(1E3*a/AmCharts.updateRate);c.rw=c.w;c.frame=0;c.width(1);setTimeout(function(){c.updateWidth.call(c)},AmCharts.updateRate)},updateWidth:function(){var a=this;a.frame++;var b=a.totalFrames;a.frame<=b&&(b=a.easing(0,a.frame,1,a.rw-1,b),a.width(b), | ||
32 | setTimeout(function(){a.updateWidth.call(a)},AmCharts.updateRate))}});AmCharts.CategoryAxis=AmCharts.Class({inherits:AmCharts.AxisBase,construct:function(a){this.cname="CategoryAxis";AmCharts.CategoryAxis.base.construct.call(this,a);this.minPeriod="DD";this.equalSpacing=this.parseDates=!1;this.position="bottom";this.startOnAxis=!1;this.firstDayOfWeek=1;this.gridPosition="middle";this.markPeriodChange=this.boldPeriodBeginning=!0;this.safeDistance=30;this.centerLabelOnFullPeriod=!0;this.periods=[{period:"ss",count:1},{period:"ss",count:5},{period:"ss",count:10},{period:"ss", | ||
33 | count:30},{period:"mm",count:1},{period:"mm",count:5},{period:"mm",count:10},{period:"mm",count:30},{period:"hh",count:1},{period:"hh",count:3},{period:"hh",count:6},{period:"hh",count:12},{period:"DD",count:1},{period:"DD",count:2},{period:"DD",count:3},{period:"DD",count:4},{period:"DD",count:5},{period:"WW",count:1},{period:"MM",count:1},{period:"MM",count:2},{period:"MM",count:3},{period:"MM",count:6},{period:"YYYY",count:1},{period:"YYYY",count:2},{period:"YYYY",count:5},{period:"YYYY",count:10}, | ||
34 | {period:"YYYY",count:50},{period:"YYYY",count:100}];this.dateFormats=[{period:"fff",format:"JJ:NN:SS"},{period:"ss",format:"JJ:NN:SS"},{period:"mm",format:"JJ:NN"},{period:"hh",format:"JJ:NN"},{period:"DD",format:"MMM DD"},{period:"WW",format:"MMM DD"},{period:"MM",format:"MMM"},{period:"YYYY",format:"YYYY"}];this.nextPeriod={};this.nextPeriod.fff="ss";this.nextPeriod.ss="mm";this.nextPeriod.mm="hh";this.nextPeriod.hh="DD";this.nextPeriod.DD="MM";this.nextPeriod.MM="YYYY";AmCharts.applyTheme(this, | ||
35 | a,this.cname)},draw:function(){AmCharts.CategoryAxis.base.draw.call(this);this.generateDFObject();var a=this.chart.chartData;this.data=a;if(AmCharts.ifArray(a)){var b,c=this.chart,d=this.start,e=this.labelFrequency,f=0;b=this.end-d+1;var l=this.gridCountR,n=this.showFirstLabel,k=this.showLastLabel,g,h="",m=AmCharts.extractPeriod(this.minPeriod);g=AmCharts.getPeriodDuration(m.period,m.count);var u,r,s,p,v,q;u=this.rotate;var x=this.firstDayOfWeek,t=this.boldPeriodBeginning,a=AmCharts.resetDateToMin(new Date(a[a.length- | ||
36 | 1].time+1.05*g),this.minPeriod,1,x).getTime(),y;this.endTime>a&&(this.endTime=a);q=this.minorGridEnabled;var w,a=this.gridAlpha,C;if(this.parseDates&&!this.equalSpacing){this.timeDifference=this.endTime-this.startTime;d=this.choosePeriod(0);e=d.period;u=d.count;r=AmCharts.getPeriodDuration(e,u);r<g&&(e=m.period,u=m.count,r=g);s=e;"WW"==s&&(s="DD");this.stepWidth=this.getStepWidth(this.timeDifference);var l=Math.ceil(this.timeDifference/r)+5,B=h=AmCharts.resetDateToMin(new Date(this.startTime-r),e, | ||
37 | u,x).getTime();s==e&&1==u&&this.centerLabelOnFullPeriod&&(v=r*this.stepWidth);this.cellWidth=g*this.stepWidth;b=Math.round(h/r);d=-1;b/2==Math.round(b/2)&&(d=-2,h-=r);var z=c.firstTime,A=0;q&&1<u&&(w=this.chooseMinorFrequency(u),C=AmCharts.getPeriodDuration(e,w));if(0<this.gridCountR)for(b=d;b<=l;b++){m=z+r*(b+Math.floor((B-z)/r))-A;"DD"==e&&(m+=36E5);m=AmCharts.resetDateToMin(new Date(m),e,u,x).getTime();"MM"==e&&(q=(m-h)/r,1.5<=(m-h)/r&&(m=m-(q-1)*r+AmCharts.getPeriodDuration("DD",3),m=AmCharts.resetDateToMin(new Date(m), | ||
38 | e,1).getTime(),A+=r));g=(m-this.startTime)*this.stepWidth;q=!1;this.nextPeriod[s]&&(q=this.checkPeriodChange(this.nextPeriod[s],1,m,h,s));y=!1;q&&this.markPeriodChange?(q=this.dateFormatsObject[this.nextPeriod[s]],this.twoLineMode&&(q=this.dateFormatsObject[s]+"\n"+q,q=AmCharts.fixBrakes(q)),y=!0):q=this.dateFormatsObject[s];t||(y=!1);h=AmCharts.formatDate(new Date(m),q);if(b==d&&!n||b==l&&!k)h=" ";this.labelFunction&&(h=this.labelFunction(h,new Date(m),this,e,u,p).toString());this.boldLabels&&(y= | ||
39 | !0);p=new this.axisItemRenderer(this,g,h,!1,v,0,!1,y);this.pushAxisItem(p);p=h=m;if(!isNaN(w))for(g=1;g<u;g+=w)this.gridAlpha=this.minorGridAlpha,q=m+C*g,q=AmCharts.resetDateToMin(new Date(q),e,w,x).getTime(),q=new this.axisItemRenderer(this,(q-this.startTime)*this.stepWidth),this.pushAxisItem(q);this.gridAlpha=a}}else if(!this.parseDates){if(this.cellWidth=this.getStepWidth(b),b<l&&(l=b),f+=this.start,this.stepWidth=this.getStepWidth(b),0<l)for(t=Math.floor(b/l),w=this.chooseMinorFrequency(t),g= | ||
40 | f,g/2==Math.round(g/2)&&g--,0>g&&(g=0),l=0,this.end-g+1>=this.autoRotateCount&&(this.labelRotation=this.autoRotateAngle),b=g;b<=this.end+2;b++){p=!1;0<=b&&b<this.data.length?(s=this.data[b],h=s.category,p=s.forceShow):h="";if(q&&!isNaN(w))if(b/w==Math.round(b/w)||p)b/t==Math.round(b/t)||p||(this.gridAlpha=this.minorGridAlpha,h=void 0);else continue;else if(b/t!=Math.round(b/t)&&!p)continue;g=this.getCoordinate(b-f);p=0;"start"==this.gridPosition&&(g-=this.cellWidth/2,p=this.cellWidth/2);x=!0;tickShift= | ||
41 | p;"start"==this.tickPosition&&(tickShift=0,x=!1,p=0);if(b==d&&!n||b==this.end&&!k)h=void 0;Math.round(l/e)!=l/e&&(h=void 0);l++;B=this.cellWidth;u&&(B=NaN);this.labelFunction&&s&&(h=this.labelFunction(h,s,this));h=AmCharts.fixBrakes(h);y=!1;this.boldLabels&&(y=!0);b>this.end&&"start"==this.tickPosition&&(h=" ");p=new this.axisItemRenderer(this,g,h,x,B,p,void 0,y,tickShift,!1,s.labelColor);p.serialDataItem=s;this.pushAxisItem(p);this.gridAlpha=a}}else if(this.parseDates&&this.equalSpacing){f=this.start; | ||
42 | this.startTime=this.data[this.start].time;this.endTime=this.data[this.end].time;this.timeDifference=this.endTime-this.startTime;d=this.choosePeriod(0);e=d.period;u=d.count;r=AmCharts.getPeriodDuration(e,u);r<g&&(e=m.period,u=m.count,r=g);s=e;"WW"==s&&(s="DD");this.stepWidth=this.getStepWidth(b);l=Math.ceil(this.timeDifference/r)+1;h=AmCharts.resetDateToMin(new Date(this.startTime-r),e,u,x).getTime();this.cellWidth=this.getStepWidth(b);b=Math.round(h/r);d=-1;b/2==Math.round(b/2)&&(d=-2,h-=r);g=this.start; | ||
43 | g/2==Math.round(g/2)&&g--;0>g&&(g=0);v=this.end+2;v>=this.data.length&&(v=this.data.length);C=!1;C=!n;this.previousPos=-1E3;20<this.labelRotation&&(this.safeDistance=5);r=g;if(this.data[g].time!=AmCharts.resetDateToMin(new Date(this.data[g].time),e,u,x).getTime())for(x=0,y=h,b=g;b<v;b++)m=this.data[b].time,this.checkPeriodChange(e,u,m,y)&&(x++,2<=x&&(r=b,b=v),y=m);q&&1<u&&(w=this.chooseMinorFrequency(u),AmCharts.getPeriodDuration(e,w));if(0<this.gridCountR)for(b=g;b<v;b++)if(m=this.data[b].time,this.checkPeriodChange(e, | ||
44 | u,m,h)&&b>=r){g=this.getCoordinate(b-this.start);q=!1;this.nextPeriod[s]&&(q=this.checkPeriodChange(this.nextPeriod[s],1,m,h,s));y=!1;q&&this.markPeriodChange?(q=this.dateFormatsObject[this.nextPeriod[s]],y=!0):q=this.dateFormatsObject[s];h=AmCharts.formatDate(new Date(m),q);if(b==d&&!n||b==l&&!k)h=" ";C?C=!1:(t||(y=!1),g-this.previousPos>this.safeDistance*Math.cos(this.labelRotation*Math.PI/180)&&(this.labelFunction&&(h=this.labelFunction(h,new Date(m),this,e,u,p)),this.boldLabels&&(y=!0),p=new this.axisItemRenderer(this, | ||
45 | g,h,void 0,void 0,void 0,void 0,y),x=p.graphics(),this.pushAxisItem(p),p=x.getBBox().width,AmCharts.isModern||(p-=g),this.previousPos=g+p));p=h=m}else isNaN(w)||(this.checkPeriodChange(e,w,m,B)&&(this.gridAlpha=this.minorGridAlpha,g=this.getCoordinate(b-this.start),q=new this.axisItemRenderer(this,g),this.pushAxisItem(q),B=m),this.gridAlpha=a)}for(b=0;b<this.data.length;b++)if(n=this.data[b])k=this.parseDates&&!this.equalSpacing?Math.round((n.time-this.startTime)*this.stepWidth+this.cellWidth/2): | ||
46 | this.getCoordinate(b-f),n.x[this.id]=k;n=this.guides.length;for(b=0;b<n;b++)k=this.guides[b],t=t=t=a=d=NaN,w=k.above,k.toCategory&&(t=c.getCategoryIndexByValue(k.toCategory),isNaN(t)||(d=this.getCoordinate(t-f),k.expand&&(d+=this.cellWidth/2),p=new this.axisItemRenderer(this,d,"",!0,NaN,NaN,k),this.pushAxisItem(p,w))),k.category&&(t=c.getCategoryIndexByValue(k.category),isNaN(t)||(a=this.getCoordinate(t-f),k.expand&&(a-=this.cellWidth/2),t=(d-a)/2,p=new this.axisItemRenderer(this,a,k.label,!0,NaN, | ||
47 | t,k),this.pushAxisItem(p,w))),k.toDate&&(k.toDate instanceof Date||(k.toDate=AmCharts.stringToDate(k.toDate,c.dataDateFormat)),this.equalSpacing?(t=c.getClosestIndex(this.data,"time",k.toDate.getTime(),!1,0,this.data.length-1),isNaN(t)||(d=this.getCoordinate(t-f))):d=(k.toDate.getTime()-this.startTime)*this.stepWidth,p=new this.axisItemRenderer(this,d,"",!0,NaN,NaN,k),this.pushAxisItem(p,w)),k.date&&(k.date instanceof Date||(k.date=AmCharts.stringToDate(k.date,c.dataDateFormat)),this.equalSpacing? | ||
48 | (t=c.getClosestIndex(this.data,"time",k.date.getTime(),!1,0,this.data.length-1),isNaN(t)||(a=this.getCoordinate(t-f))):a=(k.date.getTime()-this.startTime)*this.stepWidth,t=(d-a)/2,p="H"==this.orientation?new this.axisItemRenderer(this,a,k.label,!1,2*t,NaN,k):new this.axisItemRenderer(this,a,k.label,!1,NaN,t,k),this.pushAxisItem(p,w)),(0<d||0<a)&&(d<this.width||a<this.width)&&(d=new this.guideFillRenderer(this,a,d,k),a=d.graphics(),this.pushAxisItem(d,w),k.graphics=a,a.index=b,k.balloonText&&this.addEventListeners(a, | ||
49 | k))}this.axisCreated=!0;c=this.x;f=this.y;this.set.translate(c,f);this.labelsSet.translate(c,f);this.positionTitle();(c=this.axisLine.set)&&c.toFront();c=this.getBBox().height;2<c-this.previousHeight&&this.autoWrap&&!this.parseDates&&(this.axisCreated=this.chart.marginsUpdated=!1);this.previousHeight=c},chooseMinorFrequency:function(a){for(var b=10;0<b;b--)if(a/b==Math.round(a/b))return a/b},choosePeriod:function(a){var b=AmCharts.getPeriodDuration(this.periods[a].period,this.periods[a].count),c= | ||
50 | Math.ceil(this.timeDifference/b),d=this.periods;return this.timeDifference<b&&0<a?d[a-1]:c<=this.gridCountR?d[a]:a+1<d.length?this.choosePeriod(a+1):d[a]},getStepWidth:function(a){var b;this.startOnAxis?(b=this.axisWidth/(a-1),1==a&&(b=this.axisWidth)):b=this.axisWidth/a;return b},getCoordinate:function(a){a*=this.stepWidth;this.startOnAxis||(a+=this.stepWidth/2);return Math.round(a)},timeZoom:function(a,b){this.startTime=a;this.endTime=b},minDuration:function(){var a=AmCharts.extractPeriod(this.minPeriod); | ||
51 | return AmCharts.getPeriodDuration(a.period,a.count)},checkPeriodChange:function(a,b,c,d,e){c=new Date(c);var f=new Date(d),l=this.firstDayOfWeek;d=b;"DD"==a&&(b=1);c=AmCharts.resetDateToMin(c,a,b,l).getTime();b=AmCharts.resetDateToMin(f,a,b,l).getTime();return"DD"==a&&"hh"!=e&&c-b<=AmCharts.getPeriodDuration(a,d)?!1:c!=b?!0:!1},generateDFObject:function(){this.dateFormatsObject={};var a;for(a=0;a<this.dateFormats.length;a++){var b=this.dateFormats[a];this.dateFormatsObject[b.period]=b.format}},xToIndex:function(a){var b= | ||
52 | this.data,c=this.chart,d=c.rotate,e=this.stepWidth;this.parseDates&&!this.equalSpacing?(a=this.startTime+Math.round(a/e)-this.minDuration()/2,c=c.getClosestIndex(b,"time",a,!1,this.start,this.end+1)):(this.startOnAxis||(a-=e/2),c=this.start+Math.round(a/e));var c=AmCharts.fitToBounds(c,0,b.length-1),f;b[c]&&(f=b[c].x[this.id]);d?f>this.height+1&&c--:f>this.width+1&&c--;0>f&&c++;return c=AmCharts.fitToBounds(c,0,b.length-1)},dateToCoordinate:function(a){return this.parseDates&&!this.equalSpacing?(a.getTime()- | ||
53 | this.startTime)*this.stepWidth:this.parseDates&&this.equalSpacing?(a=this.chart.getClosestIndex(this.data,"time",a.getTime(),!1,0,this.data.length-1),this.getCoordinate(a-this.start)):NaN},categoryToCoordinate:function(a){return this.chart?(a=this.chart.getCategoryIndexByValue(a),this.getCoordinate(a-this.start)):NaN},coordinateToDate:function(a){return this.equalSpacing?(a=this.xToIndex(a),new Date(this.data[a].time)):new Date(this.startTime+a/this.stepWidth)}}); |
amcharts/themes/black.js
File was created | 1 | AmCharts.themes.black = { | |
2 | |||
3 | themeName: "black", | ||
4 | |||
5 | AmChart: { | ||
6 | color: "#e7e7e7", backgroundColor: "#222222" | ||
7 | }, | ||
8 | |||
9 | AmCoordinateChart: { | ||
10 | colors: ["#de4c4f", "#d8854f", "#eea638", "#a7a737", "#86a965", "#8aabb0", "#69c8ff", "#cfd27e", "#9d9888", "#916b8a", "#724887", "#7256bc"] | ||
11 | }, | ||
12 | |||
13 | AmStockChart: { | ||
14 | colors: ["#de4c4f", "#d8854f", "#eea638", "#a7a737", "#86a965", "#8aabb0", "#69c8ff", "#cfd27e", "#9d9888", "#916b8a", "#724887", "#7256bc"] | ||
15 | }, | ||
16 | |||
17 | AmSlicedChart: { | ||
18 | outlineAlpha: 1, | ||
19 | outlineThickness: 2, | ||
20 | labelTickColor: "#FFFFFF", | ||
21 | labelTickAlpha: 0.3, | ||
22 | colors: ["#de4c4f", "#d8854f", "#eea638", "#a7a737", "#86a965", "#8aabb0", "#69c8ff", "#cfd27e", "#9d9888", "#916b8a", "#724887", "#7256bc"] | ||
23 | }, | ||
24 | |||
25 | AmRectangularChart: { | ||
26 | zoomOutButtonColor: '#FFFFFF', | ||
27 | zoomOutButtonRollOverAlpha: 0.15, | ||
28 | zoomOutButtonImage: "lensWhite.png" | ||
29 | }, | ||
30 | |||
31 | AxisBase: { | ||
32 | axisColor: "#FFFFFF", | ||
33 | axisAlpha: 0.3, | ||
34 | gridAlpha: 0.1, | ||
35 | gridColor: "#FFFFFF", | ||
36 | dashLength: 3 | ||
37 | }, | ||
38 | |||
39 | ChartScrollbar: { | ||
40 | backgroundColor: "#000000", | ||
41 | backgroundAlpha: 0.2, | ||
42 | graphFillAlpha: 0.2, | ||
43 | graphLineAlpha: 0, | ||
44 | graphFillColor: "#FFFFFF", | ||
45 | selectedGraphFillColor: "#FFFFFF", | ||
46 | selectedGraphFillAlpha: 0.4, | ||
47 | selectedGraphLineColor: "#FFFFFF", | ||
48 | selectedBackgroundColor: "#FFFFFF", | ||
49 | selectedBackgroundAlpha: 0.09, | ||
50 | gridAlpha: 0.15 | ||
51 | }, | ||
52 | |||
53 | ChartCursor: { | ||
54 | cursorColor: "#FFFFFF", | ||
55 | color: "#000000", | ||
56 | cursorAlpha: 0.5 | ||
57 | }, | ||
58 | |||
59 | AmLegend: { | ||
60 | color: "#e7e7e7" | ||
61 | }, | ||
62 | |||
63 | AmGraph: { | ||
64 | lineAlpha: 0.9 | ||
65 | }, | ||
66 | |||
67 | |||
68 | GaugeArrow: { | ||
69 | color: "#FFFFFF", | ||
70 | alpha: 0.8, | ||
71 | nailAlpha: 0, | ||
72 | innerRadius: "40%", | ||
73 | nailRadius: 15, | ||
74 | startWidth: 15, | ||
75 | borderAlpha: 0.8, | ||
76 | nailBorderAlpha: 0 | ||
77 | }, | ||
78 | |||
79 | GaugeAxis: { | ||
80 | tickColor: "#FFFFFF", | ||
81 | tickAlpha: 1, | ||
82 | tickLength: 15, | ||
83 | minorTickLength: 8, | ||
84 | axisThickness: 3, | ||
85 | axisColor: '#FFFFFF', | ||
86 | axisAlpha: 1, | ||
87 | bandAlpha: 0.8 | ||
88 | }, | ||
89 | |||
90 | TrendLine: { | ||
91 | lineColor: "#c03246", | ||
92 | lineAlpha: 0.8 | ||
93 | }, | ||
94 | |||
95 | // ammap | ||
96 | AreasSettings: { | ||
97 | alpha: 0.8, | ||
98 | color: "#FFFFFF", | ||
99 | colorSolid: "#000000", | ||
100 | unlistedAreasAlpha: 0.4, | ||
101 | unlistedAreasColor: "#FFFFFF", | ||
102 | outlineColor: "#000000", | ||
103 | outlineAlpha: 0.5, | ||
104 | outlineThickness: 0.5, | ||
105 | rollOverColor: "#3c5bdc", | ||
106 | rollOverOutlineColor: "#000000", | ||
107 | selectedOutlineColor: "#000000", | ||
108 | selectedColor: "#f15135", | ||
109 | unlistedAreasOutlineColor: "#000000", | ||
110 | unlistedAreasOutlineAlpha: 0.5 | ||
111 | }, | ||
112 | |||
113 | LinesSettings: { | ||
114 | color: "#FFFFFF", | ||
115 | alpha: 0.8 | ||
116 | }, | ||
117 | |||
118 | ImagesSettings: { | ||
119 | alpha: 0.8, | ||
120 | labelColor: "#FFFFFF", | ||
121 | color: "#FFFFFF", | ||
122 | labelRollOverColor: "#3c5bdc" | ||
123 | }, | ||
124 | |||
125 | ZoomControl: { | ||
126 | buttonRollOverColor: "#3c5bdc", | ||
127 | buttonFillColor: "#738f58", | ||
128 | buttonBorderColor: "#738f58", | ||
129 | buttonFillAlpha: 0.8, | ||
130 | gridBackgroundColor: "#FFFFFF", | ||
131 | buttonBorderAlpha:0, | ||
132 | buttonCornerRadius:2, | ||
133 | gridAlpha:0.5, | ||
134 | gridBackgroundColor:"#FFFFFF", | ||
135 | homeIconFile:"homeIconWhite.gif", | ||
136 | buttonIconAlpha:0.6, | ||
137 | gridAlpha: 0.2, | ||
138 | buttonSize:20 | ||
139 | }, | ||
140 | |||
141 | SmallMap: { | ||
142 | mapColor: "#FFFFFF", | ||
143 | rectangleColor: "#FFFFFF", | ||
144 | backgroundColor: "#000000", | ||
145 | backgroundAlpha: 0.7, | ||
146 | borderThickness: 1, | ||
147 | borderAlpha: 0.8 | ||
148 | }, | ||
149 | |||
150 | // the defaults below are set using CSS syntax, you can use any existing css property | ||
151 | // if you don't use Stock chart, you can delete lines below | ||
152 | PeriodSelector: { | ||
153 | color: "#e7e7e7" | ||
154 | }, | ||
155 | |||
156 | PeriodButton: { | ||
157 | color: "#e7e7e7", | ||
158 | background: "transparent", | ||
159 | opacity: 0.7, | ||
160 | border: "1px solid rgba(255, 255, 255, .15)", | ||
161 | MozBorderRadius: "5px", | ||
162 | borderRadius: "5px", | ||
163 | margin: "1px", | ||
164 | outline: "none", | ||
165 | boxSizing: "border-box" | ||
166 | }, | ||
167 | |||
168 | PeriodButtonSelected: { | ||
169 | color: "#e7e7e7", | ||
170 | backgroundColor: "rgba(255, 255, 255, 0.1)", | ||
171 | border: "1px solid rgba(255, 255, 255, .3)", | ||
172 | MozBorderRadius: "5px", | ||
173 | borderRadius: "5px", | ||
174 | margin: "1px", | ||
175 | outline: "none", | ||
176 | opacity: 1, | ||
177 | boxSizing: "border-box" | ||
178 | }, | ||
179 | |||
180 | PeriodInputField: { | ||
181 | color: "#e7e7e7", | ||
182 | background: "transparent", | ||
183 | border: "1px solid rgba(255, 255, 255, .15)", | ||
184 | outline: "none" | ||
185 | }, | ||
186 | |||
187 | DataSetSelector: { | ||
188 | color: "#e7e7e7", | ||
189 | selectedBackgroundColor: "rgba(255, 255, 255, .25)", | ||
190 | rollOverBackgroundColor: "rgba(255, 255, 255, .15)" | ||
191 | }, | ||
192 | |||
193 | DataSetCompareList: { | ||
194 | color: "#e7e7e7", | ||
195 | lineHeight: "100%", | ||
196 | boxSizing: "initial", | ||
197 | webkitBoxSizing: "initial", | ||
198 | border: "1px solid rgba(255, 255, 255, .15)" | ||
199 | }, | ||
200 | |||
201 | DataSetSelect: { | ||
202 | border: "1px solid rgba(255, 255, 255, .15)", | ||
203 | outline: "none" | ||
204 | } | ||
205 | |||
206 | }; |
amcharts/themes/chalk.js
File was created | 1 | AmCharts.themes.chalk = { | |
2 | |||
3 | themeName: "chalk", | ||
4 | |||
5 | AmChart: { | ||
6 | color: "#e7e7e7", | ||
7 | fontFamily: "Covered By Your Grace", | ||
8 | fontSize: 18, | ||
9 | handDrawn: true, | ||
10 | backgroundColor: "#282828" | ||
11 | }, | ||
12 | |||
13 | AmCoordinateChart: { | ||
14 | colors: ["#FFFFFF", "#e384a6", "#f4d499", "#4d90d6", "#c7e38c", "#9986c8", "#edf28c", "#ffd1d4", "#5ee1dc", "#b0eead", "#fef85a", "#8badd2"] | ||
15 | }, | ||
16 | |||
17 | AmSlicedChart: { | ||
18 | outlineAlpha: 1, | ||
19 | labelTickColor: "#FFFFFF", | ||
20 | labelTickAlpha: 0.3, | ||
21 | colors: ["#FFFFFF", "#e384a6", "#f4d499", "#4d90d6", "#c7e38c", "#9986c8", "#edf28c", "#ffd1d4", "#5ee1dc", "#b0eead", "#fef85a", "#8badd2"] | ||
22 | }, | ||
23 | |||
24 | AmStockChart: { | ||
25 | colors: ["#FFFFFF", "#e384a6", "#f4d499", "#4d90d6", "#c7e38c", "#9986c8", "#edf28c", "#ffd1d4", "#5ee1dc", "#b0eead", "#fef85a", "#8badd2"] | ||
26 | }, | ||
27 | |||
28 | AmRectangularChart: { | ||
29 | |||
30 | zoomOutButtonColor: '#FFFFFF', | ||
31 | zoomOutButtonRollOverAlpha: 0.15, | ||
32 | zoomOutButtonImage: "lensWhite.png" | ||
33 | }, | ||
34 | |||
35 | AxisBase: { | ||
36 | axisColor: "#FFFFFF", | ||
37 | gridColor: "#FFFFFF" | ||
38 | }, | ||
39 | |||
40 | ChartScrollbar: { | ||
41 | backgroundColor: "#FFFFFF", | ||
42 | backgroundAlpha: 0.2, | ||
43 | graphFillAlpha: 0.5, | ||
44 | graphLineAlpha: 0, | ||
45 | selectedBackgroundColor: "#000000", | ||
46 | selectedBackgroundAlpha: 0.25, | ||
47 | fontSize: 15, | ||
48 | gridAlpha: 0.15 | ||
49 | }, | ||
50 | |||
51 | ChartCursor: { | ||
52 | cursorColor: "#FFFFFF", | ||
53 | color: "#000000" | ||
54 | }, | ||
55 | |||
56 | AmLegend: { | ||
57 | color: "#e7e7e7", | ||
58 | markerSize: 20 | ||
59 | }, | ||
60 | |||
61 | AmGraph: { | ||
62 | lineAlpha: 0.8 | ||
63 | }, | ||
64 | |||
65 | |||
66 | GaugeArrow: { | ||
67 | color: "#FFFFFF", | ||
68 | alpha: 0.1, | ||
69 | nailAlpha: 0, | ||
70 | innerRadius: "40%", | ||
71 | nailRadius: 15, | ||
72 | startWidth: 15, | ||
73 | borderAlpha: 0.8, | ||
74 | nailBorderAlpha: 0 | ||
75 | }, | ||
76 | |||
77 | GaugeAxis: { | ||
78 | tickColor: "#FFFFFF", | ||
79 | tickAlpha: 0.8, | ||
80 | tickLength: 15, | ||
81 | minorTickLength: 8, | ||
82 | axisThickness: 3, | ||
83 | axisColor: '#FFFFFF', | ||
84 | axisAlpha: 0.8, | ||
85 | bandAlpha: 0.4 | ||
86 | }, | ||
87 | |||
88 | TrendLine: { | ||
89 | lineColor: "#c03246", | ||
90 | lineAlpha: 0.8 | ||
91 | }, | ||
92 | |||
93 | // ammap | ||
94 | AmMap: { | ||
95 | handDrawn: false | ||
96 | }, | ||
97 | |||
98 | AreasSettings: { | ||
99 | alpha: 0.8, | ||
100 | color: "#FFFFFF", | ||
101 | colorSolid: "#000000", | ||
102 | unlistedAreasAlpha: 0.4, | ||
103 | unlistedAreasColor: "#FFFFFF", | ||
104 | outlineColor: "#000000", | ||
105 | outlineAlpha: 0.5, | ||
106 | outlineThickness: 0.5, | ||
107 | rollOverColor: "#4d90d6", | ||
108 | rollOverOutlineColor: "#000000", | ||
109 | selectedOutlineColor: "#000000", | ||
110 | selectedColor: "#e384a6", | ||
111 | unlistedAreasOutlineColor: "#000000", | ||
112 | unlistedAreasOutlineAlpha: 0.5 | ||
113 | }, | ||
114 | |||
115 | LinesSettings: { | ||
116 | color: "#FFFFFF", | ||
117 | alpha: 0.8 | ||
118 | }, | ||
119 | |||
120 | ImagesSettings: { | ||
121 | alpha: 0.8, | ||
122 | labelFontSize: 16, | ||
123 | labelColor: "#FFFFFF", | ||
124 | color: "#FFFFFF", | ||
125 | labelRollOverColor: "#4d90d6" | ||
126 | }, | ||
127 | |||
128 | ZoomControl: { | ||
129 | buttonRollOverColor: "#4d90d6", | ||
130 | buttonFillColor: "#e384a6", | ||
131 | buttonFillAlpha: 0.8, | ||
132 | buttonBorderColor: "#FFFFFF", | ||
133 | gridBackgroundColor: "#FFFFFF", | ||
134 | gridAlpha: 0.8 | ||
135 | }, | ||
136 | |||
137 | SmallMap: { | ||
138 | mapColor: "#FFFFFF", | ||
139 | rectangleColor: "#FFFFFF", | ||
140 | backgroundColor: "#000000", | ||
141 | backgroundAlpha: 0.7, | ||
142 | borderThickness: 1, | ||
143 | borderAlpha: 0.8 | ||
144 | }, | ||
145 | |||
146 | |||
147 | // the defaults below are set using CSS syntax, you can use any existing css property | ||
148 | // if you don't use Stock chart, you can delete lines below | ||
149 | PeriodSelector: { | ||
150 | fontFamily: "Covered By Your Grace", | ||
151 | fontSize:"16px", | ||
152 | color: "#e7e7e7" | ||
153 | }, | ||
154 | |||
155 | PeriodButton: { | ||
156 | fontFamily: "Covered By Your Grace", | ||
157 | fontSize:"16px", | ||
158 | color: "#e7e7e7", | ||
159 | background: "transparent", | ||
160 | opacity: 0.7, | ||
161 | border: "1px solid rgba(255, 255, 255, .15)", | ||
162 | MozBorderRadius: "5px", | ||
163 | borderRadius: "5px", | ||
164 | margin: "1px", | ||
165 | outline: "none", | ||
166 | boxSizing: "border-box" | ||
167 | }, | ||
168 | |||
169 | PeriodButtonSelected: { | ||
170 | fontFamily: "Covered By Your Grace", | ||
171 | fontSize:"16px", | ||
172 | color: "#e7e7e7", | ||
173 | backgroundColor: "rgba(255, 255, 255, 0.1)", | ||
174 | border: "1px solid rgba(255, 255, 255, .3)", | ||
175 | MozBorderRadius: "5px", | ||
176 | borderRadius: "5px", | ||
177 | margin: "1px", | ||
178 | outline: "none", | ||
179 | opacity: 1, | ||
180 | boxSizing: "border-box" | ||
181 | }, | ||
182 | |||
183 | PeriodInputField: { | ||
184 | fontFamily: "Covered By Your Grace", | ||
185 | fontSize:"16px", | ||
186 | color: "#e7e7e7", | ||
187 | background: "transparent", | ||
188 | border: "1px solid rgba(255, 255, 255, .15)", | ||
189 | outline: "none" | ||
190 | }, | ||
191 | |||
192 | DataSetSelector: { | ||
193 | fontFamily: "Covered By Your Grace", | ||
194 | fontSize:"16px", | ||
195 | color: "#e7e7e7", | ||
196 | selectedBackgroundColor: "rgba(255, 255, 255, .25)", | ||
197 | rollOverBackgroundColor: "rgba(255, 255, 255, .15)" | ||
198 | }, | ||
199 | |||
200 | DataSetCompareList: { | ||
201 | fontFamily: "Covered By Your Grace", | ||
202 | fontSize:"16px", | ||
203 | color: "#e7e7e7", | ||
204 | lineHeight: "100%", | ||
205 | boxSizing: "initial", | ||
206 | webkitBoxSizing: "initial", | ||
207 | border: "1px solid rgba(255, 255, 255, .15)" | ||
208 | }, | ||
209 | |||
210 | DataSetSelect: { | ||
211 | fontFamily: "Covered By Your Grace", | ||
212 | fontSize:"16px", | ||
213 | border: "1px solid rgba(255, 255, 255, .15)", | ||
214 | outline: "none" | ||
215 | } | ||
216 | |||
217 | }; |
amcharts/themes/dark.js
File was created | 1 | AmCharts.themes.dark = { | |
2 | |||
3 | themeName: "dark", | ||
4 | |||
5 | AmChart: { | ||
6 | color: "#e7e7e7", backgroundColor: "#282828" | ||
7 | }, | ||
8 | |||
9 | AmCoordinateChart: { | ||
10 | colors: ["#ae85c9", "#aab9f7", "#b6d2ff", "#c9e6f2", "#c9f0e1", "#e8d685", "#e0ad63", "#d48652", "#d27362", "#495fba", "#7a629b", "#8881cc"] | ||
11 | }, | ||
12 | |||
13 | AmStockChart: { | ||
14 | colors: ["#639dbd", "#e8d685", "#ae85c9", "#c9f0e1", "#d48652", "#629b6d", "#719dc3", "#719dc3"] | ||
15 | }, | ||
16 | |||
17 | AmSlicedChart: { | ||
18 | outlineAlpha: 1, | ||
19 | outlineThickness: 2, | ||
20 | labelTickColor: "#FFFFFF", | ||
21 | labelTickAlpha: 0.3, | ||
22 | colors: ["#495fba", "#e8d685", "#ae85c9", "#c9f0e1", "#d48652", "#629b6d", "#719dc3", "#719dc3"] | ||
23 | }, | ||
24 | |||
25 | AmRectangularChart: { | ||
26 | zoomOutButtonColor: '#FFFFFF', | ||
27 | zoomOutButtonRollOverAlpha: 0.15, | ||
28 | zoomOutButtonImage: "lensWhite.png" | ||
29 | }, | ||
30 | |||
31 | AxisBase: { | ||
32 | axisColor: "#FFFFFF", | ||
33 | axisAlpha: 0.3, | ||
34 | gridAlpha: 0.1, | ||
35 | gridColor: "#FFFFFF", | ||
36 | dashLength: 3 | ||
37 | }, | ||
38 | |||
39 | ChartScrollbar: { | ||
40 | backgroundColor: "#000000", | ||
41 | backgroundAlpha: 0.2, | ||
42 | graphFillAlpha: 0.2, | ||
43 | graphLineAlpha: 0, | ||
44 | graphFillColor: "#FFFFFF", | ||
45 | selectedGraphFillColor: "#FFFFFF", | ||
46 | selectedGraphFillAlpha: 0.4, | ||
47 | selectedGraphLineColor: "#FFFFFF", | ||
48 | selectedBackgroundColor: "#FFFFFF", | ||
49 | selectedBackgroundAlpha: 0.09, | ||
50 | gridAlpha: 0.15 | ||
51 | }, | ||
52 | |||
53 | ChartCursor: { | ||
54 | cursorColor: "#FFFFFF", | ||
55 | color: "#000000", | ||
56 | cursorAlpha: 0.5 | ||
57 | }, | ||
58 | |||
59 | AmLegend: { | ||
60 | color: "#e7e7e7" | ||
61 | }, | ||
62 | |||
63 | AmGraph: { | ||
64 | lineAlpha: 0.9 | ||
65 | }, | ||
66 | |||
67 | |||
68 | GaugeArrow: { | ||
69 | color: "#FFFFFF", | ||
70 | alpha: 0.8, | ||
71 | nailAlpha: 0, | ||
72 | innerRadius: "40%", | ||
73 | nailRadius: 15, | ||
74 | startWidth: 15, | ||
75 | borderAlpha: 0.8, | ||
76 | nailBorderAlpha: 0 | ||
77 | }, | ||
78 | |||
79 | GaugeAxis: { | ||
80 | tickColor: "#FFFFFF", | ||
81 | tickAlpha: 1, | ||
82 | tickLength: 15, | ||
83 | minorTickLength: 8, | ||
84 | axisThickness: 3, | ||
85 | axisColor: '#FFFFFF', | ||
86 | axisAlpha: 1, | ||
87 | bandAlpha: 0.8 | ||
88 | }, | ||
89 | |||
90 | TrendLine: { | ||
91 | lineColor: "#c03246", | ||
92 | lineAlpha: 0.8 | ||
93 | }, | ||
94 | |||
95 | // ammap | ||
96 | AreasSettings: { | ||
97 | alpha: 0.8, | ||
98 | color: "#FFFFFF", | ||
99 | colorSolid: "#000000", | ||
100 | unlistedAreasAlpha: 0.4, | ||
101 | unlistedAreasColor: "#FFFFFF", | ||
102 | outlineColor: "#000000", | ||
103 | outlineAlpha: 0.5, | ||
104 | outlineThickness: 0.5, | ||
105 | rollOverColor: "#3c5bdc", | ||
106 | rollOverOutlineColor: "#000000", | ||
107 | selectedOutlineColor: "#000000", | ||
108 | selectedColor: "#f15135", | ||
109 | unlistedAreasOutlineColor: "#000000", | ||
110 | unlistedAreasOutlineAlpha: 0.5 | ||
111 | }, | ||
112 | |||
113 | LinesSettings: { | ||
114 | color: "#FFFFFF", | ||
115 | alpha: 0.8 | ||
116 | }, | ||
117 | |||
118 | ImagesSettings: { | ||
119 | alpha: 0.8, | ||
120 | labelColor: "#FFFFFF", | ||
121 | color: "#FFFFFF", | ||
122 | labelRollOverColor: "#3c5bdc" | ||
123 | }, | ||
124 | |||
125 | ZoomControl: { | ||
126 | buttonRollOverColor: "#3c5bdc", | ||
127 | buttonFillColor: "#f15135", | ||
128 | buttonFillAlpha: 0.8, | ||
129 | gridBackgroundColor: "#FFFFFF", | ||
130 | buttonBorderAlpha:0, | ||
131 | buttonCornerRadius:2, | ||
132 | gridAlpha:0.5, | ||
133 | gridBackgroundColor:"#FFFFFF", | ||
134 | homeIconFile:"homeIconWhite.gif", | ||
135 | buttonIconAlpha:0.6, | ||
136 | gridAlpha: 0.2, | ||
137 | buttonSize:20 | ||
138 | }, | ||
139 | |||
140 | SmallMap: { | ||
141 | mapColor: "#FFFFFF", | ||
142 | rectangleColor: "#FFFFFF", | ||
143 | backgroundColor: "#000000", | ||
144 | backgroundAlpha: 0.7, | ||
145 | borderThickness: 1, | ||
146 | borderAlpha: 0.8 | ||
147 | }, | ||
148 | |||
149 | // the defaults below are set using CSS syntax, you can use any existing css property | ||
150 | // if you don't use Stock chart, you can delete lines below | ||
151 | PeriodSelector: { | ||
152 | color: "#e7e7e7" | ||
153 | }, | ||
154 | |||
155 | PeriodButton: { | ||
156 | color: "#e7e7e7", | ||
157 | background: "transparent", | ||
158 | opacity: 0.7, | ||
159 | border: "1px solid rgba(255, 255, 255, .15)", | ||
160 | MozBorderRadius: "5px", | ||
161 | borderRadius: "5px", | ||
162 | margin: "1px", | ||
163 | outline: "none", | ||
164 | boxSizing: "border-box" | ||
165 | }, | ||
166 | |||
167 | PeriodButtonSelected: { | ||
168 | color: "#e7e7e7", | ||
169 | backgroundColor: "rgba(255, 255, 255, 0.1)", | ||
170 | border: "1px solid rgba(255, 255, 255, .3)", | ||
171 | MozBorderRadius: "5px", | ||
172 | borderRadius: "5px", | ||
173 | margin: "1px", | ||
174 | outline: "none", | ||
175 | opacity: 1, | ||
176 | boxSizing: "border-box" | ||
177 | }, | ||
178 | |||
179 | PeriodInputField: { | ||
180 | color: "#e7e7e7", | ||
181 | background: "transparent", | ||
182 | border: "1px solid rgba(255, 255, 255, .15)", | ||
183 | outline: "none" | ||
184 | }, | ||
185 | |||
186 | DataSetSelector: { | ||
187 | color: "#e7e7e7", | ||
188 | selectedBackgroundColor: "rgba(255, 255, 255, .25)", | ||
189 | rollOverBackgroundColor: "rgba(255, 255, 255, .15)" | ||
190 | }, | ||
191 | |||
192 | DataSetCompareList: { | ||
193 | color: "#e7e7e7", | ||
194 | lineHeight: "100%", | ||
195 | boxSizing: "initial", | ||
196 | webkitBoxSizing: "initial", | ||
197 | border: "1px solid rgba(255, 255, 255, .15)" | ||
198 | }, | ||
199 | |||
200 | DataSetSelect: { | ||
201 | border: "1px solid rgba(255, 255, 255, .15)", | ||
202 | outline: "none" | ||
203 | } | ||
204 | |||
205 | }; |