javascript - 如何使用 canvas.toDataURL() 在 Adob​​e AIR 中获取图像的 base64?

标签 javascript air html5-canvas base64

是否可以在 Adob​​e AIR 中使用 canvas.toDataURL()

当我尝试时出现以下错误:

Error: SECURITY_ERR: DOM Exception 18

最佳答案

Adobe AIR 对 Canvas API 中使用的图像强制实现同源。一旦你在你的 Canvas 中使用了来自另一个域的东西,你就无法从中取回像素数据。但是,您可以使用 Loader 类获取像素数据,并将其转换为 Canvas ImageData。

例如:

function getDataURL(url, callback) {
  var loader = new air.Loader();
  loader.contentLoaderInfo.addEventListener(air.Event.COMPLETE, function(event) {
    var bitmapData = loader.content.bitmapData;

    var canvas = document.createElement('canvas');
    canvas.width = bitmapData.width;
    canvas.height = bitmapData.height;
    var context = canvas.getContext('2d');
    var imageData = context.createImageData(canvas.width, canvas.height);

    var dst = imageData.data;
    var src = bitmapData.getPixels(bitmapData.rect);
    src.position = 0;

    var i = 0;
    while (i < dst.length) {
      var alpha = src.readUnsignedByte();
      dst[i++] = src.readUnsignedByte();
      dst[i++] = src.readUnsignedByte();
      dst[i++] = src.readUnsignedByte();
      dst[i++] = alpha;
    }

    context.putImageData(imageData, 0, 0);
    callback(canvas.toDataURL());
  });
  loader.load(new air.URLRequest(url));
}

window.addEventListener('load', function() {
  getDataURL('http://www.google.com/images/logo.gif', function(dataURL) {
    air.trace(dataURL);
  });
}, false);

关于javascript - 如何使用 canvas.toDataURL() 在 Adob​​e AIR 中获取图像的 base64?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3672332/

相关文章:

javascript - ng2 [已禁用] ="!myInput.value"无法正常工作

javascript - 在另一个 div 中使用 div 来创建网站的结构

ios - 应用程序不会在 iOS 设备上调整大小

android - 将 Adob​​e AIR 打包为适用于 Android 的 .APK

javascript - 使用 Fabric.js 动态自动缩放 Canvas 以在 SVG 上导出

javascript - Phonegap Cordova Statusbar 插件创建双条

javascript - 如何使用 javascript 暂停/播放/寻找 silverlight 视频

java - Windows 和 OS X 桌面应用程序的首选开发平台

javascript - html2canvas图像不保存

javascript - 无法使用 JavaScript 在 Canvas 上显示文本