mirror of
https://github.com/niklasvh/html2canvas.git
synced 2023-08-10 21:13:10 +03:00
Merge pull request #77 from SunboX/background-gradients
ellipse gradient generation should now work
This commit is contained in:
commit
1ad7ed3e1c
@ -27,6 +27,7 @@ var reGradients = [
|
|||||||
/*
|
/*
|
||||||
* TODO: Add IE10 vendor prefix (-ms) support
|
* TODO: Add IE10 vendor prefix (-ms) support
|
||||||
* TODO: Add W3C gradient (linear-gradient) support
|
* TODO: Add W3C gradient (linear-gradient) support
|
||||||
|
* TODO: Add old Webkit -webkit-gradient(radial, ...) support
|
||||||
* TODO: Maybe some RegExp optimizations are possible ;o)
|
* TODO: Maybe some RegExp optimizations are possible ;o)
|
||||||
*/
|
*/
|
||||||
_html2canvas.Generate.parseGradient = function(css, bounds) {
|
_html2canvas.Generate.parseGradient = function(css, bounds) {
|
||||||
@ -114,7 +115,7 @@ _html2canvas.Generate.parseGradient = function(css, bounds) {
|
|||||||
case '-webkit-gradient':
|
case '-webkit-gradient':
|
||||||
|
|
||||||
gradient = {
|
gradient = {
|
||||||
type: m1[2],
|
type: m1[2] === 'radial' ? 'circle' : m1[2], // TODO: Add radial gradient support for older mozilla definitions
|
||||||
x0: 0,
|
x0: 0,
|
||||||
y0: 0,
|
y0: 0,
|
||||||
x1: 0,
|
x1: 0,
|
||||||
@ -205,7 +206,7 @@ _html2canvas.Generate.parseGradient = function(css, bounds) {
|
|||||||
case '-o-radial-gradient':
|
case '-o-radial-gradient':
|
||||||
|
|
||||||
gradient = {
|
gradient = {
|
||||||
type: 'radial',
|
type: 'circle',
|
||||||
x0: 0,
|
x0: 0,
|
||||||
y0: 0,
|
y0: 0,
|
||||||
x1: bounds.width,
|
x1: bounds.width,
|
||||||
@ -255,7 +256,7 @@ _html2canvas.Generate.parseGradient = function(css, bounds) {
|
|||||||
);
|
);
|
||||||
} else { // ellipse
|
} else { // ellipse
|
||||||
|
|
||||||
h2clog('No ellipse gradient supported by now, cause canvas can´t draw ellipse :(');
|
gradient.type = m2[0];
|
||||||
|
|
||||||
gradient.rx = Math.max(
|
gradient.rx = Math.max(
|
||||||
gradient.cx,
|
gradient.cx,
|
||||||
@ -278,7 +279,7 @@ _html2canvas.Generate.parseGradient = function(css, bounds) {
|
|||||||
);
|
);
|
||||||
} else { // ellipse
|
} else { // ellipse
|
||||||
|
|
||||||
h2clog('No ellipse gradient supported by now, cause canvas can´t draw ellipse :(');
|
gradient.type = m2[0];
|
||||||
|
|
||||||
gradient.rx = Math.min(
|
gradient.rx = Math.min(
|
||||||
gradient.cx,
|
gradient.cx,
|
||||||
@ -338,7 +339,8 @@ _html2canvas.Generate.Gradient = function(src, bounds) {
|
|||||||
|
|
||||||
img = new Image();
|
img = new Image();
|
||||||
|
|
||||||
if(gradient && gradient.type === 'linear'){
|
if(gradient){
|
||||||
|
if(gradient.type === 'linear'){
|
||||||
grad = ctx.createLinearGradient(gradient.x0, gradient.y0, gradient.x1, gradient.y1);
|
grad = ctx.createLinearGradient(gradient.x0, gradient.y0, gradient.x1, gradient.y1);
|
||||||
|
|
||||||
for (i = 0, len = gradient.colorStops.length; i < len; i+=1) {
|
for (i = 0, len = gradient.colorStops.length; i < len; i+=1) {
|
||||||
@ -354,9 +356,8 @@ _html2canvas.Generate.Gradient = function(src, bounds) {
|
|||||||
ctx.fillRect(0, 0, bounds.width, bounds.height);
|
ctx.fillRect(0, 0, bounds.width, bounds.height);
|
||||||
|
|
||||||
img.src = canvas.toDataURL();
|
img.src = canvas.toDataURL();
|
||||||
} else if(gradient && gradient.type === 'radial'){
|
} else if(gradient.type === 'circle'){
|
||||||
|
|
||||||
// TODO: Add support for "ellipsis" drawing
|
|
||||||
grad = ctx.createRadialGradient(gradient.cx, gradient.cy, 0, gradient.cx, gradient.cy, gradient.rx);
|
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) {
|
for (i = 0, len = gradient.colorStops.length; i < len; i+=1) {
|
||||||
@ -372,6 +373,44 @@ _html2canvas.Generate.Gradient = function(src, bounds) {
|
|||||||
ctx.fillRect(0, 0, bounds.width, bounds.height);
|
ctx.fillRect(0, 0, bounds.width, bounds.height);
|
||||||
|
|
||||||
img.src = canvas.toDataURL();
|
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]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ctxRadial.fillStyle = grad;
|
||||||
|
ctxRadial.fillRect(0, 0, di, di);
|
||||||
|
|
||||||
|
ctx.fillStyle = gradient.colorStops[i - 1].color;
|
||||||
|
ctx.fillRect(0, 0, canvas.width, canvas.height);
|
||||||
|
|
||||||
|
imgRadial = new Image();
|
||||||
|
imgRadial.onload = function() { // wait until the image is filled
|
||||||
|
|
||||||
|
// transform circle to ellipse
|
||||||
|
ctx.drawImage(imgRadial, gradient.cx - gradient.rx, gradient.cy - gradient.ry, 2 * gradient.rx, 2 * gradient.ry);
|
||||||
|
|
||||||
|
img.src = canvas.toDataURL();
|
||||||
|
|
||||||
|
}
|
||||||
|
imgRadial.src = canvasRadial.toDataURL();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return img;
|
return img;
|
||||||
|
@ -170,18 +170,18 @@
|
|||||||
background: radial-gradient(75% 19%, ellipse farthest-corner, #ababab, #0000ff 33%,#991f1f 100%);
|
background: radial-gradient(75% 19%, ellipse farthest-corner, #ababab, #0000ff 33%,#991f1f 100%);
|
||||||
}
|
}
|
||||||
.radialGradient7 {
|
.radialGradient7 {
|
||||||
background: -moz-radial-gradient(75% 19%, ellipse contain, #ababab, #0000ff 33%,#991f1f 100%);
|
background: -moz-radial-gradient(75% 19%, circle contain, #ababab, #0000ff 33%,#991f1f 100%);
|
||||||
background: -webkit-radial-gradient(75% 19%, ellipse contain, #ababab, #0000ff 33%,#991f1f 100%);
|
background: -webkit-radial-gradient(75% 19%, circle contain, #ababab, #0000ff 33%,#991f1f 100%);
|
||||||
background: -o-radial-gradient(75% 19%, ellipse contain, #ababab, #0000ff 33%,#991f1f 100%);
|
background: -o-radial-gradient(75% 19%, circle contain, #ababab, #0000ff 33%,#991f1f 100%);
|
||||||
background: -ms-radial-gradient(75% 19%, ellipse contain, #ababab, #0000ff 33%,#991f1f 100%);
|
background: -ms-radial-gradient(75% 19%, circle contain, #ababab, #0000ff 33%,#991f1f 100%);
|
||||||
background: radial-gradient(75% 19%, ellipse contain, #ababab, #0000ff 33%,#991f1f 100%);
|
background: radial-gradient(75% 19%, circle contain, #ababab, #0000ff 33%,#991f1f 100%);
|
||||||
}
|
}
|
||||||
.radialGradient8 {
|
.radialGradient8 {
|
||||||
background: -moz-radial-gradient(75% 19%, ellipse cover, #ababab, #0000ff 33%,#991f1f 100%);
|
background: -moz-radial-gradient(75% 19%, circle cover, #ababab, #0000ff 33%,#991f1f 100%);
|
||||||
background: -webkit-radial-gradient(75% 19%, ellipse cover, #ababab, #0000ff 33%,#991f1f 100%);
|
background: -webkit-radial-gradient(75% 19%, circle cover, #ababab, #0000ff 33%,#991f1f 100%);
|
||||||
background: -o-radial-gradient(75% 19%, ellipse cover, #ababab, #0000ff 33%,#991f1f 100%);
|
background: -o-radial-gradient(75% 19%, circle cover, #ababab, #0000ff 33%,#991f1f 100%);
|
||||||
background: -ms-radial-gradient(75% 19%, ellipse cover, #ababab, #0000ff 33%,#991f1f 100%);
|
background: -ms-radial-gradient(75% 19%, circle cover, #ababab, #0000ff 33%,#991f1f 100%);
|
||||||
background: radial-gradient(75% 19%, ellipse cover, #ababab, #0000ff 33%,#991f1f 100%);
|
background: radial-gradient(75% 19%, circle cover, #ababab, #0000ff 33%,#991f1f 100%);
|
||||||
}
|
}
|
||||||
.radialGradient9 {
|
.radialGradient9 {
|
||||||
background: -moz-radial-gradient(right 19%, ellipse cover, #ababab, #0000ff 33%,#991f1f 100%);
|
background: -moz-radial-gradient(right 19%, ellipse cover, #ababab, #0000ff 33%,#991f1f 100%);
|
||||||
|
@ -104,7 +104,7 @@ $(function() {
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
type: "radial",
|
type: "ellipse",
|
||||||
x0: 0,
|
x0: 0,
|
||||||
y0: 0,
|
y0: 0,
|
||||||
x1: 50,
|
x1: 50,
|
||||||
@ -129,7 +129,7 @@ $(function() {
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
type: "radial",
|
type: "circle",
|
||||||
x0: 0,
|
x0: 0,
|
||||||
y0: 0,
|
y0: 0,
|
||||||
x1: 50,
|
x1: 50,
|
||||||
@ -154,7 +154,7 @@ $(function() {
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
type: "radial",
|
type: "ellipse",
|
||||||
x0: 0,
|
x0: 0,
|
||||||
y0: 0,
|
y0: 0,
|
||||||
x1: 50,
|
x1: 50,
|
||||||
@ -179,7 +179,7 @@ $(function() {
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
type: "radial",
|
type: "circle",
|
||||||
x0: 0,
|
x0: 0,
|
||||||
y0: 0,
|
y0: 0,
|
||||||
x1: 50,
|
x1: 50,
|
||||||
@ -204,7 +204,7 @@ $(function() {
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
type: "radial",
|
type: "ellipse",
|
||||||
x0: 0,
|
x0: 0,
|
||||||
y0: 0,
|
y0: 0,
|
||||||
x1: 50,
|
x1: 50,
|
||||||
@ -229,7 +229,7 @@ $(function() {
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
type: "radial",
|
type: "circle",
|
||||||
x0: 0,
|
x0: 0,
|
||||||
y0: 0,
|
y0: 0,
|
||||||
x1: 50,
|
x1: 50,
|
||||||
|
Loading…
Reference in New Issue
Block a user