gpt4 book ai didi

javascript - 如何在不使用 image.src 或 image.onload 的情况下将 png base 64 转换为像素数组?

转载 作者:行者123 更新时间:2023-11-30 09:13:34 25 4
gpt4 key购买 nike

我想知道如何在 CSP 不允许的站点上加载 base64。这意味着我们不能做类似的事情:

image.src = "data:image/png;base64..."

所以我想我需要找到一种不同的方法。我尝试将 base64 转换为二进制字符串,然后从中获取包含像素图像数据的 UintArray。

我不知道如何从 loadImage 函数中获取图像,也不知道在获取像素时我做错了什么。

我知道从二进制字符串到像素数组的转换是错误的,base64 必须有某种类型的转换方式,我们大多数人都不知道。

这是我试图解决这个问题的代码:

        var canvas = document.getElementById("canvas");

var imageBase64 = "";

canvas.width = 540;
canvas.height = 360;

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

function loadImage(base64)
{
var binary_string = window.atob(base64.split(",")[1]);
var len = binary_string.length;
var pixels = new Uint8Array(len);

for (var i = 0; i < len; i++)
{
pixels[i] = binary_string.charCodeAt(i);
}

putImageData(ctx, {
data: pixels,
width: 100,
height: 100
}, 0, 0);



var img = new Image();
img.crossOrigin = "Anonymous";

console.log(pixels);

return img;
}

loadImage(imageBase64);

//ctx.drawImage(loadImage(imageBase64), 0, 0);



function putImageData(ctx, imageData, dx, dy, dirtyX, dirtyY, dirtyWidth, dirtyHeight)
{
var data = imageData.data;
var height = imageData.height;
var width = imageData.width;

dirtyX = dirtyX || 0;
dirtyY = dirtyY || 0;
dirtyWidth = dirtyWidth !== undefined ? dirtyWidth : width;
dirtyHeight = dirtyHeight !== undefined ? dirtyHeight : height;

var limitBottom = dirtyY + dirtyHeight;
var limitRight = dirtyX + dirtyWidth;

for (var y = dirtyY; y < limitBottom; y++)
{
for (var x = dirtyX; x < limitRight; x++)
{
var pos = y * width + x;
ctx.fillStyle = 'rgba(' + data[pos * 4 + 0]
+ ',' + data[pos * 4 + 1]
+ ',' + data[pos * 4 + 2]
+ ',' + (data[pos * 4 + 3] / 255) + ')';
ctx.fillRect(x + dx, y + dy, 1, 1);
}
}
}

也许如果我们能找出 base64 的工作原理,那么我们就可以做到。然后:任何帮助,将不胜感激 :)谢谢!

最佳答案

browserify 代码 here generated file (480kB) :

var PNG = require('pngjs').PNG;

function getPNG(bin) {
return PNG.sync.read(bin);
}

function loadImage(base64)
{
var binary_string = Buffer.from(base64, 'base64');

var png = getPNG(binary_string);

return png;
}

window.getPNG = getPNG;
window.loadImage = loadImage;

和片段演示:

<canvas id=canvas></canvas>
<script src="https://pastebin.com/raw/SN2vwZeg"></script>
<script>
var canvas = document.getElementById("canvas");

var imageBase64 = ""

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

var png = loadImage(imageBase64.split(",")[1]);

putImageData(ctx, {
data: png.data,
width: png.width,
height: png.height
}, 0, 0);


function putImageData(ctx, imageData, dx, dy, dirtyX, dirtyY, dirtyWidth, dirtyHeight)
{
var data = imageData.data;
var height = imageData.height;
var width = imageData.width;

dirtyX = dirtyX || 0;
dirtyY = dirtyY || 0;
dirtyWidth = dirtyWidth !== undefined ? dirtyWidth : width;
dirtyHeight = dirtyHeight !== undefined ? dirtyHeight : height;

var limitBottom = dirtyY + dirtyHeight;
var limitRight = dirtyX + dirtyWidth;

for (var y = dirtyY; y < limitBottom; y++)
{
for (var x = dirtyX; x < limitRight; x++)
{
var pos = y * width + x;
ctx.fillStyle = 'rgba(' + data[pos * 4 + 0]
+ ',' + data[pos * 4 + 1]
+ ',' + data[pos * 4 + 2]
+ ',' + (data[pos * 4 + 3] / 255) + ')';
ctx.fillRect(x + dx, y + dy, 1, 1);
}
}
}
</script>

关于javascript - 如何在不使用 image.src 或 image.onload 的情况下将 png base 64 转换为像素数组?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56801191/

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