如何在图片里面嵌入文字?

问题描述 投票:-1回答:1

我想把用户名嵌入到图片中,然后再把图片展示给用户,比如我有一个图片文件,现在我想把用户名放在图片中,这就像嵌入而不只是把文本。所以,文字就成了图像的实际部分了吗?你们能不能给我提个建议,输出的schould是个base64文件,这样我就可以通过api流式传输数据了.谢谢。

javascript html node.js
1个回答
0
投票

你没有说明你的API服务器运行的是什么软件,所以我写道 这个 以满足您在客户端的水印需求。 它只适用于没有透明度的图像。

它是LSB(最小有效位)编码的实现。

index.html

<!DOCTYPE html>
<script src="index.js"></script>

<body>
</body>
<script>
  (async () => {
    const base64 = ``;
    const watermark = await createWatermark(base64, 'John Doe');

    const image = new Image();
    image.src = watermark;
    document.body.appendChild(image); // displays watermarked image on screen

    const hiddenText = await readWatermark(watermark, 8);
    console.log(hiddenText); // John Doe
  })();
</script>

</html>

索引.js

function stringToBits(string) {
  return string.split('')
    .map(char => char.charCodeAt(0))
    .map(int => (int).toString(2).padStart(8, '0').split(''))
    .flat()
    .map(n => +n);
}

function bitsToString(bits) {
  bits = [...bits.map(n => getBit(n, 0))];
  return String.fromCharCode(...Array(Math.ceil(bits.length / 8))
    .fill()
    .map(() => bits.splice(0, 8))
    .map(arr => parseInt(arr.join(''), 2)));
}

function setBit(number, bitPosition, sign) {
  if (sign) return number | (1 << bitPosition);
  const mask = ~(1 << bitPosition);
  return number & mask;
}


function getBit(number, bitPosition) {
  return (number & (1 << bitPosition)) === 0 ? 0 : 1;
}

function createWatermark(imageAsBase64, text) {
  return new Promise(resolve => {
    const image = new Image();
    image.src = imageAsBase64;
    image.onload = () => {
      const canvas = document.createElement('canvas');
      canvas.width = image.width;
      canvas.height = image.height;
      const context = canvas.getContext('2d');
      context.drawImage(image, 0, 0);
      const imageData = context.getImageData(0, 0, canvas.width, canvas.height);
      const bits = stringToBits(text);
      for (let i = 0; i < text.length * 8; i += 4) {
        imageData.data[i] = setBit(imageData.data[i], 0, bits[i]);
        imageData.data[i + 1] = setBit(imageData.data[i + 1], 0, bits[i + 1]);
        imageData.data[i + 2] = setBit(imageData.data[i + 2], 0, bits[i + 2]);
        imageData.data[i + 3] = setBit(imageData.data[i + 3], 0, bits[i + 3]);
      }
      context.putImageData(imageData, 0, 0);
      resolve(canvas.toDataURL());
    }
  });
}

function readWatermark(base64, textLength) {
  return new Promise(resolve => {
    const image = new Image();
    image.src = base64;
    image.onload = () => {
      const canvas = document.createElement('canvas');
      canvas.width = image.width;
      canvas.height = image.height;
      const context = canvas.getContext('2d');
      context.drawImage(image, 0, 0);
      const imageData = context.getImageData(0, 0, canvas.width, canvas.height);
      const bits = imageData.data.slice(0, textLength * 8);
      resolve(bitsToString(bits));
    }
  });
}
© www.soinside.com 2019 - 2024. All rights reserved.