HTML5 Canvas 获取网页的像素值。

我之前在网上看过一个插件叫做出JScolor  颜色拾取器  说白了就是通过1*1PX的DOM设置颜色值通过JS来获取当前鼠标点击位置DOM的颜色值。

自从HTML5 画布出来之后。就有更好的方法来获取了,比如郭阿里巴巴ICON矢量库用的SVG和渐变来进行绘制:

我昨天用Canvas来绘制了一下,因为Canvas有现成的方法getImageData(x,y,width,height);这个方法返回一个属性data数组,也就是CanvasPixelArray

1个像素分别有四个值rgba(红,绿,蓝,阿尔法值); 1个像素就有这4个值,意味着CanvasPixelArray里面每个像素值就占了个位置简称4X(下同)。

CanvasPixelArray的排序要简单,从左上角到右下角。长度也简单4X。比如说width*height*4.比如:3*3像素CanvasPixelArray有多少个值。3*3*4=36值。

有一点说明一下,关系到我们下面说的:像素值是从1开始。但是数组的索引值是从0开始的,所以我们刚刚说的3*3像素CanvasPixelArray长度是36位。。

但是第3*3像素它的颜色值 是[....,32,33,34,35]。索引值 需要减去4开始。道理就是像素开始的坐标是1*1.但是数组是0。

第3*3像素位置的下标开始Star和结束end我们可以脑袋想想就出来。但是如果第542*245像素的值我们怎么算。当然了,如果你是天才脑袋的话。我下面的

算法可以无视:

以下算法的借鉴来自于程序出版之家:图灵程序设置的《HTML5 Canvas教程》。

像素值:rgba在CanvasPixelArray里面的排序也是红(r),跟着是绿(g),蓝(b),阿尔法(a);根据这个规律,我也只要得到红(r),然后再以此+1,+2,+3(来获取剩下的值)

而恰好红(r)是目标像素再CanvasPixelArray的stat位置。也就是我们要获取开始的位置,剩下的就OK了。

比如是我们要获取上面542*245的值。

[html]view plaincopy

varwidth=imagedates.width;

varx=542;

vary=245;

varr=(y-1)*(width*4)+(x*4)-4);

y-1上面说过了。数组的下标是0开始的。width*4获取了1行在CanvasPixelArray有多少个像素值.*(y-1)得到了在y行第一列的像素值开始下标。下面是列了542了

(x*4)-4得到了到了距离第一列之前有多少位像素值的长度。然后相加。就到了目标像素的其实位置 红色(r)

红色出来了。其他的就更加简单了。s

g=r+1;

b=r+2;

a=r+3;

/*************算法很简单。关键是要重新划分鼠标下标以及像素开始的坐标**********/

通过上面的我们就可以做一个颜色拾取器了:

[html]view plaincopy

(function(){

varc=document.getElementById("MyCanvas"),

ctx=c.getContext("2d"),

image=newImage();

image.src="1.png";

image.onload=function(){

ctx.drawImage(this,0,0);

}

c.onclick=function(e){

varx=e.clientX,y=e.clientY,x1=this.offsetLeft,y1=this.offsetTop,nowx=x-x1,nowy=y-y1;

varimagedates=ctx.getImageData(nowx,nowy,1,1);

varpixel=imagedates.data;

document.getElementById("color").style["background-color"]="rgb("+pixel[0]+","+pixel[1]+","+pixel[2]+")";

}

})()

有一点需要注意的是image.src需要和文件同源。这样才能有效执行下面的代码,不然会报错的。此外以上代码需要在服务器环境运行。本地测试data会返回[0,0,0,0];

来源http://blog.csdn.net/u011551941/article/details/46762245

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容

  • 一、实验目的 学习使用 weka 中的常用分类器,完成数据分类任务。 二、实验内容 了解 weka 中 explo...
    yigoh阅读 8,524评论 5 4
  • SwiftDay011.MySwiftimport UIKitprintln("Hello Swift!")var...
    smile丽语阅读 3,830评论 0 6
  • 信息偏倚 现在是信息爆炸的时代,那么信息多,对我们的帮助就越大吗?现在其实是个垃圾信息横飞的时代。 真的需要那么...
    k承龙阅读 558评论 5 49
  • 使用工具:webstorm 2016.3.5;先配置下vue环境:vue开发环境搭建验证环境搭建好了,执行下(np...
    张中华阅读 3,642评论 0 2
  • 不经历生死,无以成长。
    willmodesty阅读 69评论 0 0