合并两个 dataURI 以创建单个图像
Merge two dataURIs to create a single image
我想生成由标签和图标组成的图像。标签部分会有很大差异(50-100),而图标大约有 10 个。我想通过将最终图像分成两部分(标签图像和图标图像)以模块化方式制作最终图像。我将为标签构建一个 returns dataURI 服务,而图标 dataURI 将嵌入到页面中。然后我想结合这两个不同的 dataURI 来创建一个代表组合图像的单一 dataURI。
我如何在客户端执行此操作?
您可以使用数据 uri 创建图像,然后使用 canvas
绘制包含这些图像的新图像。这是一个简单的例子:
var nloaded = 0;
function checkload(event) {
nloaded++;
if (nloaded < 2) {
return;
}
var canvas = document.querySelector('canvas');
var context = canvas.getContext('2d');
context.drawImage(image1, 0, 0, 50, 50);
context.drawImage(image2, 50, 50, 100, 100);
var combined = new Image;
combined.src = canvas.toDataURL('data/gif');
document.body.appendChild(combined);
}
var image1 = new Image;
image1.onload = checkload;
image1.src = '';
var image2 = new Image;
image2.onload = checkload;
image2.src = '';
canvas {
display: none;
}
<canvas width=100 height=100></canvas>
.
从数据 URI 加载图像并使用 canvas 上下文的 drawImage
命令组合后,您可以使用 canvas 创建新图像,例如:
var combined = new Image;
combined.src = canvas.toDataURL('data/gif');
不幸的是,这在 IE8 中不起作用。
使用包含 URI 源和 x、y 偏移量的图像对象数组的示例:
var images = [
{ src: '', x: 0, y: 0 },
{ src: '', x: 20, y: 20 },
];
var canvas = document.createElement('canvas');
var destination = document.getElementById('canvas');
Promise.all(images.map(imageObj => add2canvas(canvas, imageObj)))
.then(() => destination.append(canvas));
function add2canvas(canvas, imageObj) {
return new Promise( (resolve, reject) => {
if (!imageObj || typeof imageObj != 'object') return reject();
var image = new Image();
image.onload = function () {
canvas.getContext('2d')
.drawImage(this, imageObj.x || 0, imageObj.y || 0);
resolve();
};
image.src = imageObj.src;
});
}
更多bells/whistles...生成复合png的函数:
function mergeImageURIs(images) {
return new Promise( (resolve, reject) => {
var canvas = document.createElement('canvas');
canvas.width = 1000; // desired width of merged images
canvas.height = 1000; // desired height of merged images
Promise.all(images.map(imageObj => add2canvas(canvas, imageObj))).then(() => resolve(canvas.toDataURL('image/png'), reject));
});
}
function add2canvas(canvas, imageObj) {
return new Promise( (resolve, reject) => {
if (!imageObj || typeof imageObj != 'object') return reject();
var x = imageObj.x && canvas.width ? (imageObj.x >=0 ? imageObj.x : canvas.width + imageObj.x) : 0;
var y = imageObj.y && canvas.height ? (imageObj.y >=0 ? imageObj.y : canvas.height + imageObj.y) : 0;
var image = new Image();
image.onload = function () {
canvas.getContext('2d').drawImage(this, x, y);
resolve();
};
image.src = imageObj.src;
});
}
我想生成由标签和图标组成的图像。标签部分会有很大差异(50-100),而图标大约有 10 个。我想通过将最终图像分成两部分(标签图像和图标图像)以模块化方式制作最终图像。我将为标签构建一个 returns dataURI 服务,而图标 dataURI 将嵌入到页面中。然后我想结合这两个不同的 dataURI 来创建一个代表组合图像的单一 dataURI。
我如何在客户端执行此操作?
您可以使用数据 uri 创建图像,然后使用 canvas
绘制包含这些图像的新图像。这是一个简单的例子:
var nloaded = 0;
function checkload(event) {
nloaded++;
if (nloaded < 2) {
return;
}
var canvas = document.querySelector('canvas');
var context = canvas.getContext('2d');
context.drawImage(image1, 0, 0, 50, 50);
context.drawImage(image2, 50, 50, 100, 100);
var combined = new Image;
combined.src = canvas.toDataURL('data/gif');
document.body.appendChild(combined);
}
var image1 = new Image;
image1.onload = checkload;
image1.src = '';
var image2 = new Image;
image2.onload = checkload;
image2.src = '';
canvas {
display: none;
}
<canvas width=100 height=100></canvas>
.
从数据 URI 加载图像并使用 canvas 上下文的 drawImage
命令组合后,您可以使用 canvas 创建新图像,例如:
var combined = new Image;
combined.src = canvas.toDataURL('data/gif');
不幸的是,这在 IE8 中不起作用。
使用包含 URI 源和 x、y 偏移量的图像对象数组的示例:
var images = [
{ src: '', x: 0, y: 0 },
{ src: '', x: 20, y: 20 },
];
var canvas = document.createElement('canvas');
var destination = document.getElementById('canvas');
Promise.all(images.map(imageObj => add2canvas(canvas, imageObj)))
.then(() => destination.append(canvas));
function add2canvas(canvas, imageObj) {
return new Promise( (resolve, reject) => {
if (!imageObj || typeof imageObj != 'object') return reject();
var image = new Image();
image.onload = function () {
canvas.getContext('2d')
.drawImage(this, imageObj.x || 0, imageObj.y || 0);
resolve();
};
image.src = imageObj.src;
});
}
更多bells/whistles...生成复合png的函数:
function mergeImageURIs(images) {
return new Promise( (resolve, reject) => {
var canvas = document.createElement('canvas');
canvas.width = 1000; // desired width of merged images
canvas.height = 1000; // desired height of merged images
Promise.all(images.map(imageObj => add2canvas(canvas, imageObj))).then(() => resolve(canvas.toDataURL('image/png'), reject));
});
}
function add2canvas(canvas, imageObj) {
return new Promise( (resolve, reject) => {
if (!imageObj || typeof imageObj != 'object') return reject();
var x = imageObj.x && canvas.width ? (imageObj.x >=0 ? imageObj.x : canvas.width + imageObj.x) : 0;
var y = imageObj.y && canvas.height ? (imageObj.y >=0 ? imageObj.y : canvas.height + imageObj.y) : 0;
var image = new Image();
image.onload = function () {
canvas.getContext('2d').drawImage(this, x, y);
resolve();
};
image.src = imageObj.src;
});
}