为了账号安全,请及时绑定邮箱和手机立即绑定

如何在图像中嵌入文本?

如何在图像中嵌入文本?

子衿沉夜 2022-09-29 16:58:26
我想在向用户显示该图像之前在图像中嵌入用户名。就像我有一个图像文件,现在我想把用户名放在图像里面,就像嵌入而不仅仅是放置文本一样。所以文字成为图像的实际部分?你们能不能建议我一个出路,输出schould是一个base64文件,这样我就可以通过api流式传输数据。谢谢。
查看完整描述

1 回答

?
手掌心

TA贡献1942条经验 获得超3个赞

您没有指定您的API服务器正在运行的软件,所以我为您的客户端水印需求编写了此内容。它仅适用于没有透明度的图像。

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

索引.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));

    }

  });

}


查看完整回答
反对 回复 2022-09-29
  • 1 回答
  • 0 关注
  • 107 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信