【问题标题】:Adding a watermark to a canvas that already has an image - HTML5, Canvas向已有图像的画布添加水印 - HTML5、Canvas
【发布时间】:2014-10-13 09:53:09
【问题描述】:

我有一个摄像头视频源和一个画布。

当用户单击提交时,画布会获取提要的图像

     <video id="video" width="300" height="200" autoplay></video>
     </section>
      <section class="btn">
      <button id="btnClick">Submit</button><br>
      </section>

     <section>
      <canvas id="canvas" width="300" height="300">
      </section>

用户点击提交后,可以点击分享上传图片。

        <input type="button" onclick="uploadEx()" value="Share" />

        <form method="post" accept-charset="utf-8" name="form1">
        <input name="hidden_data" id='hidden_data' type="hidden"/>
         </form>

我希望能够在用户通过单击共享按钮提交第一个快照之前在图像顶部覆盖另一个 png。

上传图片的JS:

           function uploadEx() {
            var canvas = document.getElementById("canvas");
            var dataURL = canvas.toDataURL("image/png");
            document.getElementById('hidden_data').value = dataURL;

            var fd = new FormData(document.forms["form1"]);

            var xhr = new XMLHttpRequest();
            xhr.open('POST', 'uploadscript.php', true);

            xhr.upload.onprogress = function(e) {
                if (e.lengthComputable) {
                    var percentComplete = (e.loaded / e.total) * 100;
                    console.log(percentComplete + '% uploaded');
                    alert('Image uploaded');
                }
            };

            xhr.onload = function() {

            };
            xhr.send(fd);
        };

上传时如何在顶部叠加第二张图片(如水印)?

【问题讨论】:

  • @GameAlchemist 知识的好处在于它可以自我更新。如果您将有关水印的知识提供给 Cody Raspien,那么您自己有关水印的知识不会减少。 ;-)

标签: javascript html html5-canvas overlay watermark


【解决方案1】:

这是使用临时画布的一种方法:

  • 创建一个临时的内存画布:document.createElement('canvas')

  • 将主画布绘制到临时画布上:tempContext.drawImage(mainCanvas,0,0)

  • 添加一些重叠文本(或其他内容)作为水印:tempContext.fillText('Mine!',0,0)

  • 获取临时画布的dataURL:tempCanvas.toDataURL()

示例代码和演示:

var canvas=document.getElementById("canvas");
var ctx=canvas.getContext("2d");
var cw=canvas.width;
var ch=canvas.height;

var img=new Image();
img.crossOrigin='anonymous';
img.onload=start;
img.src="https://dl.dropboxusercontent.com/u/139992952/earth.jpg";
function start(){
  canvas.width=img.width;
  canvas.height=img.height;
  ctx.drawImage(img,0,0);
  var dataURL=watermarkedDataURL(canvas,"It's Mine!");
}


function watermarkedDataURL(canvas,text){
  var tempCanvas=document.createElement('canvas');
  var tempCtx=tempCanvas.getContext('2d');
  var cw,ch;
  cw=tempCanvas.width=canvas.width;
  ch=tempCanvas.height=canvas.height;
  tempCtx.drawImage(canvas,0,0);
  tempCtx.font="24px verdana";
  var textWidth=tempCtx.measureText(text).width;
  tempCtx.globalAlpha=.50;
  tempCtx.fillStyle='white'
  tempCtx.fillText(text,cw-textWidth-10,ch-20);
  tempCtx.fillStyle='black'
  tempCtx.fillText(text,cw-textWidth-10+2,ch-20+2);
  // just testing by adding tempCanvas to document
  document.body.appendChild(tempCanvas);
  return(tempCanvas.toDataURL());
}
body{ background-color: ivory; padding:20px;}
canvas{border:1px solid red;}
<canvas id="canvas" width=300 height=300></canvas>
<h2>Watermarked...</h2>

【讨论】:

  • 关于如何将图像添加为水印而不是纯文本的任何想法?
  • drawImage...也许给水印图像提供高对比度和不饱和颜色但不透明度低?实际上,这完全取决于您要使用哪种图像添加水印。 :-)
猜你喜欢
  • 2013-12-09
  • 1970-01-01
  • 2011-07-24
  • 1970-01-01
  • 1970-01-01
  • 2014-12-05
  • 2021-12-31
  • 1970-01-01
  • 2014-01-10
相关资源
最近更新 更多