javascript – 默认Android浏览器上的图像alpha

前端之家收集整理的这篇文章主要介绍了javascript – 默认Android浏览器上的图像alpha前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我试图将图像变成双色并将其贴在画布上.

适用于桌面浏览器:

> Chrome
> Firefox
> Safari
> Internet Explorer

移动浏览器失败:

> Android

Workable demo on JSFiddle,此示例适用于Chrome,但在Android的默认浏览器中失败.

代码是:

摘要是:

>将背景颜色设置为灰色,以便更容易观察到alpha
>创建64乘64的画布
>在透明背景上加载笑脸图像
>将图像绘制到画布上
>获取图像的数据
>对于每个像素,使红色更强
>替换画布上的更改图像

笑脸看起来像这样(块引用,所以你可以告诉它是透明的):

但是,与chrome和android浏览器相比,

android绘图的背景是红色的,而chrome绘图是完全透明的.

所以…

>这里发生了什么?
>如何更改代码以使android绘图与chrome绘图匹配?

注意:我已经尝试过if(像素[索引3] == 0)继续;并且我知道这一点,但它不适用于具有不同不透明度的图像.

最佳答案
好的,我有一个result.

首先看看你的循环:

for (var i = 0; i < numPixels; i++) { //for every pixel in the image
     var index = i * 4;

index将比numPixels大3倍以上.并将获得未定义的值.平均值是NaN.但是,我解决了这个问题 – 结果是一样的.

所以我尝试对每个像素使用fillStyle和fillRect.一切都变好了.我的code

function putImageData(ctx,imageData,dx,dy,dirtyX,dirtyY,dirtyWidth,dirtyHeight) {
    var data = imageData.data;
    var height = imageData.height;
    var width = imageData.width;

    dirtyX = dirtyX || 0;
    dirtyY = dirtyY || 0;
    dirtyWidth = dirtyWidth !== undefined ? dirtyWidth : width;
    dirtyHeight = dirtyHeight !== undefined ? dirtyHeight : height;

    var limitBottom = dirtyY + dirtyHeight;
    var limitRight = dirtyX + dirtyWidth;

    for (var y = dirtyY; y < limitBottom; y++) {
        for (var x = dirtyX; x < limitRight; x++) {
            var pos = y * width + x;
            //adding red increased here
            ctx.fillStyle = 'rgba(' + data[pos * 4 + 0] + 255 + ',' + data[pos * 4 + 1] + ',' + data[pos * 4 + 2] + ',' + (data[pos * 4 + 3] / 255) + ')';
            ctx.fillRect(x + dx,y + dy,1,1);
        }
    }
};

var image = new Image();
image.src = '';

image.onload = function () {
    var context = document.getElementById("mycanvas").getContext("2d"),imageData;

    context.drawImage(image,0);
    imageData = context.getImageData(0,64);

    putImageData(context,0);
}
原文链接:https://www.f2er.com/android/431109.html

猜你在找的Android相关文章