有没有办法快速确定浏览器是否支持启用CORS的图像而不是污染浏览器?

时间:2011-12-08 23:02:24

标签: javascript html5 canvas cors

是否有一个快速测试来确定浏览器是否支持启用CORS的图像,而不是在绘制它们时污染画布。我知道Chrome 15支持这个,Firefox 9Beta但不是Firefox 8,Safari不支持,IE9不支持。但是必须有一个非常简单的测试来确定这一点,基本上是在带有图像的画布上绘制,看看当你试图获取图像数据时是否会出现异常,或者是否有其他简单的方法来确定它。

3 个答案:

答案 0 :(得分:8)

这似乎有效:

if ('crossOrigin' in new Image())
    // ...

答案 1 :(得分:5)

以下是我测试CORS染色帆布支撑的方法。如果某人有办法而无需加载图片,请在此处发布:

function CanvasFunctions() {
    var _initialized = false, _corsNotSupported = false;


    function DrawImage(image, src) {
        jQuery.when(initialized()).then(function () { 
            if (_corsNotSupported) {
               image.src = GetProxyImage(src);
            } else {
               image.src = src;
            } 
        }
    }

    function initialized() {
        if (_initialized) {
            return true;
        }

        var dfd = $.Deferred();

        var src = 'http://example.com/corsImage.jpg',
            image.onload = function () {
                var canvas = document.createElement('canvas');
                canvas.width = 250;
                canvas.height = 250;
                var ctx = canvas.getContext('2d');
                ctx.drawImage(image, 0, 0, 200, 200);
                try {
                    var hit = ctx.getImageData(0, 0, 1, 1).data[3] > 1;
                    console.log('Canvas was not tainted by CORS image, hit: ' + hit);
                } catch (e)  {
                    console.log('Canvas was tainted by CORS image, reverting to passthru for images');
                    _corsNotSupported = true;
                }
                _initialized = true;
                dfd.resolve(true);
            });

        image.src = src;


        return dfd.promise();
    }
}

答案 2 :(得分:4)

确定浏览器是否支持CORS的最简单方法是查找XHR withCredentials属性。 IE使用XDomainRequest对象而不是XHR,所以你也需要查找它:

function supportsCors() {
  var xhr = new XMLHttpRequest();
  if ("withCredentials" in xhr) {
    // Supports CORS
    return true;
  } else if (typeof XDomainRequest != "undefined") {
    // IE
    return true;
  }
  return false;
}