mirror of
https://github.com/niklasvh/html2canvas.git
synced 2023-08-10 21:13:10 +03:00
Added support for base64 encoded images as sources
This commit is contained in:
parent
9f924dfbab
commit
39551dac1f
@ -28,6 +28,16 @@
|
|||||||
* THE SOFTWARE.
|
* THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
if (typeof Array.prototype.indexOf == "undefined") {
|
||||||
|
Array.prototype.indexOf = function(elem) {
|
||||||
|
if (!this.length) return -1;
|
||||||
|
for (var i = 0, len = this.length; i < len; i++) {
|
||||||
|
if (this[i] == elem) return i
|
||||||
|
}
|
||||||
|
return -1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a render of the element el
|
* Creates a render of the element el
|
||||||
* @constructor
|
* @constructor
|
||||||
@ -173,7 +183,6 @@ html2canvas.prototype.init = function(){
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
html2canvas.prototype.start = function(){
|
html2canvas.prototype.start = function(){
|
||||||
// console.log(this.images);
|
|
||||||
if (this.images.length == 0 || this.imagesLoaded==this.images.length/2){
|
if (this.images.length == 0 || this.imagesLoaded==this.images.length/2){
|
||||||
|
|
||||||
this.log('Finished loading '+this.imagesLoaded+' images, Started parsing');
|
this.log('Finished loading '+this.imagesLoaded+' images, Started parsing');
|
||||||
@ -294,11 +303,13 @@ html2canvas.prototype.finish = function(){
|
|||||||
html2canvas.prototype.drawBackground = function(el,bounds,ctx){
|
html2canvas.prototype.drawBackground = function(el,bounds,ctx){
|
||||||
|
|
||||||
// TODO add support for multi background-images
|
// TODO add support for multi background-images
|
||||||
var background_image = this.getCSS(el,"background-image").split(",")[0];
|
var background_image = this.getCSS(el,"background-image");
|
||||||
var background_repeat = this.getCSS(el,"background-repeat").split(",")[0];
|
var background_repeat = this.getCSS(el,"background-repeat").split(",")[0];
|
||||||
|
|
||||||
if (typeof background_image != "undefined" && /^(1|none)$/.test(background_image)==false && /^(-webkit|-moz|linear-gradient|-o-)/.test(background_image)==false){
|
if (!background_image.match(/data:image\/.*;base64,/i))
|
||||||
|
background_image = this.getCSS(el,"background-image").split(",")[0];
|
||||||
|
|
||||||
|
if (typeof background_image != "undefined" && /^(1|none)$/.test(background_image)==false && /^(-webkit|-moz|linear-gradient|-o-)/.test(background_image)==false){
|
||||||
background_image = this.backgroundImageUrl(background_image);
|
background_image = this.backgroundImageUrl(background_image);
|
||||||
var image = this.loadImage(background_image);
|
var image = this.loadImage(background_image);
|
||||||
|
|
||||||
@ -439,7 +450,10 @@ html2canvas.prototype.drawBackground = function(el,bounds,ctx){
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
html2canvas.prototype.backgroundImageUrl = function(src){
|
html2canvas.prototype.backgroundImageUrl = function(src){
|
||||||
if (src.substr(0,5)=='url("'){
|
if (src.match(/data:image\/.*;base64,/i)) {
|
||||||
|
return src
|
||||||
|
}
|
||||||
|
if (src.toLowerCase().substr(0,5)=='url("'){
|
||||||
src = src.substr(5);
|
src = src.substr(5);
|
||||||
src = src.substr(0,src.length-2);
|
src = src.substr(0,src.length-2);
|
||||||
}else{
|
}else{
|
||||||
@ -610,7 +624,6 @@ html2canvas.prototype.getBorderData = function(el){
|
|||||||
|
|
||||||
html2canvas.prototype.drawBorders = function(el,ctx, bounds,clip){
|
html2canvas.prototype.drawBorders = function(el,ctx, bounds,clip){
|
||||||
|
|
||||||
|
|
||||||
var x = bounds.left;
|
var x = bounds.left;
|
||||||
var y = bounds.top;
|
var y = bounds.top;
|
||||||
var w = bounds.width;
|
var w = bounds.width;
|
||||||
@ -961,7 +974,7 @@ html2canvas.prototype.getImages = function(el) {
|
|||||||
|
|
||||||
if (background_image && background_image != "1" && background_image != "none" && background_image.substring(0,7)!="-webkit" && background_image.substring(0,3)!="-o-" && background_image.substring(0,4)!="-moz"){
|
if (background_image && background_image != "1" && background_image != "none" && background_image.substring(0,7)!="-webkit" && background_image.substring(0,3)!="-o-" && background_image.substring(0,4)!="-moz"){
|
||||||
// TODO add multi image background support
|
// TODO add multi image background support
|
||||||
var src = this.backgroundImageUrl(background_image.split(",")[0]);
|
var src = this.backgroundImageUrl(background_image.match(/data:image\/.*;base64,/i) ? background_image : background_image.split(",")[0]);
|
||||||
this.preloadImage(src);
|
this.preloadImage(src);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -991,7 +1004,14 @@ html2canvas.prototype.preloadImage = function(src){
|
|||||||
|
|
||||||
|
|
||||||
if (this.getIndex(this.images,src)==-1){
|
if (this.getIndex(this.images,src)==-1){
|
||||||
if (this.isSameOrigin(src)){
|
if (src.match(/data:image\/.*;base64,/i)) {
|
||||||
|
var img = new Image();
|
||||||
|
img.src = src.replace(/url\(['"]|['"]\)$/img, '');
|
||||||
|
this.images.push(src);
|
||||||
|
this.images.push(img);
|
||||||
|
this.imagesLoaded++;
|
||||||
|
this.start();
|
||||||
|
} else if(this.isSameOrigin(src)){
|
||||||
this.images.push(src);
|
this.images.push(src);
|
||||||
// console.log('a'+src);
|
// console.log('a'+src);
|
||||||
var img = new Image();
|
var img = new Image();
|
||||||
|
@ -46,6 +46,11 @@
|
|||||||
div{
|
div{
|
||||||
display:block;
|
display:block;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.encoded {
|
||||||
|
background:url("");
|
||||||
|
background-position: center center;
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
</head>
|
</head>
|
||||||
@ -88,11 +93,13 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="medium">
|
<div class="medium">
|
||||||
|
|
||||||
<div style="background:url(image.jpg) no-repeat -15% 25px;"></div>
|
<div style="background:url(image.jpg) no-repeat -15% 25px;"></div>
|
||||||
<div style="background-image:url(image.jpg), url(image2.jpg); background-repeat: repeat-x; background-position: 50px 50px, 100px 100px;"></div>
|
<div style="background-image:url(image.jpg), url(image2.jpg); background-repeat: repeat-x; background-position: 50px 50px, 100px 100px;"></div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="medium">
|
||||||
|
<div class="encoded"></div>
|
||||||
|
</div>
|
||||||
|
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user