我正在尝试将带有javascript或jquery的图像文件分成四个相等的部分。 是否可以将像280px x 60px这样的图像分成四个相等的部分,并将它们用base64编码保存为四个变量?
答案 0 :(得分:5)
假设我们有一个Base64图像,如:
让我们去拍摄这4张照片!
var canvas = document.createElement('canvas');
var ctx = canvas.getContext("2d");
var parts = [];
var img = new Image();
img.onload = split_4;
img.src = ".......................etc"
如果 slice 所需的图像 260×80 意味着我们需要将 canvas 元素设置为1/4那么大:
var w2 = img.width / 2, // 130
h2 = img.height / 2; // 40
canvas.width = w2;
canvas.height = h2;
// 0 0 1.iteration
// -130 0 2.iteration
// 0 -40 3.iteration
// -130 -40 4.iteration
在每次循环迭代中,我们只需将检索到的Canvas数据推送到我们的parts
数组中:
for(var i=0; i<4; i++){
var x = (-w2*i) % (w2*2), // New X position
y = (h2*i)<=h2? 0 : -h2 ; // New Y position
ctx.drawImage(this, x, y, w2*2, h2*2); // imgObject, X, Y, width, height
parts.push( canvas.toDataURL() ); // ("image/jpeg") for jpeg
}
现在总是在onload
函数内部,您可以从数组中检索所有图像部分:
console.log( parts ); // ["...z9d/oBHAAAAAElFTkSuQmCC",
// "...yVhNNW1AAAAAElFTkSuQmCC",
// "...Q2FoAAAAABJRU5ErkJggg==",
// "...RQXgXQAAAAASUVORK5CYII="]
仅获取(即)使用第一张图片:parts[0];
var canvas = document.createElement('canvas'), // In memory canvas
ctx = canvas.getContext("2d"),
parts = [], // to push into oud base64 strings
img = new Image();
function split_4() {
var w2 = img.width / 2,
h2 = img.height / 2;
for (var i = 0; i < 4; i++) {
var x = (-w2 * i) % (w2 * 2),
y = (h2 * i) <= h2 ? 0 : -h2;
canvas.width = w2;
canvas.height = h2;
ctx.drawImage(this, x, y, w2 * 2, h2 * 2); // img, x, y, w, h
parts.push(canvas.toDataURL()); // ("image/jpeg") for jpeg
//>> JUST FOR DEMO
var slicedImage = document.createElement("img")
slicedImage.src = parts[i];
var div = document.getElementById("test");
div.appendChild(slicedImage);
//<< JUST FOR DEMO
}
console.log(parts);
};
img.onload = split_4;
img.src = "";
img {
margin: 10px;
}
<div id="test"></div>