Canvas 全局不透明度和全局图像重叠设置


全局不透明度

globalAlpha

globalAlpha = 1 (Default)

var canvas = document.getElementById('canvas')
    canvas.width = 1200;
    canvas.height = 800;
    var context = canvas.getContext("2d");

    context.globalAlpha = 0.7; // 设置整个绘制系统的透明度

    for(var i = 0; i < 100; i++){
      var R = Math.floor(Math.random()*255);
      var G = Math.floor(Math.random()*255);
      var B = Math.floor(Math.random()*255);

      context.fillStyle = `rgb(${R}, ${G}, ${B})`

      context.beginPath();
      context.arc(Math.random()*canvas.width, Math.random()*canvas.height, Math.random()*100, 0, 2*Math.PI);
      context.fill();
    }


全局图像重叠

globleCompositeOperation

globleCompositeOperation = "source-over" (Default)

source-over

source-atop

source-in

source-out


destination-over

destination-atop

destination-in

destination-out


lighter
copy
xor


各参数效果演示代码

image-20211014143155391
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    #buttons {width: 1200px; margin: 10px auto; clear: both;}
    #buttons a {font-size: 18px; display: block; float: left; margin-right: 14px;}
  </style>
</head>
<body>
  <canvas id="canvas"></canvas>
  <div id="buttons">
    <a href="">source-over</a>
    <a href="">source-atop</a>
    <a href="">source-in</a>
    <a href="">source-out</a>
    <a href="">destination-over</a>
    <a href="">destination-atop</a>
    <a href="">destination-in</a>
    <a href="">destination-out</a>
    <a href="">lighter</a>
    <a href="">copy</a>
    <a href="">xor</a>
  </div>
  <script>
    draw('source-over');
    let buttons = document.getElementById('buttons').getElementsByTagName('a');
    for(let i = 0; i < buttons.length; i++) {
      buttons[i].onclick = function() {
        draw(this.text);
        return false;
      }
    }
    function draw(compositeStyle) {
      const canvas = document.getElementById('canvas');
      canvas.width = 1200;
      canvas.height = 800;
      const context = canvas.getContext('2d');
      context.clearRect(0, 0, canvas.width, canvas.height);
      // draw title
      context.font = 'bold 40px Arial';
      context.textAlign = 'center';
      context.textBaseline = 'middle';
      context.fillStyle = '#058'
      context.fillText(`globalCompositeOperation = ${compositeStyle}`, canvas.width / 2, 60);

      // draw a rect
      context.fillStyle = 'blue';
      context.fillRect(300, 150, 500, 500);

      // draw a triangle
      context.globalCompositeOperation = compositeStyle;
      context.fillStyle = 'red';
      context.beginPath();
      context.moveTo(700, 250);
      context.lineTo(1000, 750);
      context.lineTo(400, 750);
      context.closePath();
      context.fill();
    }
  </script>
</body>
</html>
posted @ 2021-10-14 14:36  Better-HTQ  阅读(634)  评论(0编辑  收藏  举报