2012-12-29 19:43:15 +04:00
|
|
|
window.html2canvas = function(elements, opts) {
|
2013-01-30 22:12:25 +04:00
|
|
|
elements = (elements.length) ? elements : [elements];
|
2012-11-25 22:59:31 +04:00
|
|
|
var queue,
|
|
|
|
canvas,
|
|
|
|
options = {
|
|
|
|
// general
|
|
|
|
logging: false,
|
|
|
|
elements: elements,
|
2013-01-04 01:15:06 +04:00
|
|
|
background: "#fff",
|
2012-11-25 22:59:31 +04:00
|
|
|
|
|
|
|
// preload options
|
2013-01-12 00:36:23 +04:00
|
|
|
proxy: null,
|
2012-11-25 22:59:31 +04:00
|
|
|
timeout: 0, // no timeout
|
|
|
|
useCORS: false, // try to load images as CORS (where available), before falling back to proxy
|
|
|
|
allowTaint: false, // whether to allow images to taint the canvas, won't need proxy if set to true
|
|
|
|
|
|
|
|
// parse options
|
|
|
|
svgRendering: false, // use svg powered rendering where available (FF11+)
|
|
|
|
ignoreElements: "IFRAME|OBJECT|PARAM",
|
|
|
|
useOverflow: true,
|
|
|
|
letterRendering: false,
|
2013-01-12 00:36:23 +04:00
|
|
|
chinese: false,
|
2012-11-25 22:59:31 +04:00
|
|
|
|
|
|
|
// render options
|
|
|
|
|
|
|
|
width: null,
|
|
|
|
height: null,
|
|
|
|
taintTest: true, // do a taint test with all images before applying to canvas
|
|
|
|
renderer: "Canvas"
|
2012-12-29 19:43:15 +04:00
|
|
|
};
|
2012-11-25 22:59:31 +04:00
|
|
|
|
|
|
|
options = _html2canvas.Util.Extend(opts, options);
|
|
|
|
|
|
|
|
_html2canvas.logging = options.logging;
|
|
|
|
options.complete = function( images ) {
|
|
|
|
|
|
|
|
if (typeof options.onpreloaded === "function") {
|
|
|
|
if ( options.onpreloaded( images ) === false ) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
queue = _html2canvas.Parse( images, options );
|
|
|
|
|
|
|
|
if (typeof options.onparsed === "function") {
|
|
|
|
if ( options.onparsed( queue ) === false ) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
canvas = _html2canvas.Renderer( queue, options );
|
|
|
|
|
|
|
|
if (typeof options.onrendered === "function") {
|
|
|
|
options.onrendered( canvas );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
// for pages without images, we still want this to be async, i.e. return methods before executing
|
|
|
|
window.setTimeout( function(){
|
|
|
|
_html2canvas.Preload( options );
|
|
|
|
}, 0 );
|
|
|
|
|
|
|
|
return {
|
|
|
|
render: function( queue, opts ) {
|
|
|
|
return _html2canvas.Renderer( queue, _html2canvas.Util.Extend(opts, options) );
|
|
|
|
},
|
|
|
|
parse: function( images, opts ) {
|
|
|
|
return _html2canvas.Parse( images, _html2canvas.Util.Extend(opts, options) );
|
|
|
|
},
|
|
|
|
preload: function( opts ) {
|
|
|
|
return _html2canvas.Preload( _html2canvas.Util.Extend(opts, options) );
|
|
|
|
},
|
|
|
|
log: h2clog
|
|
|
|
};
|
2012-03-02 20:05:03 +04:00
|
|
|
};
|
2012-03-02 22:35:48 +04:00
|
|
|
|
2012-12-29 19:43:15 +04:00
|
|
|
window.html2canvas.log = h2clog; // for renderers
|
|
|
|
window.html2canvas.Renderer = {
|
2012-11-25 22:59:31 +04:00
|
|
|
Canvas: undefined // We are assuming this will be used
|
|
|
|
};
|