gpt4 book ai didi

javascript - 将 base64 图像拆分为多个部分

转载 作者:搜寻专家 更新时间:2023-11-01 04:08:52 24 4
gpt4 key购买 nike

我正在尝试使用 javascript 或 jquery 将图像文件分成四个相等的部分。是否可以将280px x 60px这样的图片分成四等份,然后用base64编码保存到四个变量中?

最佳答案

假设我们有一个像这样的 Base64 图像:

slice split cut image into parts using canvas, HTML5

让我们去获取那 4 张图片吧!

get image parts from whole image using Canvas, Javascript


  1. 创建一个内存中的 canvas 元素并准备它的上下文:

var canvas = document.createElement('canvas');
var ctx = canvas.getContext("2d");

  1. 然后让我们准备一个空数组来稍后存储我们的 base64 字符串:

var parts = [];

  1. 现在我们需要创建一个 图像,分配一个onload 函数并将其设置为src:

var img = new Image();
img.onload = split_4;
img.src = ".......................etc"

  1. split_4函数:

如果我们需要切片的图像是260×80意味着我们需要将我们的canvas元素设置为该尺寸的1/4 :

var w2 = img.width  / 2,  // 130
h2 = img.height / 2; // 40

canvas.width = w2;
canvas.height = h2;

  1. 绘制我们的 Canvas 4 次,每次将我们的图像移动到新的 XY 位置:

//      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>

关于javascript - 将 base64 图像拆分为多个部分,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25463416/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com