diff --git a/src/Core.js b/src/Core.js
index 8c2a907af..a29e6cb20 100644
--- a/src/Core.js
+++ b/src/Core.js
@@ -75,7 +75,8 @@ _html2canvas.Util.getCSS = function (el, attribute) {
// If we're not dealing with a regular pixel number
// but a number that has a weird ending, we need to convert it to pixels
- if ( !/^-?\d+(?:px)?$/i.test( val ) && /^-?\d/.test( val ) ) {
+
+ if ( !/^-?[0-9]+\.?[0-9]*(?:px)?$/i.test( val ) && /^-?\d/.test( val ) ) {
// Remember the original values
left = style.left;
@@ -94,7 +95,13 @@ _html2canvas.Util.getCSS = function (el, attribute) {
}
}
+
+ if (!/^(thin|medium|thick)$/i.test( val )) {
+ return Math.round(parseFloat( val )) + "px";
+ }
+
return val;
+
}
@@ -104,7 +111,7 @@ _html2canvas.Util.getCSS = function (el, attribute) {
if ( attribute === "backgroundPosition" ) {
val = (val.split(",")[0] || "0 0").split(" ");
-
+
val[ 0 ] = ( val[0].indexOf( "%" ) === -1 ) ? toPX( attribute + "X", val[ 0 ] ) : val[ 0 ];
val[ 1 ] = ( val[1] === undefined ) ? val[0] : val[1]; // IE 9 doesn't return double digit always
val[ 1 ] = ( val[1].indexOf( "%" ) === -1 ) ? toPX( attribute + "Y", val[ 1 ] ) : val[ 1 ];
@@ -114,8 +121,7 @@ _html2canvas.Util.getCSS = function (el, attribute) {
// IE 9>
if (attribute === "backgroundPosition") {
// Older IE uses -x and -y
- val = [ toPX( attribute + "X", el.currentStyle[ attribute + "X" ] ), toPX( attribute + "Y", el.currentStyle[ attribute + "X" ] ) ];
-
+ val = [ toPX( attribute + "X", el.currentStyle[ attribute + "X" ] ), toPX( attribute + "Y", el.currentStyle[ attribute + "Y" ] ) ];
} else {
val = toPX( attribute, el.currentStyle[ attribute ] );
@@ -212,8 +218,9 @@ _html2canvas.Util.Children = function(el) {
// $(el).contents() !== el.childNodes, Opera / IE have issues with that
var children;
try {
- children = $(el).contents();
- // children = (el.nodeName && el.nodeName.toUpperCase() === "IFRAME") ? el.contentDocument || el.contentWindow.document : Array.prototype.push.call([], el.childNodes );
+ // children = $(el).contents();
+ children = (el.nodeName && el.nodeName.toUpperCase() === "IFRAME") ? el.contentDocument || el.contentWindow.document : el.childNodes ;
+
} catch (ex) {
h2clog("html2canvas.Util.Children failed with exception: " + ex.message);
children = [];
diff --git a/src/Preload.js b/src/Preload.js
index e16b6a056..563005f59 100644
--- a/src/Preload.js
+++ b/src/Preload.js
@@ -144,7 +144,8 @@ _html2canvas.Preload = function( options ) {
// TODO add multi image background support
- if (background_image.substring(0,7) === "-webkit" || background_image.substring(0,3) === "-o-" || background_image.substring(0,4) === "-moz") {
+ if (!/^(-webkit|-o|-moz|-ms|linear)-/.test( src )) {
+ // if (background_image.substring(0,7) === "-webkit" || background_image.substring(0,3) === "-o-" || background_image.substring(0,4) === "-moz") {
img = _html2canvas.Generate.Gradient( background_image, _html2canvas.Util.Bounds( el ) );
@@ -210,10 +211,10 @@ _html2canvas.Preload = function( options ) {
};
- // TODO Opera has no load/error event for SVG images
+ // TODO Opera has no load/error event for SVG images
- // Opera ninja onload's cached images
- /*
+ // Opera ninja onload's cached images
+ /*
window.setTimeout(function(){
if ( img.width !== 0 && imageObj.succeeded === undefined ) {
img.onload();
diff --git a/tests/qunit/index.html b/tests/qunit/index.html
index 1a465b504..529082bb7 100644
--- a/tests/qunit/index.html
+++ b/tests/qunit/index.html
@@ -22,7 +22,7 @@
-
+