使用HTML5 <canvas>元素,我想加载一个图像文件(PNG, JPEG等),将其完全透明地绘制到画布上,然后将其淡入。我已经弄清楚如何加载图像并将其绘制到画布上,但我不知道如何改变其不透明度。

这是我到目前为止的代码:

var canvas = document.getElementById('myCanvas');
    
if (canvas.getContext)
{
    var c           = canvas.getContext('2d');
    c.globalAlpha   = 0;
    
    var img     = new Image();
    img.onload  = function() {
        c.drawImage(img, 0, 0);
    }
    img.src     = 'image.jpg';
}

有人能给我指出正确的方向吗比如设置一个属性或者调用一个函数来改变透明度?


当前回答

编辑:标记为“正确”的答案是不正确的。

这很容易做到。试试这段代码,把“ie.jpg”换成你手边的任何图片:

<!DOCTYPE HTML>
<html>
    <head>
        <script>
            var canvas;
            var context;
            var ga = 0.0;
            var timerId = 0;
            
            function init()
            {
                canvas = document.getElementById("myCanvas");
                context = canvas.getContext("2d");
                timerId = setInterval("fadeIn()", 100);
            }
            
            function fadeIn()
            {
                context.clearRect(0,0, canvas.width,canvas.height);
                context.globalAlpha = ga;
                var ie = new Image();
                ie.onload = function()
                {
                    context.drawImage(ie, 0, 0, 100, 100);
                };
                ie.src = "ie.jpg";
                
                ga = ga + 0.1;
                if (ga > 1.0)
                {
                    goingUp = false;
                    clearInterval(timerId);
                }
            }
        </script>
    </head>
    <body onload="init()">
        <canvas height="200" width="300" id="myCanvas"></canvas>
    </body>
</html>

键是globalAlpha属性。

在Win7上用IE 9、FF 5、Safari 5和Chrome 12测试。

其他回答

你不能。它是即时模式图形。但是你可以通过在它上面画一个不透明的矩形来模拟它。

如果图像的上方不是恒定的颜色,那么它就会变得相当棘手。在这种情况下,您应该能够使用像素操作方法。在绘制图像之前保存该区域,然后在不透明的情况下将其混合到顶部。

一些使用globalAlpha的简单示例代码:

ctx.save();
ctx.globalAlpha = 0.4;
ctx.drawImage(img, x, y);
ctx.restore();

如果你需要加载img:

var img = new Image();
img.onload = function() {
    ctx.save();
    ctx.globalAlpha = 0.4;
    ctx.drawImage(img, x, y);
    ctx.restore()
};
img.src = "http://...";

注:

将'src'设置在最后,以确保在所有平台上调用onload处理程序,即使图像已经在缓存中。 在保存和恢复之间包装诸如globalAlpha之类的更改(实际上经常使用它们),以确保您不会从其他地方破坏设置,特别是当从事件中调用绘图代码时。

编辑:标记为“正确”的答案是不正确的。

这很容易做到。试试这段代码,把“ie.jpg”换成你手边的任何图片:

<!DOCTYPE HTML>
<html>
    <head>
        <script>
            var canvas;
            var context;
            var ga = 0.0;
            var timerId = 0;
            
            function init()
            {
                canvas = document.getElementById("myCanvas");
                context = canvas.getContext("2d");
                timerId = setInterval("fadeIn()", 100);
            }
            
            function fadeIn()
            {
                context.clearRect(0,0, canvas.width,canvas.height);
                context.globalAlpha = ga;
                var ie = new Image();
                ie.onload = function()
                {
                    context.drawImage(ie, 0, 0, 100, 100);
                };
                ie.src = "ie.jpg";
                
                ga = ga + 0.1;
                if (ga > 1.0)
                {
                    goingUp = false;
                    clearInterval(timerId);
                }
            }
        </script>
    </head>
    <body onload="init()">
        <canvas height="200" width="300" id="myCanvas"></canvas>
    </body>
</html>

键是globalAlpha属性。

在Win7上用IE 9、FF 5、Safari 5和Chrome 12测试。

设置全局Alpha绘制具有不透明度的对象,然后将其设置为正常。

//////////////////////// 圆 /////////////////////// ctx。globalAlpha = 0.75; ctx.beginPath (); ctx。圆弧(x1, y1, r1, 0, Math.PI*2); ctx。fillStyle =颜色; ctx.fill (); ctx.closePath (); ctx。globalAlpha = 1;

这个建议是基于canvas 2d上下文中的像素操作。

中数:

您可以在字节级别上直接操作画布中的像素数据

为了操作像素,我们将在这里使用两个函数——getImageData和putImageData。

getImageData usage:

var myImageData = context.getImageData(left, top, width, height);

putImageData语法:

context.putImageData(myImageData, x, y); 

context是你的canvas 2d context, x和y是在画布上的位置。

为了得到红色、绿色、蓝色和alpha值,我们将执行以下操作:

var r = imageData.data[((x*(imageData.width*4)) + (y*4))];
var g = imageData.data[((x*(imageData.width*4)) + (y*4)) + 1];
var b = imageData.data[((x*(imageData.width*4)) + (y*4)) + 2];
var a = imageData.data[((x*(imageData.width*4)) + (y*4)) + 3];

其中x是水平偏移量,y是垂直偏移量。

使图像半透明的代码:

var canvas = document.getElementById('myCanvas');
var c = canvas.getContext('2d');
var img = new Image();
img.onload  = function() {
   c.drawImage(img, 0, 0);
   var ImageData = c.getImageData(0,0,img.width,img.height);
   for(var i=0;i<img.height;i++)
      for(var j=0;j<img.width;j++)
         ImageData.data[((i*(img.width*4)) + (j*4) + 3)] = 127;//opacity = 0.5 [0-255]
   c.putImageData(ImageData,0,0);//put image data back
}
img.src = 'image.jpg';

你可以制作你自己的“着色器”-在这里看到完整的MDN文章