Compare View
Commits (2)
-
Signed-off-by: tom200e <tom200e@hotmail.com>
Showing
200 changed files
Show diff stats
Too many changes.
To preserve performance only 100 of 200 files displayed.
amcharts/amcharts.js
... | ... | @@ -0,0 +1,376 @@ |
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}; | |
0 | 377 | \ No newline at end of file | ... | ... |
amcharts/exporting/amexport.js
... | ... | @@ -0,0 +1,793 @@ |
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 | +}); | |
0 | 794 | \ No newline at end of file | ... | ... |
amcharts/exporting/canvg.js
... | ... | @@ -0,0 +1,2842 @@ |
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 | +} | |
0 | 2843 | \ No newline at end of file | ... | ... |
amcharts/exporting/filesaver.js
... | ... | @@ -0,0 +1,233 @@ |
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 | |
0 | 234 | \ No newline at end of file | ... | ... |
amcharts/exporting/jspdf.js
... | ... | @@ -0,0 +1,1943 @@ |
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 | +}()); | |
0 | 1944 | \ No newline at end of file | ... | ... |
amcharts/exporting/jspdf.plugin.addimage.js
... | ... | @@ -0,0 +1,230 @@ |
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) | |
0 | 231 | \ No newline at end of file | ... | ... |
amcharts/exporting/rgbcolor.js
... | ... | @@ -0,0 +1,288 @@ |
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 | + | ... | ... |
amcharts/funnel.js
... | ... | @@ -0,0 +1,8 @@ |
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()}}); | |
0 | 9 | \ No newline at end of file | ... | ... |
amcharts/gauge.js
... | ... | @@ -0,0 +1,19 @@ |
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)}}}); | |
0 | 20 | \ No newline at end of file | ... | ... |
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
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/bg.js
... | ... | @@ -0,0 +1 @@ |
1 | +AmCharts.translations.bg = {"monthNames":["Януари","Февруари","Март","Април","Май","Юни","Юли","Август","Септември","Октомври","Ноември","Декември"],"shortMonthNames":["Яну","Фев","Мар","Апр","Май","Юни","Юли","Авг","Сеп","Окт","Ное","Дек"],"dayNames":["Понеделник","Вторник","Сряда","Четвъртък","Петък","Събота","Неделя"],"shortDayNames":["Пн","Вт","Ср","Чт","Пт","Сб","Нд"],"zoomOutText":"Покажи всички"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/de.js
... | ... | @@ -0,0 +1,13 @@ |
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 | +} | |
0 | 14 | \ No newline at end of file | ... | ... |
amcharts/lang/es.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/fi.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/fo.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/fr.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/hr.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/hu.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/id.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/is.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/it.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/lt.js
... | ... | @@ -0,0 +1 @@ |
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ą"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/lv.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/mk.js
... | ... | @@ -0,0 +1 @@ |
1 | +AmCharts.translations.mk = {"monthNames":["Јануари","Февруари","Март","Април","Мај","Јуни","Јули","Август","Септември","Октомври","Ноември","Декември"],"shortMonthNames":["Јан","Фев","Мар","Апр","Мај","Јун","Јул","Авг","Сеп","Окт","Ное","Дек"],"dayNames":["Понеделник","Вторник","Среда","Четврток","Петок","Сабота","Недела"],"shortDayNames":["Пон","Вто","Сре","Чет","Пет","Саб","Нед"],"zoomOutText":"Прикажи ги сите"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/mn.js
... | ... | @@ -0,0 +1 @@ |
1 | +AmCharts.translations.mn = {"monthNames":["Хулгана сарын","Үхэр сарын","Бар сарын","Туулай сарын","Луу сарын","Могой сарын","Морь сарын","Хонь сарын","Бич сарын","Тахиа сарын","Нохой сарын","Гахай сарын"],"shortMonthNames":["Хул","Үхэ","Бар","Туу","Луу","Мог","Мор","Хон","Бич","Тах","Нох","Гах"],"dayNames":["Даваа","Мягмар","Лхагва","Пүрэв","Баасан","Бямба","Ням"],"shortDayNames":["Да","Мя","Лх","Пү","Ба","Бя","Ня"],"zoomOutText":"Бүх харуулах"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/mt.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/nl.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/no.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/pl.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/pt.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/ro.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/ru.js
... | ... | @@ -0,0 +1 @@ |
1 | +AmCharts.translations.ru = {"monthNames":["Январь","Февраль","Март","Апрель","Май","Июнь","Июль","Август","Сентябрь","Октябрь","Ноябрь","Декабрь"],"shortMonthNames":["Янв","Фев","Мар","Апр","Май","Июн","Июл","Авг","Сен","Окт","Ноя","Дек"],"dayNames":["Понедельник","Вторник","Среда","Четверг","Пятница","Суббота","Воскресенье"],"shortDayNames":["Пнд","Втр","Срд","Чтв","Птн","Сбт","Вск"],"zoomOutText":"Показать все"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/rw.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/sk.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/so.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/th.js
... | ... | @@ -0,0 +1 @@ |
1 | +AmCharts.translations.th = {"monthNames":["มกราคม","กุมภาพันธ์","มีนาคม","เมษายน","พฤษภาคม","มิถุนายน","กรกฎาคม","สิงหาคม","กันยายน","ตุลาคม","พฤศจิกายน","ธันวาคม"],"shortMonthNames":["ม.ค.","ก.พ.","มี.ค.","เม.ย.","พ.ค.","มิ.ย.","ก.ค.","ส.ค.","ก.ย.","ต.ค.","พ.ย.","ธ.ค."],"dayNames":["จันทร์","อังคาร","พุธ","พฤหัสบดี","ศุกร์","เสาร์","อาทิตย์"],"shortDayNames":["จ.","อ.","พ.","พฤ.","ศ.","ส.","อา."],"zoomOutText":"แสดงทั้งหมด"} | |
0 | 2 | \ No newline at end of file | ... | ... |
amcharts/lang/tr.js
... | ... | @@ -0,0 +1 @@ |
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"} | |
0 | 2 | \ No newline at end of file | ... | ... |
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
... | ... | @@ -0,0 +1,10 @@ |
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}}); | |
0 | 11 | \ No newline at end of file | ... | ... |
amcharts/radar.js
... | ... | @@ -0,0 +1,10 @@ |
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(){}}); | |
0 | 11 | \ No newline at end of file | ... | ... |
amcharts/serial.js
... | ... | @@ -0,0 +1,53 @@ |
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)}}); | |
0 | 54 | \ No newline at end of file | ... | ... |
amcharts/themes/black.js
... | ... | @@ -0,0 +1,206 @@ |
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 | +}; | |
0 | 207 | \ No newline at end of file | ... | ... |
amcharts/themes/chalk.js
... | ... | @@ -0,0 +1,217 @@ |
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 | +}; | |
0 | 218 | \ No newline at end of file | ... | ... |
amcharts/themes/dark.js
... | ... | @@ -0,0 +1,205 @@ |
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 | +}; | |
0 | 206 | \ No newline at end of file | ... | ... |