欢迎您访问我爱IT技术网,今天小编为你分享的javascript教程:【通过javascript把图片转化为字符画】,下面是详细的讲解!
通过javascript把图片转化为字符画
通过javascript把图片转化为字符画
1.获取上传图片对象数据
Javascript无法直接获取本地上传的图片的数据,html5可以解决这一问题 。html5里面的FileReader interface可以把图片对象的数据读到内存,然后通过接口的进度事件(Progress Events)访问这些数据。
浏览器支持:
1、Internet Explorer: 10+
2、Firefox: 10+
3、Chrome: 13+
4、Opera: 12+
5、Safari: partial
var reader=new FileReader(); //建立一个FileReader接口
reader.readAsDataURL(fileBtn.files[0]); //fileBtn为文件上传控件对象
reader.onload=function () { //在onload事件中访问图像数据
img.src=http://www.jb51.net/article/reader.result; }
2.获取图像对象像素点
图像对象的getImageData 方法返回一个对象,每个像素点的 rgba 值都保存在其 data 属性下面,这是一个一位数组, 也就是说,rgba 分别对应一个值,然后接着就是一下像素点的 rgba,假设 getImageData.data 的值为 [1,2,3,4,5,6,7,8], 那么 getImageData 对象范围就包含了 2 个像素点,第一个像素点的 rgba 值分别是 1,2,3,4,第二个像素点的就是 4,5,6,7,8。 因此,我们在取每个像素点的 rgba 值的时候其index 应该在像素点的索引值上乘以 4,然后通过 getGray() 计算灰度。
var imgData=c.getImageData(0, 0, img.width, img.height);
var imgDataArr=imgData.data;
var imgDataWidth=imgData.width;
var imgDataHeight=imgData.height;
for (h=0; h < imgDataHeight; h +=12) {
for (w=0; w < imgDataWidth; w +=6) {
var index=(w + imgDataWidth * h) * 4;
var r=imgDataArr[index + 0];
var g=imgDataArr[index + 1];
var b=imgDataArr[index + 2];
}
}
3.根据rgb值计算灰度
不同的RGB空间,灰阶的计算公式有所不同,常见的几种RGB空间的计算灰阶的公式如下:
1、简化 sRGB IEC61966-2.1 [gamma=2.20]
Gray=(R^2.2 * 0.2126 + G^2.2 * 0.7152 + B^2.2 * 0.0722)^(1/2.2)
2、 Adobe RGB (1998) [gamma=2.20]
Gray=(R^2.2 * 0.2973 + G^2.2 * 0.6274 + B^2.2 * 0.0753)^(1/2.2)
3、Apple RGB [gamma=1.80]
Gray=(R^1.8 * 0.2446 + G^1.8 * 0.6720 + B^1.8 * 0.0833)^(1/1.8)
4、ColorMatch RGB [gamma=1.8]
Gray=(R^1.8 * 0.2750 + G^1.8 * 0.6581 + B^1.8 * 0.0670)^(1/1.8)
5、简化 KODAK DC Series Digital Camera [gamma=2.2]
Gray=(R^2.2 * 0.2229 + G^2.2 * 0.7175 + B^2.2 * 0.0595)^(1/2.2)
// 根据rgb值计算灰度
function getGray(r, g, b) {
return 0.299 * r + 0.578 * g + 0.114 * b;
}
4.根据灰度生成相应字符
把不同的灰度替换成相应的字符,原则上灰度越深的像素应该用越复杂的字符,具体什么字符可以自由替换,这只是一个测试版本。
代码片段:
// 根据灰度生成相应字符
function toText(g) {
if (g <=30) {
return '8′;
} else if (g > 30 && g <=60) {
return '&';
} else if (g > 60 && g <=120) {
return '$';
} else if (g > 120 && g <=150) {
return '*';
} else if (g > 150 && g <=180) {
return 'o';
} else if (g > 180 && g <=210) {
return '!';
} else if (g > 210 && g <=240) {
return ';';
} else {
return ‘.';
}
}
到这次我们的工作就完成得差不多啦,上面只给出了一些代码的片段,把原理疏通了一下,具体怎么实现大家可以自由发挥。猛点这里代码下载地址
关于通过javascript把图片转化为字符画的用户互动如下:
相关问题:能把图片变为字符画的网站
答:你好。 很幸运看到你的问题。 但是又很遗憾到现在还没有人回答你的问题。也可能你现在已经在别的地方找到了答案,那就得恭喜你啦。 对于你的问题我爱莫能助! 可能是你问的问题有些专业了。或者别人没有遇到或者接触过你的问题,所以帮不了你。... >>详细
相关问题:JAVA图片转成字符画
答:#首先在D盘写一个文件"temp.html",如下内容 图片转文本 body { font-family: 宋体; line-height: 0.8em; letter-spacing: 0px; font-size: 8px; } ${content} #在D盘放一个图片(放小一点的)"a.jpg" >>详细
相关问题:求大神把这张图片变成字符画
答:模糊 一般 较精细 >>详细
- 【firefox】firefox浏览器不支持innerText的解决
- 【Extjs】Extjs学习过程中新手容易碰到的低级错误
- 【clearInterval】js clearInterval()方法的定义
- 【ComboBox】ComboBox 和 DateField 在IE下消失的
- 【dom】javascript dom追加内容实现示例-追加内容
- 【has】基于jquery的has()方法以及与find()方法以
- 【extjs】Extjs入门之动态加载树代码-动态加载树
- 【checkbox】让checkbox不选中即将选中的checkbox
- 【Array】js中更短的 Array 类型转换-类型转换
- 【append】append和appendTo的区别以及appendChil
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
