2011-11-16 03:25:02 +04:00
|
|
|
|
/*
|
|
|
|
|
html2canvas @VERSION@ <http://html2canvas.hertzen.com>
|
|
|
|
|
Copyright (c) 2011 Niklas von Hertzen. All rights reserved.
|
|
|
|
|
http://www.twitter.com/niklasvh
|
2012-03-07 01:41:22 +04:00
|
|
|
|
|
|
|
|
|
Contributor(s):
|
|
|
|
|
Niklas von Hertzen <http://www.twitter.com/niklasvh>
|
|
|
|
|
André Fiedler <http://www.twitter.com/sonnenkiste>
|
2011-11-16 03:25:02 +04:00
|
|
|
|
|
|
|
|
|
Released under MIT License
|
2012-03-03 21:18:39 +04:00
|
|
|
|
*/
|
2011-11-16 03:25:02 +04:00
|
|
|
|
|
2012-03-05 23:20:44 +04:00
|
|
|
|
(function(){
|
|
|
|
|
|
2012-03-02 20:05:03 +04:00
|
|
|
|
_html2canvas.Generate = {};
|
2011-09-13 00:50:43 +04:00
|
|
|
|
|
2012-03-05 23:20:44 +04:00
|
|
|
|
var reGradients = [
|
2012-03-07 01:36:29 +04:00
|
|
|
|
/^(-webkit-linear-gradient)\(([a-z\s]+)([\w\d\.\s,%\(\)]+)\)$/,
|
|
|
|
|
/^(-o-linear-gradient)\(([a-z\s]+)([\w\d\.\s,%\(\)]+)\)$/,
|
|
|
|
|
/^(-webkit-gradient)\((linear|radial),\s((?:\d{1,3}%?)\s(?:\d{1,3}%?),\s(?:\d{1,3}%?)\s(?:\d{1,3}%?))([\w\d\.\s,%\(\)-]+)\)$/,
|
2012-03-10 02:20:34 +04:00
|
|
|
|
/^(-moz-linear-gradient)\(((?:\d{1,3}%?)\s(?:\d{1,3}%?))([\w\d\.\s,%\(\)]+)\)$/,
|
2012-03-10 03:09:16 +04:00
|
|
|
|
/^(-webkit-radial-gradient)\(((?:\d{1,3}%?)\s(?:\d{1,3}%?)),\s(\w+)\s([a-z-]+)([\w\d\.\s,%\(\)]+)\)$/,
|
|
|
|
|
/^(-moz-radial-gradient)\(((?:\d{1,3}%?)\s(?:\d{1,3}%?)),\s(\w+)\s?([a-z-]*)([\w\d\.\s,%\(\)]+)\)$/,
|
|
|
|
|
/^(-o-radial-gradient)\(((?:\d{1,3}%?)\s(?:\d{1,3}%?)),\s(\w+)\s([a-z-]+)([\w\d\.\s,%\(\)]+)\)$/
|
2012-03-05 23:20:44 +04:00
|
|
|
|
];
|
|
|
|
|
|
2012-03-07 01:45:38 +04:00
|
|
|
|
/*
|
|
|
|
|
* TODO: Add IE10 vendor prefix (-ms) support
|
2012-03-07 01:50:09 +04:00
|
|
|
|
* TODO: Add W3C gradient (linear-gradient) support
|
2012-03-10 18:28:09 +04:00
|
|
|
|
* TODO: Add old Webkit -webkit-gradient(radial, ...) support (new Chrome doesn´t support old syntax?!)
|
2012-03-07 01:45:38 +04:00
|
|
|
|
* TODO: Maybe some RegExp optimizations are possible ;o)
|
|
|
|
|
*/
|
2012-03-06 02:21:28 +04:00
|
|
|
|
_html2canvas.Generate.parseGradient = function(css, bounds) {
|
2012-03-05 23:20:44 +04:00
|
|
|
|
var gradient, i, len = reGradients.length, m1, stop, m2, m2Len, step, m3;
|
|
|
|
|
|
|
|
|
|
for(i = 0; i < len; i+=1){
|
|
|
|
|
m1 = css.match(reGradients[i]);
|
|
|
|
|
if(m1) break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if(m1) {
|
|
|
|
|
switch(m1[1]) {
|
|
|
|
|
case '-webkit-linear-gradient':
|
2012-03-07 01:26:43 +04:00
|
|
|
|
case '-o-linear-gradient':
|
2012-03-05 23:20:44 +04:00
|
|
|
|
|
|
|
|
|
gradient = {
|
2012-03-06 01:04:25 +04:00
|
|
|
|
type: 'linear',
|
2012-03-07 22:20:09 +04:00
|
|
|
|
x0: null,
|
|
|
|
|
y0: null,
|
|
|
|
|
x1: null,
|
|
|
|
|
y1: null,
|
2012-03-06 01:04:25 +04:00
|
|
|
|
colorStops: []
|
2012-03-05 23:20:44 +04:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// get coordinates
|
|
|
|
|
m2 = m1[2].match(/\w+/g);
|
|
|
|
|
if(m2){
|
|
|
|
|
m2Len = m2.length;
|
|
|
|
|
for(i = 0; i < m2Len; i+=1){
|
|
|
|
|
switch(m2[i]) {
|
|
|
|
|
case 'top':
|
2012-03-07 22:20:09 +04:00
|
|
|
|
gradient.y0 = 0;
|
2012-03-05 23:20:44 +04:00
|
|
|
|
gradient.y1 = bounds.height;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 'right':
|
|
|
|
|
gradient.x0 = bounds.width;
|
2012-03-07 22:20:09 +04:00
|
|
|
|
gradient.x1 = 0;
|
2012-03-05 23:20:44 +04:00
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 'bottom':
|
|
|
|
|
gradient.y0 = bounds.height;
|
2012-03-07 22:20:09 +04:00
|
|
|
|
gradient.y1 = 0;
|
2012-03-05 23:20:44 +04:00
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case 'left':
|
2012-03-07 22:20:09 +04:00
|
|
|
|
gradient.x0 = 0;
|
2012-03-05 23:20:44 +04:00
|
|
|
|
gradient.x1 = bounds.width;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2012-03-07 22:20:09 +04:00
|
|
|
|
if(gradient.x0 === null && gradient.x1 === null){ // center
|
|
|
|
|
gradient.x0 = gradient.x1 = bounds.width / 2;
|
|
|
|
|
}
|
|
|
|
|
if(gradient.y0 === null && gradient.y1 === null){ // center
|
|
|
|
|
gradient.y0 = gradient.y1 = bounds.height / 2;
|
|
|
|
|
}
|
2012-03-05 23:20:44 +04:00
|
|
|
|
|
|
|
|
|
// get colors and stops
|
2012-03-07 01:26:43 +04:00
|
|
|
|
m2 = m1[3].match(/((?:rgb|rgba)\(\d{1,3},\s\d{1,3},\s\d{1,3}(?:,\s[0-9\.]+)?\)(?:\s\d{1,3}(?:%|px))?)+/g);
|
2012-03-05 23:20:44 +04:00
|
|
|
|
if(m2){
|
|
|
|
|
m2Len = m2.length;
|
|
|
|
|
step = 1 / Math.max(m2Len - 1, 1);
|
|
|
|
|
for(i = 0; i < m2Len; i+=1){
|
2012-03-07 01:26:43 +04:00
|
|
|
|
m3 = m2[i].match(/((?:rgb|rgba)\(\d{1,3},\s\d{1,3},\s\d{1,3}(?:,\s[0-9\.]+)?\))\s*(\d{1,3})?(%|px)?/);
|
2012-03-05 23:20:44 +04:00
|
|
|
|
if(m3[2]){
|
|
|
|
|
stop = parseFloat(m3[2]);
|
2012-03-07 01:26:43 +04:00
|
|
|
|
if(m3[3] === '%'){
|
2012-03-05 23:20:44 +04:00
|
|
|
|
stop /= 100;
|
2012-03-07 01:26:43 +04:00
|
|
|
|
} else { // px - stupid opera
|
|
|
|
|
stop /= bounds.width;
|
2012-03-05 23:20:44 +04:00
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
stop = i * step;
|
|
|
|
|
}
|
|
|
|
|
gradient.colorStops.push({
|
|
|
|
|
color: m3[1],
|
|
|
|
|
stop: stop
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case '-webkit-gradient':
|
2012-03-06 03:03:36 +04:00
|
|
|
|
|
|
|
|
|
gradient = {
|
|
|
|
|
type: m1[2],
|
|
|
|
|
x0: 0,
|
|
|
|
|
y0: 0,
|
|
|
|
|
x1: 0,
|
|
|
|
|
y1: 0,
|
|
|
|
|
colorStops: []
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// get coordinates
|
|
|
|
|
m2 = m1[3].match(/(\d{1,3})%?\s(\d{1,3})%?,\s(\d{1,3})%?\s(\d{1,3})%?/);
|
|
|
|
|
if(m2){
|
|
|
|
|
gradient.x0 = (m2[1] * bounds.width) / 100;
|
|
|
|
|
gradient.y0 = (m2[2] * bounds.height) / 100;
|
|
|
|
|
gradient.x1 = (m2[3] * bounds.width) / 100;
|
|
|
|
|
gradient.y1 = (m2[4] * bounds.height) / 100;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// get colors and stops
|
|
|
|
|
m2 = m1[4].match(/((?:from|to|color-stop)\((?:[0-9\.]+,\s)?(?:rgb|rgba)\(\d{1,3},\s\d{1,3},\s\d{1,3}(?:,\s[0-9\.]+)?\)\))+/g);
|
|
|
|
|
if(m2){
|
|
|
|
|
m2Len = m2.length;
|
|
|
|
|
for(i = 0; i < m2Len; i+=1){
|
|
|
|
|
m3 = m2[i].match(/(from|to|color-stop)\(([0-9\.]+)?(?:,\s)?((?:rgb|rgba)\(\d{1,3},\s\d{1,3},\s\d{1,3}(?:,\s[0-9\.]+)?\))\)/);
|
|
|
|
|
stop = parseFloat(m3[2]);
|
|
|
|
|
if(m3[1] === 'from') stop = 0.0;
|
|
|
|
|
if(m3[1] === 'to') stop = 1.0;
|
|
|
|
|
gradient.colorStops.push({
|
|
|
|
|
color: m3[3],
|
|
|
|
|
stop: stop
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
2012-03-05 23:20:44 +04:00
|
|
|
|
break;
|
2012-03-07 01:11:01 +04:00
|
|
|
|
|
|
|
|
|
case '-moz-linear-gradient':
|
|
|
|
|
|
|
|
|
|
gradient = {
|
|
|
|
|
type: 'linear',
|
|
|
|
|
x0: 0,
|
|
|
|
|
y0: 0,
|
|
|
|
|
x1: 0,
|
|
|
|
|
y1: 0,
|
|
|
|
|
colorStops: []
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// get coordinates
|
|
|
|
|
m2 = m1[2].match(/(\d{1,3})%?\s(\d{1,3})%?/);
|
|
|
|
|
|
|
|
|
|
// m2[1] == 0% -> left
|
|
|
|
|
// m2[1] == 50% -> center
|
|
|
|
|
// m2[1] == 100% -> right
|
|
|
|
|
|
|
|
|
|
// m2[2] == 0% -> top
|
|
|
|
|
// m2[2] == 50% -> center
|
|
|
|
|
// m2[2] == 100% -> bottom
|
|
|
|
|
|
|
|
|
|
if(m2){
|
|
|
|
|
gradient.x0 = (m2[1] * bounds.width) / 100;
|
|
|
|
|
gradient.y0 = (m2[2] * bounds.height) / 100;
|
|
|
|
|
gradient.x1 = bounds.width - gradient.x0;
|
|
|
|
|
gradient.y1 = bounds.height - gradient.y0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// get colors and stops
|
|
|
|
|
m2 = m1[3].match(/((?:rgb|rgba)\(\d{1,3},\s\d{1,3},\s\d{1,3}(?:,\s[0-9\.]+)?\)(?:\s\d{1,3}%)?)+/g);
|
|
|
|
|
if(m2){
|
|
|
|
|
m2Len = m2.length;
|
|
|
|
|
step = 1 / Math.max(m2Len - 1, 1);
|
|
|
|
|
for(i = 0; i < m2Len; i+=1){
|
|
|
|
|
m3 = m2[i].match(/((?:rgb|rgba)\(\d{1,3},\s\d{1,3},\s\d{1,3}(?:,\s[0-9\.]+)?\))\s*(\d{1,3})?(%)?/);
|
|
|
|
|
if(m3[2]){
|
|
|
|
|
stop = parseFloat(m3[2]);
|
|
|
|
|
if(m3[3]){ // percentage
|
|
|
|
|
stop /= 100;
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
stop = i * step;
|
|
|
|
|
}
|
|
|
|
|
gradient.colorStops.push({
|
|
|
|
|
color: m3[1],
|
|
|
|
|
stop: stop
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
break;
|
2012-03-10 02:20:34 +04:00
|
|
|
|
|
|
|
|
|
case '-webkit-radial-gradient':
|
2012-03-10 02:58:32 +04:00
|
|
|
|
case '-moz-radial-gradient':
|
2012-03-10 03:05:42 +04:00
|
|
|
|
case '-o-radial-gradient':
|
2012-03-10 02:20:34 +04:00
|
|
|
|
|
|
|
|
|
gradient = {
|
2012-03-10 19:31:16 +04:00
|
|
|
|
type: 'circle',
|
2012-03-10 02:20:34 +04:00
|
|
|
|
x0: 0,
|
|
|
|
|
y0: 0,
|
|
|
|
|
x1: bounds.width,
|
|
|
|
|
y1: bounds.height,
|
|
|
|
|
cx: 0,
|
|
|
|
|
cy: 0,
|
|
|
|
|
rx: 0,
|
|
|
|
|
ry: 0,
|
|
|
|
|
colorStops: []
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// center
|
|
|
|
|
m2 = m1[2].match(/(\d{1,3})%?\s(\d{1,3})%?/);
|
|
|
|
|
if(m2){
|
|
|
|
|
gradient.cx = (m2[1] * bounds.width) / 100;
|
|
|
|
|
gradient.cy = (m2[2] * bounds.height) / 100;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// size
|
2012-03-10 03:09:16 +04:00
|
|
|
|
m2 = m1[3].match(/\w+/);
|
2012-03-10 02:58:32 +04:00
|
|
|
|
m3 = m1[4].match(/[a-z-]*/);
|
2012-03-10 02:20:34 +04:00
|
|
|
|
if(m2 && m3){
|
|
|
|
|
switch(m3[0]){
|
|
|
|
|
case 'farthest-corner':
|
|
|
|
|
case 'cover': // is equivalent to farthest-corner
|
2012-03-10 02:58:32 +04:00
|
|
|
|
case '': // mozilla removes "cover" from definition :(
|
2012-03-10 02:20:34 +04:00
|
|
|
|
var tl = Math.sqrt(Math.pow(gradient.cx, 2) + Math.pow(gradient.cy, 2));
|
|
|
|
|
var tr = Math.sqrt(Math.pow(gradient.cx, 2) + Math.pow(gradient.y1 - gradient.cy, 2));
|
|
|
|
|
var br = Math.sqrt(Math.pow(gradient.x1 - gradient.cx, 2) + Math.pow(gradient.y1 - gradient.cy, 2));
|
|
|
|
|
var bl = Math.sqrt(Math.pow(gradient.x1 - gradient.cx, 2) + Math.pow(gradient.cy, 2));
|
|
|
|
|
gradient.rx = gradient.ry = Math.max(tl, tr, br, bl);
|
|
|
|
|
break;
|
|
|
|
|
case 'closest-corner':
|
|
|
|
|
var tl = Math.sqrt(Math.pow(gradient.cx, 2) + Math.pow(gradient.cy, 2));
|
|
|
|
|
var tr = Math.sqrt(Math.pow(gradient.cx, 2) + Math.pow(gradient.y1 - gradient.cy, 2));
|
|
|
|
|
var br = Math.sqrt(Math.pow(gradient.x1 - gradient.cx, 2) + Math.pow(gradient.y1 - gradient.cy, 2));
|
|
|
|
|
var bl = Math.sqrt(Math.pow(gradient.x1 - gradient.cx, 2) + Math.pow(gradient.cy, 2));
|
|
|
|
|
gradient.rx = gradient.ry = Math.min(tl, tr, br, bl);
|
|
|
|
|
break;
|
|
|
|
|
case 'farthest-side':
|
2012-03-10 03:23:17 +04:00
|
|
|
|
if(m2[0] === 'circle'){
|
2012-03-10 02:20:34 +04:00
|
|
|
|
gradient.rx = gradient.ry = Math.max(
|
|
|
|
|
gradient.cx,
|
|
|
|
|
gradient.cy,
|
|
|
|
|
gradient.x1 - gradient.cx,
|
|
|
|
|
gradient.y1 - gradient.cy
|
|
|
|
|
);
|
|
|
|
|
} else { // ellipse
|
|
|
|
|
|
2012-03-10 19:31:16 +04:00
|
|
|
|
gradient.type = m2[0];
|
2012-03-10 02:20:34 +04:00
|
|
|
|
|
|
|
|
|
gradient.rx = Math.max(
|
|
|
|
|
gradient.cx,
|
|
|
|
|
gradient.x1 - gradient.cx
|
|
|
|
|
);
|
|
|
|
|
gradient.ry = Math.max(
|
|
|
|
|
gradient.cy,
|
|
|
|
|
gradient.y1 - gradient.cy
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case 'closest-side':
|
|
|
|
|
case 'contain': // is equivalent to closest-side
|
2012-03-10 03:23:17 +04:00
|
|
|
|
if(m2[0] === 'circle'){
|
2012-03-10 02:20:34 +04:00
|
|
|
|
gradient.rx = gradient.ry = Math.min(
|
|
|
|
|
gradient.cx,
|
|
|
|
|
gradient.cy,
|
|
|
|
|
gradient.x1 - gradient.cx,
|
|
|
|
|
gradient.y1 - gradient.cy
|
|
|
|
|
);
|
|
|
|
|
} else { // ellipse
|
|
|
|
|
|
2012-03-10 19:31:16 +04:00
|
|
|
|
gradient.type = m2[0];
|
2012-03-10 02:20:34 +04:00
|
|
|
|
|
|
|
|
|
gradient.rx = Math.min(
|
|
|
|
|
gradient.cx,
|
|
|
|
|
gradient.x1 - gradient.cx
|
|
|
|
|
);
|
|
|
|
|
gradient.ry = Math.min(
|
|
|
|
|
gradient.cy,
|
|
|
|
|
gradient.y1 - gradient.cy
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
// TODO: add support for "30px 40px" sizes (webkit only)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// color stops
|
2012-03-10 03:05:42 +04:00
|
|
|
|
m2 = m1[5].match(/((?:rgb|rgba)\(\d{1,3},\s\d{1,3},\s\d{1,3}(?:,\s[0-9\.]+)?\)(?:\s\d{1,3}(?:%|px))?)+/g);
|
2012-03-10 02:20:34 +04:00
|
|
|
|
if(m2){
|
|
|
|
|
m2Len = m2.length;
|
|
|
|
|
step = 1 / Math.max(m2Len - 1, 1);
|
|
|
|
|
for(i = 0; i < m2Len; i+=1){
|
2012-03-10 03:05:42 +04:00
|
|
|
|
m3 = m2[i].match(/((?:rgb|rgba)\(\d{1,3},\s\d{1,3},\s\d{1,3}(?:,\s[0-9\.]+)?\))\s*(\d{1,3})?(%|px)?/);
|
2012-03-10 02:20:34 +04:00
|
|
|
|
if(m3[2]){
|
|
|
|
|
stop = parseFloat(m3[2]);
|
2012-03-10 03:05:42 +04:00
|
|
|
|
if(m3[3] === '%'){
|
2012-03-10 02:20:34 +04:00
|
|
|
|
stop /= 100;
|
2012-03-10 03:05:42 +04:00
|
|
|
|
} else { // px - stupid opera
|
|
|
|
|
stop /= bounds.width;
|
2012-03-10 02:20:34 +04:00
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
stop = i * step;
|
|
|
|
|
}
|
|
|
|
|
gradient.colorStops.push({
|
|
|
|
|
color: m3[1],
|
|
|
|
|
stop: stop
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
break;
|
2012-03-05 23:20:44 +04:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return gradient;
|
|
|
|
|
};
|
2011-09-13 18:09:33 +04:00
|
|
|
|
|
2012-03-02 20:05:03 +04:00
|
|
|
|
_html2canvas.Generate.Gradient = function(src, bounds) {
|
2011-09-13 00:50:43 +04:00
|
|
|
|
var canvas = document.createElement('canvas'),
|
|
|
|
|
ctx = canvas.getContext('2d'),
|
2012-03-10 02:20:34 +04:00
|
|
|
|
gradient, grad, i, len, img;
|
2011-09-13 00:50:43 +04:00
|
|
|
|
|
|
|
|
|
canvas.width = bounds.width;
|
|
|
|
|
canvas.height = bounds.height;
|
|
|
|
|
|
2012-03-10 03:11:01 +04:00
|
|
|
|
// TODO: add support for multi defined background gradients (like radial gradient example in background.html)
|
2012-03-06 02:21:28 +04:00
|
|
|
|
gradient = _html2canvas.Generate.parseGradient(src, bounds);
|
2012-03-03 21:18:39 +04:00
|
|
|
|
|
2012-03-05 23:20:44 +04:00
|
|
|
|
img = new Image();
|
|
|
|
|
|
2012-03-10 19:31:16 +04:00
|
|
|
|
if(gradient){
|
|
|
|
|
if(gradient.type === 'linear'){
|
|
|
|
|
grad = ctx.createLinearGradient(gradient.x0, gradient.y0, gradient.x1, gradient.y1);
|
|
|
|
|
|
|
|
|
|
for (i = 0, len = gradient.colorStops.length; i < len; i+=1) {
|
|
|
|
|
try {
|
|
|
|
|
grad.addColorStop(gradient.colorStops[i].stop, gradient.colorStops[i].color);
|
|
|
|
|
}
|
|
|
|
|
catch(e) {
|
|
|
|
|
h2clog(['failed to add color stop: ', e, '; tried to add: ', gradient.colorStops[i], '; stop: ', i, '; in: ', src]);
|
|
|
|
|
}
|
2011-09-13 00:50:43 +04:00
|
|
|
|
}
|
2012-03-10 19:31:16 +04:00
|
|
|
|
|
|
|
|
|
ctx.fillStyle = grad;
|
|
|
|
|
ctx.fillRect(0, 0, bounds.width, bounds.height);
|
2011-09-13 00:50:43 +04:00
|
|
|
|
|
2012-03-10 19:31:16 +04:00
|
|
|
|
img.src = canvas.toDataURL();
|
|
|
|
|
} else if(gradient.type === 'circle'){
|
|
|
|
|
|
|
|
|
|
grad = ctx.createRadialGradient(gradient.cx, gradient.cy, 0, gradient.cx, gradient.cy, gradient.rx);
|
|
|
|
|
|
|
|
|
|
for (i = 0, len = gradient.colorStops.length; i < len; i+=1) {
|
|
|
|
|
try {
|
|
|
|
|
grad.addColorStop(gradient.colorStops[i].stop, gradient.colorStops[i].color);
|
|
|
|
|
}
|
|
|
|
|
catch(e) {
|
|
|
|
|
h2clog(['failed to add color stop: ', e, '; tried to add: ', gradient.colorStops[i], '; stop: ', i, '; in: ', src]);
|
|
|
|
|
}
|
2012-03-10 02:20:34 +04:00
|
|
|
|
}
|
2012-03-10 19:31:16 +04:00
|
|
|
|
|
|
|
|
|
ctx.fillStyle = grad;
|
|
|
|
|
ctx.fillRect(0, 0, bounds.width, bounds.height);
|
|
|
|
|
|
|
|
|
|
img.src = canvas.toDataURL();
|
|
|
|
|
} else if(gradient.type === 'ellipse'){
|
|
|
|
|
|
|
|
|
|
// draw circle
|
|
|
|
|
var canvasRadial = document.createElement('canvas'),
|
|
|
|
|
ctxRadial = canvasRadial.getContext('2d'),
|
|
|
|
|
ri = Math.max(gradient.rx, gradient.ry),
|
|
|
|
|
di = ri * 2, imgRadial;
|
|
|
|
|
|
|
|
|
|
canvasRadial.width = canvasRadial.height = di;
|
|
|
|
|
|
|
|
|
|
grad = ctxRadial.createRadialGradient(gradient.rx, gradient.ry, 0, gradient.rx, gradient.ry, ri);
|
|
|
|
|
|
|
|
|
|
for (i = 0, len = gradient.colorStops.length; i < len; i+=1) {
|
|
|
|
|
try {
|
|
|
|
|
grad.addColorStop(gradient.colorStops[i].stop, gradient.colorStops[i].color);
|
|
|
|
|
}
|
|
|
|
|
catch(e) {
|
|
|
|
|
h2clog(['failed to add color stop: ', e, '; tried to add: ', gradient.colorStops[i], '; stop: ', i, '; in: ', src]);
|
|
|
|
|
}
|
2012-03-10 02:20:34 +04:00
|
|
|
|
}
|
2012-03-10 19:31:16 +04:00
|
|
|
|
|
|
|
|
|
ctxRadial.fillStyle = grad;
|
|
|
|
|
ctxRadial.fillRect(0, 0, di, di);
|
2012-03-10 02:20:34 +04:00
|
|
|
|
|
2012-03-10 19:31:16 +04:00
|
|
|
|
imgRadial = new Image();
|
|
|
|
|
imgRadial.src = canvasRadial.toDataURL();
|
|
|
|
|
|
|
|
|
|
// transform circle to ellipse
|
|
|
|
|
ctx.fillStyle = gradient.colorStops[i - 1].color;
|
|
|
|
|
ctx.fillRect(0, 0, canvas.width, canvas.height);
|
|
|
|
|
|
|
|
|
|
ctx.drawImage(imgRadial, gradient.cx - gradient.rx, gradient.cy - gradient.ry, 2 * gradient.rx, 2 * gradient.ry);
|
|
|
|
|
|
|
|
|
|
img.src = canvas.toDataURL();
|
|
|
|
|
}
|
2011-09-13 00:50:43 +04:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return img;
|
2012-03-02 20:05:03 +04:00
|
|
|
|
};
|
2011-09-13 18:09:33 +04:00
|
|
|
|
|
2012-03-02 20:05:03 +04:00
|
|
|
|
_html2canvas.Generate.ListAlpha = function(number) {
|
2011-09-13 18:09:33 +04:00
|
|
|
|
var tmp = "",
|
|
|
|
|
modulus;
|
|
|
|
|
|
|
|
|
|
do {
|
|
|
|
|
modulus = number % 26;
|
|
|
|
|
tmp = String.fromCharCode((modulus) + 64) + tmp;
|
|
|
|
|
number = number / 26;
|
|
|
|
|
}while((number*26) > 26);
|
|
|
|
|
|
|
|
|
|
return tmp;
|
2012-03-02 20:05:03 +04:00
|
|
|
|
};
|
2011-09-13 18:09:33 +04:00
|
|
|
|
|
2012-03-02 20:05:03 +04:00
|
|
|
|
_html2canvas.Generate.ListRoman = function(number) {
|
2011-09-13 18:09:33 +04:00
|
|
|
|
var romanArray = ["M", "CM", "D", "CD", "C", "XC", "L", "XL", "X", "IX", "V", "IV", "I"],
|
|
|
|
|
decimal = [1000, 900, 500, 400, 100, 90, 50, 40, 10, 9, 5, 4, 1],
|
|
|
|
|
roman = "",
|
|
|
|
|
v,
|
|
|
|
|
len = romanArray.length;
|
|
|
|
|
|
|
|
|
|
if (number <= 0 || number >= 4000) {
|
|
|
|
|
return number;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (v=0; v < len; v+=1) {
|
|
|
|
|
while (number >= decimal[v]) {
|
|
|
|
|
number -= decimal[v];
|
|
|
|
|
roman += romanArray[v];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return roman;
|
|
|
|
|
|
2012-03-02 20:05:03 +04:00
|
|
|
|
};
|
2012-03-05 23:20:44 +04:00
|
|
|
|
|
|
|
|
|
})();
|