我之前在网上看过一个插件叫做出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的值。

var width=imagedates.width;
var x=542;
var y=245;
var r=(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;

/*************算法非常easy。关键是要又一次划分鼠标下标以及像素開始的坐标**********/

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

(function(){
var c=document.getElementById("MyCanvas"),
ctx=c.getContext("2d"),
image=new Image();
image.src="1.png";
image.onload=function(){
ctx.drawImage(this,0,0);
}
c.onclick=function(e){
var x=e.clientX,y=e.clientY,x1=this.offsetLeft,y1=this.offsetTop,nowx=x-x1,nowy=y-y1;
var imagedates=ctx.getImageData(nowx,nowy,1,1);
var pixel=imagedates.data;
document.getElementById("color").style["background-color"]="rgb("+pixel[0]+","+pixel[1]+","+pixel[2]+")";
}
})()

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

HTML5 Canvas 获取网页的像素值。的更多相关文章

  1. JavaScript 基于HTML5 canvas 获取文本占用的像素宽度

    基于HTML5 canvas 获取文本占用的像素宽度   by:授客 QQ:1033553122 直接上代码   // 获取单行文本的像素宽度 getTextPixelWith(text, fontS ...

  2. 基于HTML5 Canvas的网页画板实现教程

    HTML5的功能非常强大,尤其是Canvas的应用更加广泛,Canvas画布上面不仅可以绘制任意的图形,而且可以实现多种多样的动画,甚至是一些交互式的应用,比如网页网版.这次我们要来看的就是一款基于H ...

  3. AE IRasterCursor 获取栅格图层像素值

    在编写使用栅格图层的代码时,常常要获取栅格图层的像素值(PixelValue).如果想获取某一点的像素值,可以使用IRaster2中的getPixelValue方法.但如果想要获得的是图层中的某一块甚 ...

  4. HTML5 Canvas 为网页添加文字水印

    <!DOCTYPE html> <html> <body> <canvas id=" style="border:1px solid #d ...

  5. 用HTML5 Canvas为网页添加动态波浪背景

    查看所有代码请去Github 本文出自 “UED” 博客:http://5344794.blog.51cto.com/5334794/1430877 <!DOCTYPE html> < ...

  6. html5 Canvas API

    详细内容请点击 1.HTML Canvas API有两方面优势可以弥补:首先,不需要将所绘制图像中的每个图元当做对象存储,因此执行性能非常好:其次,在其他编程语言现有的优秀二维绘图API的基础上实现C ...

  7. HTML5之Canvas时钟(网页效果--每日一更)

    今天,带来的是使用HTML5中Canvas标签实现的动态时钟效果. 话不多说,先看效果:亲,请点击这里 众所周知,Canvas标签是HTML5中的灵魂,HTML5 Canvas是屏幕上的一个由Java ...

  8. [js高手之路] html5 canvas系列教程 - 像素操作(反色,黑白,亮度,复古,蒙版,透明)

    接着上文[js高手之路] html5 canvas系列教程 - 状态详解(save与restore),相信大家都应该玩过美颜功能,而我们今天要讲的就是canvas强大的像素处理能力,通过像素处理,实现 ...

  9. HTML5 Canvas中实现绘制一个像素宽的细线

    正统的HTML5 Canvas中如下代码 ctx.lineWidth = 1; ctx.beginPath(); ctx.moveTo(10, 100); ctx.lineTo(300,100); c ...

随机推荐

  1. 【BZOJ1010】【HNOI2008】玩具装箱toy (斜率优化DP) 解题报告

    题目: 题目在这里 思路与做法: 这题不难想. 首先我们先推出一个普通的dp方程: \(f_i = min \{ f_j+(i-j-1+sum_i-sum_j-L)^2\}\) 然后就推一推式子了: ...

  2. linux系统在线搭建禅道

    1.先安装wget:yum -y install wget 2.下载安装禅道:[root@zhaowen ~]# wget http://dl.cnezsoft.com/zentao/9.0.1/Ze ...

  3. RabbitMQ(三) 集群配置

    RabbitMQ--集群配置 之前不管是搞Redis.SQL.Mongo还是其他的东西,一律都没说过集群要怎么搞,电脑实在是带不动.说透彻点就是懒,懒得搭也懒得写,今日深刻意识到错误,做学问是不能懒的 ...

  4. poj 1161 Floyd+枚举

    题意是: 给出n个点,围成m个区域.从区域到另一个区域间需穿过至少一条边(若两区域相邻)——边连接着两点. 给出这么一幅图,并给出一些点,问从这些点到同一个区域的穿过边数最小值. 解题思路如下: 将区 ...

  5. oracle scott趣事

    Oracle里面是scott是个什么用户呢? 这个就要追朔到Oracle的创业阶段了, 1977年6月,埃里森,Bob Miner和Ed Oates在硅谷共同创办了一家名为软件开发实验室(Softwa ...

  6. C++程序开发的基本过程

    前两天说去一家小公司实习,被他们的一个技术员工的一个问题问到了,问的我当时都没有反应过来,回来后突然发现这个问题我会啊 ,只是当时没想到这么浅显.现在总结下: C++程序开发的基本过程: 1)编辑 开 ...

  7. CUDA与OpenCL架构

    CUDA与OpenCL架构 目录 CUDA与OpenCL架构 目录 1 GPU的体系结构 1.1 GPU简介 1.2 GPU与CPU的差异 2 CUDA架构 2.1 硬件架构 2.1.1 GPU困境 ...

  8. SQL SERVER数据库状态

    一个SQL SERVER数据库会处于很多种状态,例如 ONLINE .RESTORING .RECOVERING .RECOVERY_PENDING  .SUSPECT.EMERGENCY .OFFL ...

  9. 数组、ArrayList、HashTable

    相同点:都可以存储一组数据 不同点: 1)数组,必须要先分配空间,存储数据固定 2)ArrayList,存储数据可以自由扩展 3)HashTable与ArrayList一样,但是它是有意义的,键值对形 ...

  10. Centos7 执行firewall-cmd –permanent –add-service=mysql报错“ModuleNotFoundError: No module named 'gi'”

    因为目前环境Python3.x与Python2.x版本并存,所以导致以上问题. 解决方法: 第一步,vim  /usr/bin/firewall-cmd, 将#!/usr/bin/python -Es ...