diff --git a/vendor/assets/javascripts/html5jp_graphs/circle.js b/vendor/assets/javascripts/html5jp_graphs/circle.js
index 102b009..d8fd46c 100755
--- a/vendor/assets/javascripts/html5jp_graphs/circle.js
+++ b/vendor/assets/javascripts/html5jp_graphs/circle.js
@@ -1,4 +1,4 @@
-// Copyright 2007 futomi http://www.html5.jp/
+// Copyright 2007-2009 futomi http://www.html5.jp/
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
@@ -11,6 +11,8 @@
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
+//
+// circle.js v1.0.2
if( typeof html5jp == 'undefined' ) {
html5jp = new Object();
@@ -25,17 +27,19 @@ if( typeof html5jp.graph == 'undefined' ) {
html5jp.graph.circle = function (id) {
var elm = document.getElementById(id);
if(! elm) { return; }
- if(elm.nodeName != "CANVAS") { return; }
- if(elm.parentNode.nodeName != "DIV") { return; };
- this.canvas = elm;
+ if( ! elm.nodeName.match(/^CANVAS$/i) ) { return; }
+ if( ! elm.parentNode.nodeName.match(/^DIV$/i) ) { return; };
/* CANVAS要素 */
- if ( ! this.canvas ){ return; }
- if ( ! this.canvas.getContext ){ return; }
+ if ( ! elm.getContext ){ return; }
+ this.canvas = elm;
/* 2D コンテクストの生成 */
this.ctx = this.canvas.getContext('2d');
this.canvas.style.margin = "0";
this.canvas.parentNode.style.position = "relative";
this.canvas.parentNode.style.padding = "0";
+ /* CANVAS要素の親要素となるDIV要素の幅と高さをセット */
+ this.canvas.parentNode.style.width = this.canvas.width + "px";
+ this.canvas.parentNode.style.height = this.canvas.height + "px";
};
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
* 描画
@@ -130,7 +134,7 @@ html5jp.graph.circle.prototype.draw = function(items, inparams) {
var sum = 0;
for(var i=0; i 0) {
+ /* 円弧を描画 */
+ this.ctx.beginPath();
+ if(p >= 100) { // for excanvas
+ this.ctx.arc(cpos.x, cpos.y, cpos.r, 0, Math.PI*2, false);
+ } else {
+ this.ctx.moveTo(cpos.x,cpos.y);
+ this.ctx.lineTo(
+ cpos.x + cpos.r * Math.cos(startAngle),
+ cpos.y + cpos.r * Math.sin(startAngle)
+ );
+ this.ctx.arc(cpos.x, cpos.y, cpos.r, startAngle, endAngle, false);
}
- } else {
- if(params.caption == true) {
- div.appendChild( document.createTextNode(cap) );
- if(params.captionNum == true || params.captionRate == true) {
- div.appendChild( document.createElement('BR') );
- }
+ this.ctx.closePath();
+ /* 円グラフのグラデーションをセット */
+ var radgrad = this.ctx.createRadialGradient(cpos.x,cpos.y,0,cpos.x,cpos.y,cpos.r);
+ radgrad.addColorStop(0, "rgba(" + rgb + ",1)");
+ radgrad.addColorStop(0.7, "rgba(" + rgb + ",0.85)");
+ radgrad.addColorStop(1, "rgba(" + rgb + ",0.75)");
+ this.ctx.fillStyle = radgrad;
+ this.ctx.fill();
+ /* 円弧の枠線 */
+ if(params.border == true) {
+ this.ctx.stroke();
}
- if(params.captionRate == true) {
- div.appendChild( document.createTextNode( p + "%" ) );
+ /* キャプション */
+ var drate;
+ var fontSize;
+ if(r <= 0.03) {
+ drate = 1.1;
+ } else if(r <= 0.05) {
+ drate = 0.9;
+ } else if(r <= 0.1) {
+ drate = 0.8;
+ } else if(r <= 0.15) {
+ drate = 0.7;
+ } else {
+ drate = 0.6;
}
- if(params.captionNum == true) {
- var numCap = n;
- if(params.caption == true || params.captionRate == true) {
- numCap = "(" + numCap + ")";
+ var cp = {
+ x: cpos.x + (cpos.r * drate) * Math.cos( (startAngle + endAngle) / 2 ),
+ y: cpos.y + (cpos.r * drate) * Math.sin( (startAngle + endAngle) / 2 )
+ };
+ var div = document.createElement('DIV');
+ if(r <= 0.05) {
+ if(params.captionRate == true) {
+ div.appendChild( document.createTextNode( p + "%") );
+ }
+ } else {
+ if(params.caption == true) {
+ div.appendChild( document.createTextNode(cap) );
+ if(params.captionNum == true || params.captionRate == true) {
+ div.appendChild( document.createElement('BR') );
+ }
+ }
+ if(params.captionRate == true) {
+ div.appendChild( document.createTextNode( p + "%" ) );
+ }
+ if(params.captionNum == true) {
+ var numCap = n;
+ if(params.caption == true || params.captionRate == true) {
+ numCap = "(" + numCap + ")";
+ }
+ div.appendChild( document.createTextNode( numCap ) );
}
- div.appendChild( document.createTextNode( numCap ) );
}
- }
- div.style.position = 'absolute';
- div.style.textAlign = 'center';
- div.style.color = params.captionColor;
- div.style.fontSize = params.fontSize;
- div.style.fontFamily = params.fontFamily;
- div.style.margin = "0";
- div.style.padding = "0";
- div.style.visible = "hidden";
- if( params.textShadow == true ) {
- var dif = [ [ 0, 1], [ 0, -1], [ 1, 0], [ 1, 1], [ 1, -1], [-1, 0], [-1, 1], [-1, -1] ];
- for(var j=0; j<8; j++) {
- var s = div.cloneNode(true);
- this.canvas.parentNode.appendChild(s);
- s.style.color = "black";
- s.style.left = (parseFloat(cp.x - s.offsetWidth / 2 + dif[j][0])).toString() + "px";
- s.style.top = (cp.y - s.offsetHeight / 2 + dif[j][1]).toString() + "px";
+ div.style.position = 'absolute';
+ div.style.textAlign = 'center';
+ div.style.color = params.captionColor;
+ div.style.fontSize = params.fontSize;
+ div.style.fontFamily = params.fontFamily;
+ div.style.margin = "0";
+ div.style.padding = "0";
+ div.style.visible = "hidden";
+ if( params.textShadow == true ) {
+ var dif = [ [ 0, 1], [ 0, -1], [ 1, 0], [ 1, 1], [ 1, -1], [-1, 0], [-1, 1], [-1, -1] ];
+ for(var j=0; j<8; j++) {
+ var s = div.cloneNode(true);
+ this.canvas.parentNode.appendChild(s);
+ s.style.color = "black";
+ s.style.left = (parseFloat(cp.x - s.offsetWidth / 2 + dif[j][0])).toString() + "px";
+ s.style.top = (cp.y - s.offsetHeight / 2 + dif[j][1]).toString() + "px";
+ }
}
+ this.canvas.parentNode.appendChild(div);
+ div.style.left = (cp.x - div.offsetWidth / 2).toString() + "px";
+ div.style.top = (cp.y - div.offsetHeight / 2).toString() + "px";
}
- this.canvas.parentNode.appendChild(div);
- div.style.left = (cp.x - div.offsetWidth / 2).toString() + "px";
- div.style.top = (cp.y - div.offsetHeight / 2).toString() + "px";
/* 凡例 */
if(params.legend == true) {
/* 文字 */
diff --git a/vendor/assets/javascripts/html5jp_graphs/excanvas-compressed.js b/vendor/assets/javascripts/html5jp_graphs/excanvas-compressed.js
deleted file mode 100755
index 9d71658..0000000
--- a/vendor/assets/javascripts/html5jp_graphs/excanvas-compressed.js
+++ /dev/null
@@ -1,19 +0,0 @@
-if(!window.CanvasRenderingContext2D){(function(){var I=Math,i=I.round,L=I.sin,M=I.cos,m=10,A=m/2,Q={init:function(a){var b=a||document;if(/MSIE/.test(navigator.userAgent)&&!window.opera){var c=this;b.attachEvent("onreadystatechange",function(){c.r(b)})}},r:function(a){if(a.readyState=="complete"){if(!a.namespaces["s"]){a.namespaces.add("g_vml_","urn:schemas-microsoft-com:vml")}var b=a.createStyleSheet();b.cssText="canvas{display:inline-block;overflow:hidden;text-align:left;width:300px;height:150px}g_vml_\\:*{behavior:url(#default#VML)}";
-var c=a.getElementsByTagName("canvas");for(var d=0;d"){var d="/"+a.tagName,e;while((e=a.nextSibling)&&e.tagName!=d){e.removeNode()}if(e){e.removeNode()}}a.parentNode.replaceChild(c,a);return c},initElement:function(a){a=this.q(a);a.getContext=function(){if(this.l){return this.l}return this.l=new K(this)};a.attachEvent("onpropertychange",V);a.attachEvent("onresize",
-W);var b=a.attributes;if(b.width&&b.width.specified){a.style.width=b.width.nodeValue+"px"}else{a.width=a.clientWidth}if(b.height&&b.height.specified){a.style.height=b.height.nodeValue+"px"}else{a.height=a.clientHeight}return a}};function V(a){var b=a.srcElement;switch(a.propertyName){case "width":b.style.width=b.attributes.width.nodeValue+"px";b.getContext().clearRect();break;case "height":b.style.height=b.attributes.height.nodeValue+"px";b.getContext().clearRect();break}}function W(a){var b=a.srcElement;
-if(b.firstChild){b.firstChild.style.width=b.clientWidth+"px";b.firstChild.style.height=b.clientHeight+"px"}}Q.init();var R=[];for(var E=0;E<16;E++){for(var F=0;F<16;F++){R[E*16+F]=E.toString(16)+F.toString(16)}}function J(){return[[1,0,0],[0,1,0],[0,0,1]]}function G(a,b){var c=J();for(var d=0;d<3;d++){for(var e=0;e<3;e++){var g=0;for(var h=0;h<3;h++){g+=a[d][h]*b[h][e]}c[d][e]=g}}return c}function N(a,b){b.fillStyle=a.fillStyle;b.lineCap=a.lineCap;b.lineJoin=a.lineJoin;b.lineWidth=a.lineWidth;b.miterLimit=
-a.miterLimit;b.shadowBlur=a.shadowBlur;b.shadowColor=a.shadowColor;b.shadowOffsetX=a.shadowOffsetX;b.shadowOffsetY=a.shadowOffsetY;b.strokeStyle=a.strokeStyle;b.d=a.d;b.e=a.e}function O(a){var b,c=1;a=String(a);if(a.substring(0,3)=="rgb"){var d=a.indexOf("(",3),e=a.indexOf(")",d+1),g=a.substring(d+1,e).split(",");b="#";for(var h=0;h<3;h++){b+=R[Number(g[h])]}if(g.length==4&&a.substr(3,1)=="a"){c=g[3]}}else{b=a}return[b,c]}function S(a){switch(a){case "butt":return"flat";case "round":return"round";
-case "square":default:return"square"}}function K(a){this.a=J();this.m=[];this.k=[];this.c=[];this.strokeStyle="#000";this.fillStyle="#000";this.lineWidth=1;this.lineJoin="miter";this.lineCap="butt";this.miterLimit=m*1;this.globalAlpha=1;this.canvas=a;var b=a.ownerDocument.createElement("div");b.style.width=a.clientWidth+"px";b.style.height=a.clientHeight+"px";b.style.overflow="hidden";b.style.position="absolute";a.appendChild(b);this.j=b;this.d=1;this.e=1}var j=K.prototype;j.clearRect=function(){this.j.innerHTML=
-"";this.c=[]};j.beginPath=function(){this.c=[]};j.moveTo=function(a,b){this.c.push({type:"moveTo",x:a,y:b});this.f=a;this.g=b};j.lineTo=function(a,b){this.c.push({type:"lineTo",x:a,y:b});this.f=a;this.g=b};j.bezierCurveTo=function(a,b,c,d,e,g){this.c.push({type:"bezierCurveTo",cp1x:a,cp1y:b,cp2x:c,cp2y:d,x:e,y:g});this.f=e;this.g=g};j.quadraticCurveTo=function(a,b,c,d){var e=this.f+0.6666666666666666*(a-this.f),g=this.g+0.6666666666666666*(b-this.g),h=e+(c-this.f)/3,l=g+(d-this.g)/3;this.bezierCurveTo(e,
-g,h,l,c,d)};j.arc=function(a,b,c,d,e,g){c*=m;var h=g?"at":"wa",l=a+M(d)*c-A,n=b+L(d)*c-A,o=a+M(e)*c-A,f=b+L(e)*c-A;if(l==o&&!g){l+=0.125}this.c.push({type:h,x:a,y:b,radius:c,xStart:l,yStart:n,xEnd:o,yEnd:f})};j.rect=function(a,b,c,d){this.moveTo(a,b);this.lineTo(a+c,b);this.lineTo(a+c,b+d);this.lineTo(a,b+d);this.closePath()};j.strokeRect=function(a,b,c,d){this.beginPath();this.moveTo(a,b);this.lineTo(a+c,b);this.lineTo(a+c,b+d);this.lineTo(a,b+d);this.closePath();this.stroke()};j.fillRect=function(a,
-b,c,d){this.beginPath();this.moveTo(a,b);this.lineTo(a+c,b);this.lineTo(a+c,b+d);this.lineTo(a,b+d);this.closePath();this.fill()};j.createLinearGradient=function(a,b,c,d){var e=new H("gradient");return e};j.createRadialGradient=function(a,b,c,d,e,g){var h=new H("gradientradial");h.n=c;h.o=g;h.i.x=a;h.i.y=b;return h};j.drawImage=function(a,b){var c,d,e,g,h,l,n,o,f=a.runtimeStyle.width,k=a.runtimeStyle.height;a.runtimeStyle.width="auto";a.runtimeStyle.height="auto";var q=a.width,r=a.height;a.runtimeStyle.width=
-f;a.runtimeStyle.height=k;if(arguments.length==3){c=arguments[1];d=arguments[2];h=(l=0);n=(e=q);o=(g=r)}else if(arguments.length==5){c=arguments[1];d=arguments[2];e=arguments[3];g=arguments[4];h=(l=0);n=q;o=r}else if(arguments.length==9){h=arguments[1];l=arguments[2];n=arguments[3];o=arguments[4];c=arguments[5];d=arguments[6];e=arguments[7];g=arguments[8]}else{throw"Invalid number of arguments";}var s=this.b(c,d),t=[],v=10,w=10;t.push(" ','","");this.j.insertAdjacentHTML("BeforeEnd",t.join(""))};j.stroke=function(a){var b=[],c=O(a?this.fillStyle:this.strokeStyle),d=c[0],e=c[1]*this.globalAlpha,g=10,h=10;b.push("n.x){n.x=k.x}if(l.y==
-null||k.yn.y){n.y=k.y}}}b.push(' ">');if(typeof this.fillStyle=="object"){var v={x:"50%",y:"50%"},w=n.x-l.x,x=n.y-l.y,p=w>x?w:x;v.x=i(this.fillStyle.i.x/w*100+50)+"%";v.y=i(this.fillStyle.i.y/x*100+50)+"%";var y=[];if(this.fillStyle.p=="gradientradial"){var z=this.fillStyle.n/p*100,B=this.fillStyle.o/p*100-z}else{var z=0,B=100}var C={offset:null,color:null},D={offset:null,color:null};this.fillStyle.h.sort(function(T,U){return T.offset-U.offset});for(var o=0;oC.offset||C.offset==null){C.offset=u.offset;C.color=u.color}if(u.offset')}else if(a){b.push('')}else{b.push("')}b.push("");this.j.insertAdjacentHTML("beforeEnd",b.join(""));this.c=[]};j.fill=function(){this.stroke(true)};j.closePath=function(){this.c.push({type:"close"})};j.b=function(a,b){return{x:m*(a*this.a[0][0]+b*this.a[1][0]+this.a[2][0])-A,y:m*(a*this.a[0][1]+b*this.a[1][1]+this.a[2][1])-A}};j.save=function(){var a={};N(this,a);
-this.k.push(a);this.m.push(this.a);this.a=G(J(),this.a)};j.restore=function(){N(this.k.pop(),this);this.a=this.m.pop()};j.translate=function(a,b){var c=[[1,0,0],[0,1,0],[a,b,1]];this.a=G(c,this.a)};j.rotate=function(a){var b=M(a),c=L(a),d=[[b,c,0],[-c,b,0],[0,0,1]];this.a=G(d,this.a)};j.scale=function(a,b){this.d*=a;this.e*=b;var c=[[a,0,0],[0,b,0],[0,0,1]];this.a=G(c,this.a)};j.clip=function(){};j.arcTo=function(){};j.createPattern=function(){return new P};function H(a){this.p=a;this.n=0;this.o=
-0;this.h=[];this.i={x:0,y:0}}H.prototype.addColorStop=function(a,b){b=O(b);this.h.push({offset:1-a,color:b})};function P(){}G_vmlCanvasManager=Q;CanvasRenderingContext2D=K;CanvasGradient=H;CanvasPattern=P})()};
diff --git a/vendor/assets/javascripts/html5jp_graphs/excanvas.js b/vendor/assets/javascripts/html5jp_graphs/excanvas.js
index 3e1aedf..367764b 100755
--- a/vendor/assets/javascripts/html5jp_graphs/excanvas.js
+++ b/vendor/assets/javascripts/html5jp_graphs/excanvas.js
@@ -28,80 +28,101 @@
// (http://www.whatwg.org/specs/web-apps/current-work/#the-doctype)
// or use Box Sizing Behavior from WebFX
// (http://webfx.eae.net/dhtml/boxsizing/boxsizing.html)
+// * Non uniform scaling does not correctly scale strokes.
// * Optimize. There is always room for speed improvements.
-// only add this code if we do not already have a canvas implementation
-if (!window.CanvasRenderingContext2D) {
+// Only add this code if we do not already have a canvas implementation
+if (!document.createElement('canvas').getContext) {
-(function () {
+(function() {
// alias some functions to make (compiled) code shorter
var m = Math;
var mr = m.round;
var ms = m.sin;
var mc = m.cos;
+ var abs = m.abs;
+ var sqrt = m.sqrt;
// this is used for sub pixel precision
var Z = 10;
var Z2 = Z / 2;
+ /**
+ * This funtion is assigned to the