HTML5_canvas_像素操作_图片马赛克_图片反相
canvas 像素操作
像素,即像素点,一个像素只有一个颜色
100*100 的 px 的屏幕区域有 100*100*4 个像素点,即 width*height*4
rgba(0, 0, 0, 1); 在 css 中透明的范围为 0-1
rgba(0, 0, 0, 255); 在 canvas 中透明的范围也为 0-255
读取空白画布的像素点,为黑色透明色 (0, 0, 0, 0)____即使画布设置颜色为 red
所以,一般读取 绘画 的像素点
- 读取已有像素,改写后再绘制
// 1. 读取矩形像素信息 参数1,参数2 矩形左上角坐标
var imgData = pen.getImageData(100, 100, 100, 100); 参数3,参数4 矩形的 width 和 height
// 2. 改变像素
for(var i=0; i<imgData.data.length; i++){
imgData.data[4*i+0] = 144;
imgData.data[4*i+1] = 144;
imgData.data[4*i+2] = 144;
imgData.data[4*i+3] = 144;
}
// 3. 将改变的像素数组,绘制带画布 (100, 100) 区域
pen.putImageData(imgData, 100, 100);
- 自建一个像素数据数据,改写后绘制
// 1. 创建像素对象 返回的像素数组,也是黑色透明色 (0, 0, 0, 0);
var imgData = pen.createImagData(100, 100);
// 2. 改变像素信息
for(var i=0; i<imgData.length; i++){
imgData.data[4*i+0] = 14;
imgData.data[4*i+1] = 164;
imgData.data[4*i+2] = 154;
imgData.data[4*i+3] = 255;
}
// 3. 写入已改变像素点 数组
pen.putImageData(imgData, 100, 100);
单个像素写入操作 (封装)
1. 获取画布所有像素点的信息
var imgData = pen.getImageData(0, 0, myCanvas.width, myCanvas.height);
2. 设置 (99, 99) 点 为 蓝色
setPxInfo(imgData, 99, 99, [0, 0, 255, 0]);
3. 函数封装
function setColorPos(imgArr, x, y, rgba){
imgArr.data[(imgArr.width*y+x)*4+0] = rgba[0];
imgArr.data[(imgArr.width*y+x)*4+1] = rgba[1];
imgArr.data[(imgArr.width*y+x)*4+2] = rgba[2];
imgArr.data[(imgArr.width*y+x)*4+3] = rgba[3];
};
读取单个像素颜色操作 (封装)
1. 获取画布所有像素点的信息
var imgData = pen.getImageData(0, 0, myCanvas.width, myCanvas.height);
2. 设置 (99, 99) 点 为 蓝色
getPxInfo(imgData, 99, 99);
3. 函数封装
function getColorPos(imgArr, x, y){
var rgba = [];
rgba[0] = imgArr.data[(imgArr.width*y+x)*4+0];
rgba[1] = imgArr.data[(imgArr.width*y+x)*4+1];
rgba[2] = imgArr.data[(imgArr.width*y+x)*4+2];
rgba[3] = imgArr.data[(imgArr.width*y+x)*4+3]; return rgba;
};
图片马赛克处理 案例

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<title></title> <link rel="stylesheet" type="text/css" href="./css/index.css" /> <script type="text/javascript" src="./js/kjfFunctions.js"></script>
<script type="text/javascript" src="./js/index.js"></script> <style type="text/css">
body {
width: 100%;
color: #000;
background: #96b377;
font: 14px Helvetica, Arial, sans-serif;
} #wrap {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
</style>
</head> <body> <div id="wrap"></div> <!-- javascript 代码 -->
<script type="text/javascript">
// 创建 画布的width 画布的height 背景颜色 父元素
function createCanvasTo(canvasWidth, canvasHeight, bgColor, parentObj){
var myCanvas = document.createElement("canvas");
myCanvas.width = canvasWidth;
myCanvas.height = canvasHeight;
myCanvas.innerText = " 您的浏览器不支持 canvas,建议更新或者更换浏览器。";
if(bgColor){
myCanvas.style.backgroundColor = bgColor;
};
if(parentObj){
parentObj.appendChild(myCanvas);
}; return myCanvas;
}; var wrap = document.getElementById("wrap");
var myCanvas = createCanvasTo(1040, 480, "#eee", wrap); // 获取画笔
var pen = myCanvas.getContext("2d");
pen.fillStyle = 'olive'; // 填充的颜色
pen.strokeStyle = "blue"; // 笔的颜色
pen.lineWidth = 4; // 笔宽
pen.lineCap = "round"; // 圆形结束
pen.lineJoin = "round"; // 圆角 // 开始绘制
var imgObj = new Image();
imgObj.src = "./img/Nick.jpg";
imgObj.onload = function(){
pen.drawImage(imgObj, 0, 0, 520, 480); var imgData = pen.getImageData(0,0,520,480); size = 5;
var i = 0,
j = 0,
a = 0,
b = 0;
for(i=0; i<imgData.width; i++){
for(j=0; j<imgData.height; j++){
var colorPoint = getColorPos( imgData,
Math.floor(i*size+Math.random()*size),
Math.floor(j*size+Math.random()*size)); for(a=0; a<size; a++){
for(b=0; b<size; b++){
setColorPos(imgData, i*size+a, j*size+b, colorPoint);
};
};
};
};
pen.putImageData(imgData, 520, 0);
}; function getColorPos(imgArr, x, y){
var rgba = [];
rgba[0] = imgArr.data[(imgArr.width*y+x)*4+0];
rgba[1] = imgArr.data[(imgArr.width*y+x)*4+1];
rgba[2] = imgArr.data[(imgArr.width*y+x)*4+2];
rgba[3] = imgArr.data[(imgArr.width*y+x)*4+3]; return rgba;
}; function setColorPos(imgArr, x, y, rgba){
imgArr.data[(imgArr.width*y+x)*4+0] = rgba[0];
imgArr.data[(imgArr.width*y+x)*4+1] = rgba[1];
imgArr.data[(imgArr.width*y+x)*4+2] = rgba[2];
imgArr.data[(imgArr.width*y+x)*4+3] = rgba[3];
}; </script>
</body>
</html>
图片反相处理

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<title>图片反相</title> <style type="text/css">
body {
width: 100%;
color: #000;
background: #96b377;
font: 14px Helvetica, Arial, sans-serif;
} #wrap {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
</style>
</head> <body> <div id="wrap"></div> <!-- javascript 代码 -->
<script type="text/javascript">
// 创建 画布的width 画布的height 背景颜色 父元素
function createCanvasTo(canvasWidth, canvasHeight, bgColor, parentObj){
var myCanvas = document.createElement("canvas");
myCanvas.width = canvasWidth;
myCanvas.height = canvasHeight;
myCanvas.innerText = " 您的浏览器不支持 canvas,建议更新或者更换浏览器。";
if(bgColor){
myCanvas.style.backgroundColor = bgColor;
};
if(parentObj){
parentObj.appendChild(myCanvas);
}; return myCanvas;
}; var wrap = document.getElementById("wrap");
var myCanvas = createCanvasTo(520*3, 480, "#eee", wrap); var imgObj = new Image();
imgObj.src = "./img/Nick.jpg";
imgObj.onload = function(){
var pen = myCanvas.getContext("2d");
pen.drawImage(imgObj, 0, 0, 520, 480);
pen.drawImage(imgObj, 520, 0, 520, 480); var pxObj = pen.getImageData(520+100, 100, 100, 160);
setColorInversion(pxObj);
pen.putImageData(pxObj, 520+100, 100); pxObj = pen.getImageData(0, 0, 520, 480);
setColorInversion(pxObj);
pen.putImageData(pxObj, 520*2, 0);
}; function setColorInversion(pxObj){
var i = 0;
var j = 0;
for(i=0; i<pxObj.width; i++){
for(j=0; j<pxObj.height; j++){
pxObj.data[(pxObj.width*j+i)*4+0] = 255 - pxObj.data[(pxObj.width*j+i)*4+0];
pxObj.data[(pxObj.width*j+i)*4+1] = 255 - pxObj.data[(pxObj.width*j+i)*4+1];
pxObj.data[(pxObj.width*j+i)*4+2] = 255 - pxObj.data[(pxObj.width*j+i)*4+2];
pxObj.data[(pxObj.width*j+i)*4+3] = 150;
};
};
};
</script>
</body>
</html>
HTML5_canvas_像素操作_图片马赛克_图片反相的更多相关文章
- HTML5_canvas_图片加载_双缓冲_跳帧闪烁问题
canvas 图片加载 pen.drawImage(ele, showX, showY, imgWidth, imgHeight); ele 将 img 元素 加载到画布上 步骤 1. 创建一个 ...
- CLOSE-UP FORMALWEAR_意大利进口_2015秋冬_男装发布会_西装图片系列_男装西装设计资料_WeArTrends时尚资讯网_国内最专业的服装设计资讯网站
CLOSE-UP FORMALWEAR_意大利进口_2015秋冬_男装发布会_西装图片系列_男装西装设计资料_WeArTrends时尚资讯网_国内最专业的服装设计资讯网站 CLOSE-UP FORMA ...
- PHP图片裁剪_图片缩放_PHP生成缩略图
在制作网页过程中,为了排版整齐美观,对网页中的图片处理成固定大小尺寸的图片,或是要截去图片边角中含有水印的图片,对于图片量多,每天更新大量图,靠人工PS处理是不现实的,那么有没有自动处理图片的程序了! ...
- 基于HTML5 Canvas实现的图片马赛克模糊特效
效果请点击下面网址: http://hovertree.com/texiao/html5/1.htm 一.开门见山受美国肖像画家Chuck Close的启发,此脚本通过使用HTML5 canvas元素 ...
- 2.4.5 用NPOI操作EXCEL--插入图片
我们知道,在Excel中是可以插入图片的.操作菜单是“插入->图片”,然后选择要插入图片,可以很容易地在Excel插入图片.同样,在NPOI中,利用代码也可以实现同样的效果.在NPOI中插入图片 ...
- JAVA之旅(二十六)——装饰设计模式,继承和装饰的区别,LineNumberReader,自定义LineNumberReader,字节流读取操作,I/O复制图片
JAVA之旅(二十六)--装饰设计模式,继承和装饰的区别,LineNumberReader,自定义LineNumberReader,字节流读取操作,I/O复制图片 一.装饰设计模式 其实我们自定义re ...
- PPT导出图片质量太差?简单操作直接导出印刷质地图片
PPT导出图片质量太差?简单操作直接导出印刷质地图片 PPT不仅可以用于展示文档,还可以用于简单图片合成处理,同时,PPT文档还可以全部导出为图片. 默认情况下,PPT导出的图片为96DPI ...
- Java学习笔记——IO操作之以图片地址下载图片
以图片地址下载图片 读取给定图片文件的内容,用FileInputStream public static byte[] mReaderPicture(String filePath) { byte[] ...
- Spring_MVC_教程_快速入门_深入分析
Spring MVC 教程,快速入门,深入分析 博客分类: SPRING Spring MVC 教程快速入门 资源下载: Spring_MVC_教程_快速入门_深入分析V1.1.pdf Spring ...
随机推荐
- SpringCloud笔记二:搭建项目基础框架
目录 搭建框架 新建父工程 新建子工程api 新建子工程提供者provider 新建消费者consumer 总结 搭建框架 我们的SpringCloud微服务框架是父子工程,有一个父工程,剩下的都是子 ...
- ArcGis Classic COM Add-Ins插件开发的一般流程 C#
COM add-ins是我对这种开发方式的称呼,Esri的官方文档里称其为“Extending ArcObject”或者“Classic COM extensibility”,Esri所称的addin ...
- JDBC Template
JDBC Template 1. Spring JDBC Spring框架对JDBC的简单封装,提供了一个JDBCTemplate对象用来简化JDBC的开发 步骤: 导入jar包 创建JDBCTemp ...
- [再寄小读者之数学篇](2014-06-26 Logarithmical Sobolev inequality using BMO space)
$$\bex q>3\ra \sen{\n f}_{L^\infty} \leq C(q)\sez{ 1+\sen{\n f}_{BMO} \ln^\frac{1}{2}\sex{e+\sen{ ...
- Android App性能测试之一:简介
1.性能测试 启动时间,主要测试App在启动过程中的耗时情况 CPU, 主要测试App在使用过程中的CPU占比率 流量,主要测试App在使用过程中对流量的消耗情况 电量,主要测试App在使用过程中对电 ...
- java包
首先是java.io java.lang java.util java.lang.math
- warning: ISO C++ forbids converting a string constant to 'char*' [-Wwrite-strings]
在C++中, char* p = "abc"; // valid in C, invalid in C++ 会跳出警告:warning: ISO C++ forbids conve ...
- 肺结节CT影像特征提取(三)——肺结节CT影像特征提取系统软件设计
肺结节的特征提取在临床中有着重要应用,在上篇文章已经对肺结节的基本特征和CT影像特征提取算法有了介绍,提出了三类肺结节CT影像特征提取算法.本文重点介绍肺结节CT影像特征提取系统的功能介绍及使用,利用 ...
- django/python日志logging 的配置以及处理
日志在程序开发中是少不了的,通过日志我们可以分析到错误在什么地方,有什么异常.在生产环境下有很大的用处.在java 开发中通常用 log4j,logback 等三方组件.那么在 django中是怎么处 ...
- python正则表达式--特殊字符
正则表达式—特殊表达式含义 正则表达式的字母和数字表示他们自身,但多数字母和数字前加一个反斜杠时会拥有不同的含义. 下面列出了正则表达式模式语法中的特殊元素. 1.普通字符集 1) \w ...