- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
嗨,html2canvas 和 SVG 大师也许你可以帮助我,我正在尝试从 SVG 下载图像,用户在 SVG 区域上设置图像,但是当我使用 html2canvas 生成图像时,背景图像看起来很奇怪,需要下载生成的文件,我收到错误:“未捕获( promise 中)DOMException:无法执行‘toDataURL’“HTMLCanvasElement”:受污染的 Canvas 可能无法导出。”
我举了一个例子来更好地理解: http://jsfiddle.net/equerol/sodofkcs/5711/
html2canvas(document.getElementById("svgContainer"), {
logging: true,
allowTaint: true,
}).then(function(canvas) {
document.body.appendChild(canvas);
var myImage = canvas.toDataURL("image/png");
downloadURI("data:" + myImage, "yourImage.png");
});
谢谢。
最佳答案
我不太明白你的问题。我认为您在这里问两件事(图像看起来很奇怪,由于 Canvas 受污染而无法下载)。
对于第一个问题,您应该澄清您真正要问的内容(奇怪是什么意思?您想实现什么目标?...)
对于第二个(受污染的 Canvas ),您正在处理安全问题:
Allowing cross-origin use of images and canvas
上面的链接深入解释了您面临的问题。
您应该尝试使用链接中建议的方法之一。
通过在 Canvas 中使用嵌入的图像数据 URI,我可以轻松克服安全问题,使其不再受到污染。我基本上用 dataURI 替换了您的外部图像 URL。 请尝试找到适合您问题的更好解决方案。
Working version of your fiddle (download canvas is possible)
以下是受影响的代码以及我为使其正常工作而替换的代码(已 chop ):
/* ... */
<g id="svgPoly4" clip-path="url(#d)" class="droppable">
<image width="500" height="500" xlink:href="data:image/png;base64,iVBORw0KGgoAAAA....ggg=="></image>
</g>
/* ... */
抱歉,在原来的答案中我应该更清楚地了解您面临的安全问题。
基本上,您正在尝试获取在 SVG 合成中重新格式化/重新设计的外国图像的屏幕截图。这意味着恶意实体可以使用此技术劫持用户的敏感信息(图像),以防浏览器没有阻止。
要解决您的问题,您真正应该做的就是提供与页面其余部分同源的 SVG 中嵌入的图像。如果由于某种原因/用例您需要获取外部图像用于合成,这些图像应由您的后端代理。
无论如何,我对你的 fiddle 做了一些调整,现在它可以在 Chrome、Firefox 和 Safari 中使用。 Edge 无法工作(但鉴于您最初的实现,我猜您还没有尝试过)。
此版本强调了您应该做什么 do to replace the image in your SVG .
注意:图像之前已上传到允许跨源访问资源的服务器(它添加了 Access-Control-Allow-Origin
header )
SVG html 作为模板字符串加载,加载图像时数据 URL 将被替换。
图片已加载:
var downloadedImg = new Image;
downloadedImg.crossOrigin = "Anonymous";
downloadedImg.addEventListener("load", imageReceived, false);
downloadedImg.src = "https://i.imgur.com/szhc74z.png";
模板 SVG html 字符串中的数据 URL 被替换:
var svg = svgTemplate.replace('${imageUrl}', dataUrl);
document.getElementById('rootSvg').innerHTML = svg;
Safari 的其他解决方法:
html2canvas 及其“重新渲染”SVG 的方式似乎存在某种问题。
为了缓解这种情况,一旦将 SVG 添加到文档中,就会调用 html2canvas
函数。这将为“真正的”调用“预热”过程。
我的 fiddle 的目的只是为了证明这一壮举是可以完成的,但是请尝试使用后端代理方法或不同的设计来解决您的问题。
关于javascript - html2canvas 下载带有 SVG 背景图像的图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53752220/
我可以使用两种方法添加一个 child ,一种是 Canvas.AddVisualChild(Visual); Canvas.AddLogicalChild(Visual); 我在视觉对象的 Draw
在过去的几周里,我一直在尝试各种方法,试图找到将 BDD 用于依赖于 HTML5 Canvas 元素以及用户与之交互的 Web 应用程序的最佳方法。 我一直在使用 Jasmine 和 Cucumber
我正在尝试完成撤消/重做。我正在使用loadFromJSON(...)从我存储在数组中的 Canvas 状态重新构建 Canvas 。基本上,我的想法是破坏现有的 Canvas 并重新构建 Canva
我正在尝试在 Canvas 上设置简单的放大/缩小功能。我正在使用 KineticJS 处理触摸事件并在 Canvas 中绘图,但无法实现缩放。 KinteicJS 有一个类似的例子,但它们总是在中心
我正在使用 processing.js 在 javascript 中开发一个画笔应用程序 它正在使用 Canvas 对象。我想在 Canvas 的背景中保留一个图像。在前景中画一些东西。在保存时,我只
您好,我想为 discord.js Bot 安装 Canvas 。 当我尝试使用以下命令安装 Canvas 时npm install canvas我收到以下错误: pi@server:~/Bots/D
我正在尝试使用 Canvas 和动力学的组合来构建填充图案,但在尝试获得连续线时遇到了问题。 此 jsfiddle显示了到目前为止我所拥有的,但是因为我的重复模式是正方形,角会影响线条,我尝试使用 l
我正在开发一个 webassembly 程序。 我可以使用 emscripten_set_canvas_size 设置 Canvas 大小(我一直读到我需要切换到新的 API,因为这个 API 会贬值
您好,我已经为第一个 Canvas 中的第一个图像创建了一个圆形表单,但我没有成功使用第一个 Canvas 的 dataURL 并将其添加到第二个 Canvas 中。 这是我的 fiddle :htt
问题在于不同浏览器之间的不一致。 使用Dart Chrome,JS Chrome,JS Opera运行 双击可以进入和退出全屏 m_oCanvas.width =(window.screen.widt
我正在使用Flutter框架和Dart开发图像编辑器,因此无法将矩阵滤镜应用于 Canvas 。 我正在尝试使用“Paint”类和“canvas.drawPaint(paint)”函数将矩阵过滤器应用
如果在已经具有非整数比例因子的 Canvas 上绘制图像,我会遇到 Canvas 上下文drawImage()方法的问题。似乎这样的图像以一种奇怪的方式被剪切(有时图像的最右边的部分被剪切,有时是最底
Canvas 的“宽度”属性值有限制吗? 在下面的示例中,我在 ScrolledWindow 中创建一个 Canvas。 # Packages package require BWidget # Ma
我正在尝试制作类似于 this article 底部的效果的文本效果 我建议的方法是: 制作两个 Canvas ,一个是可见的,另一个是不可见的我用它作为缓冲区。 在缓冲区 Canvas 上绘制一些文
例如var new = canvas.toDataURL("image/png"); 我希望这个新变量中存在的 base64 显示到存在的第二个 Canvas 元素中。但是它不使用 drawimage
有人有使用这两个 Node.js 库中的一个或两个的经验吗?很想知道每个人的成功或困难。 最佳答案 LearnBoost是社区中最多产的 Node 模块开发人员之一,因此我选择使用 node-canv
如何知道 Canvas 运行的是“WebGL”还是普通 Canvas ? 通过检查源代码,我发现这两种情况都是 Canvas 。 最佳答案 这真的取决于你想如何去发现。 例如你可以这样调用 `getC
在 Canvas 上绘图非常好。甚至橡皮擦也能正常工作。问题是,当 Canvas 保存为图像时,它绘制的是黑线而不是橡皮擦。 为了更好地理解,我添加了屏幕截图和代码。 1。在删除绘图时 - 一个。源代
我正在尝试为 Canvas 附加鼠标悬停和鼠标移出事件: 默认 Canvas 是函数drawcircle的 Canvas 。 如果用户越过 Canvas ,应将其更改为drawEllipse的 Can
我正在使用 Three.js 构建一个简单的 2D 游戏。我只使用世界的 X 和 Y 位置来移动对象,将它们的 z 位置保留为零。我使用禁用旋转的 TrackballControls,以允许使用右键单
我是一名优秀的程序员,十分优秀!