ada*_*101 6 javascript html5 image data-uri
使用JavaScript,我想转换像这样的img标签:
<img width="11" height="14" src="http://mysite/file.gif" alt="File Icon">
Run Code Online (Sandbox Code Playgroud)
进入一个像这样的dataurl:
<img width="11" height="14" src="data:image/gif;base64,R0lGODlhCwAOAMQfAP////7+/vj4+Hh4eHd3d/v7+/Dw8HV1dfLy8ubm5vX19e3t7fr6+nl5edra2nZ2dnx8fMHBwYODg/b29np6eujo6JGRkeHh4eTk5LCwsN3d3dfX13Jycp2dnevr6////yH5BAEAAB8ALAAAAAALAA4AAAVq4NFw1DNAX/o9imAsBtKpxKRd1+YEWUoIiUoiEWEAApIDMLGoRCyWiKThenkwDgeGMiggDLEXQkDoThCKNLpQDgjeAsY7MHgECgx8YR8oHwNHfwADBACGh4EDA4iGAYAEBAcQIg0Dk gcEIQA7" alt="File Icon">
Run Code Online (Sandbox Code Playgroud)
这可能吗?
小智 25
以下是如何使用以下命令获取图像的数据 url fetch
:
(async function() {
let blob = await fetch("https://example.com/image.png").then(r => r.blob());
let dataUrl = await new Promise(resolve => {
let reader = new FileReader();
reader.onload = () => resolve(reader.result);
reader.readAsDataURL(blob);
});
// now do something with `dataUrl`
})();
Run Code Online (Sandbox Code Playgroud)
小智 8
首先,将图像加载到画布中
var canvas = document.createElement("canvas");
context = canvas.getContext('2d');
make_base();
function make_base()
{
base_image = new Image();
base_image.src = 'img/base.png';
base_image.onload = function(){
context.drawImage(base_image, 100, 100);
}
}
Run Code Online (Sandbox Code Playgroud)
确保更新context.drawImage(base_image, 100, 100);
适合您的应用程序的to值.
资料来源:https://stackoverflow.com/a/6011402/3969707
然后将画布转换为数据.
var jpegUrl = canvas.toDataURL("image/jpeg");
var pngUrl = canvas.toDataURL(); // PNG is the default
Run Code Online (Sandbox Code Playgroud)
资料来源:https://stackoverflow.com/a/15685877/3969707
我将使用与加载的图像大小相同的临时画布元素来解决这个问题:
function imageToUri(url, callback) {
const canvas = document.createElement('canvas');
const ctx = canvas.getContext('2d');
var base_image = new Image();
base_image.src = url;
base_image.onload = function() {
canvas.width = base_image.width;
canvas.height = base_image.height;
ctx.drawImage(base_image, 0, 0);
callback(canvas.toDataURL('image/png'));
canvas.remove();
}
}
imageToUri('./assets/some_image.png', function(uri) {
console.log(uri);
});
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
22725 次 |
最近记录: |