我一直在尝试使用 canvas 元素,并且很好奇如何实现效果。
我从一系列教程和演示中找到了我想要的东西,但我需要一些帮助才能完成剩下的工作。我正在寻找的是在 上对图像进行像素化mouseover,然后在 上重新聚焦/取消像素化mouseout。将鼠标悬停在主转盘下方的块上时,您可以在http://www.cropp.com/ 上看到一个很好的效果示例。
这是我开始的小提琴的链接。小提琴不起作用,因为您不能使用跨域图像(womp womp),但到目前为止您仍然可以看到我的代码。将鼠标悬停在我的画布对象上时,我可以对图像进行像素化,但这与我想要获得的效果有点倒退。任何帮助或建议将不胜感激。
var pixelation = 40,
    fps = 120,
    timeInterval = 1000 / fps, 
    canvas = document.getElementById('photo'),
    context = canvas.getContext('2d'),
    imgObj = new Image();
imgObj.src = 'images/me.jpg';
imgObj.onload = function () {    
    context.drawImage(imgObj, 0, 0);
};
canvas.addEventListener('mouseover', function() {
    var interval = setInterval(function () {
        context.drawImage(imgObj, 0, 0);
        if (pixelation < 1) {
            clearInterval(interval);
            pixelation = 40;
        } else {
            pixelate(context, canvas.width, canvas.height, 0, 0);
        }
    }, timeInterval);
});
function pixelate(context, srcWidth, srcHeight, xPos, yPos) {
    var sourceX = xPos,
        sourceY = yPos,
        imageData = context.getImageData(sourceX, sourceY, srcWidth, srcHeight),
        data = imageData.data;
    for (var y = 0; y < srcHeight; y += pixelation) {
        for (var x = 0; x < srcWidth; x += pixelation) {
            var red = data[((srcWidth * y) + x) * 4],
                green = data[((srcWidth * y) + x) * 4 + 1],
                blue = data[((srcWidth * y) + x) * 4 + 2];
            for (var n = 0; n < pixelation; n++) {
                for (var m = 0; m < pixelation; m++) {
                    if (x + m < srcWidth) {
                        data[((srcWidth * (y + n)) + (x + m)) * 4] = red;
                        data[((srcWidth * (y + n)) + (x + m)) * 4 + 1] = green;
                        data[((srcWidth * (y + n)) + (x + m)) * 4 + 2] = blue;
                    }
                }
            }
        }
    }
    // overwrite original image
    context.putImageData(imageData, xPos, yPos);
    pixelation -= 1;
}