最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

JS获取图片的topN色值方法

来源:动视网 责编:小采 时间:2020-11-27 19:58:31
文档

JS获取图片的topN色值方法

JS获取图片的topN色值方法:这次给大家带来JS获取图片的top N色值方法,JS获取图片top N色值的注意事项有哪些,下面就是实战案例,一起来看一下。题目要求找出一个页面中出现次数最多的标签。个人解法:var eles = document.getElementsByTagName('*'
推荐度:
导读JS获取图片的topN色值方法:这次给大家带来JS获取图片的top N色值方法,JS获取图片top N色值的注意事项有哪些,下面就是实战案例,一起来看一下。题目要求找出一个页面中出现次数最多的标签。个人解法:var eles = document.getElementsByTagName('*'


1、数据获取

图片数据获取使用了canvas的getImageData()方法,能获取到图片每个像素点的rgba数据。

var imgdatas=context.getImageData(0,0,150,150);//获取当前canvas数据
var imgdata = imgdatas.data;//获取rgba数据
var i = 0, len = imgdata.length;
var arr = [];
//将图片rgba数据push到新数组中
for(i ; i<len ; i+=4 ) {
 arr.push(imgdata[i]+','+imgdata[i+1]+','+imgdata[i+2]+','+imgdata[i+3]); 
}

这样就可以拿到图片的所有数据了,剩下的就是数学问题了。

2、数据聚类

去重,相同色值合并,记录该色值出现个数(权重)weight

聚类方法就比较多了,直接数学统计,或者k-means,决策树,朴素贝叶斯,支持向量机等等,喜欢哪个就用哪个就可以了,但是还是需要考虑下不同方法的适用情况和效率什么的了。
我们会得到这样一个数组 [{rgba: '21,12,45,0', weight: 12}, {...}]来记录色值和出现次数,

3、聚类结果排序

对上一步中得到的json数组进行排序,根据属性weight的值从大到小或者从小到大排序,排序算法就不用多言了。

4、结果预览

5、to Do

相似色值合并

rgba(234,234,234,1)和rgba(234,235,235,1)类似的这种是否有必要合并成为一个值,这里又会涉及到相似度计算等问题。

优化聚类算法

提高复杂度,提升性能,提升执行速度

结合可视化的一些东西

6、总结

数据多的处理还是放在后端比较合适,毕竟可以利用分布式框架等多端计算。

而浏览器处理数据的能力还是有限。

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

在小程序里实现animation动画

小程序获取openid及用户信息的方法

使用jquery做出PC端轮播图的实列详解

文档

JS获取图片的topN色值方法

JS获取图片的topN色值方法:这次给大家带来JS获取图片的top N色值方法,JS获取图片top N色值的注意事项有哪些,下面就是实战案例,一起来看一下。题目要求找出一个页面中出现次数最多的标签。个人解法:var eles = document.getElementsByTagName('*'
推荐度:
标签: 图片 方法 获取
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top