• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >html5 > 如何提取图片的主题色?

如何提取图片的主题色?

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-03

本文主要包含html5,javascript等相关知识,匿名希望在学习及工作中可以帮助到您
本篇文章给大家带来的内容是关于如何提取图片的主题色?有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

工作时遇到一个需求:提取图片主题色,通过某种映射关系,选取ui给出的对应颜色。脑海中浮现如果只是纯前端如何实现呢?

一、思路与准备

利用canvas获取图像像素信息,然后用某种算法将主题颜色提取出来。

1.1 了解Canvas画布真实像素原理

MDN: 事实上,你可以直接通过getImageData,返回一个imageData对象,获取场景像素数据。

imageData对象包含下列几个只读属性:

width:图片宽度,单位是像素

height:图片高度,单位是像素

data:Uint8ClampedArray类型的一维数组,包含着RGBA格式的整型数据,范围在0至255之间(包括255)。

data属性返回一个 Uint8ClampedArray,它可以被使用作为查看初始像素数据。每个像素用4个 1 bytes值(按照红,绿,蓝和透明值的顺序,"RGBA"格式) 来代表。每个颜色值部份用0至255来代表。每个部分被分配到一个在数组内连续的索引,左上角像素的红色部分在数组的索引0位置。像素从左到右被处理,然后往下,遍历整个数组。
Uint8ClampedArray 包含高度 × 宽度 × 4 bytes数据,索引值从0到(高度×宽度×4)-1

1.2 了解中位切分法 (Median cut)

中位切分法通常是在图像处理中降低图像位元深度的算法,可用来将高位的图转换位低位的图,如将24bit的图转换为8bit的图。我们也可以用来提取图片的主题色,其原理是是将图像每个像素颜色看作是以R、G、B为坐标轴的一个三维空间中的点,由于三个颜色的取值范围为0~255,所以图像中的颜色都分布在这个颜色立方体内。如图所示:

2908790571-5bc8652ad58f7_articlex.png

之后将RGB中最长的一边从颜色统计的中位数一切为二,使得到的两个长方体所包含的像素数量相同,如下图所示重复这个过程直到切出长方体数量等于主题色数量为止,最后取每个长方体的中点即可。

1599935469-5bc8652ae2fb7_articlex.png

在实际使用中如果只是按照中点进行切割,会出现有些长方体的体积很大但是像素数量很少的情况。解决的办法是在切割前对长方体进行优先级排序,排序的系数为体积 * 像素数。这样就可以基本解决此类问题了。

其中color-thief库就是基于中位切分法实现的。

以上就是如何提取图片的主题色?的详细内容,更多请关注微课江湖其它相关文章!

您可能想查找下面的文章:

  • HTML5知识点总结
  • HTML5的本地存储
  • HTML5本地存储之IndexedDB
  • Html5实现文件异步上传功能
  • Html5新标签datalist实现输入框与后台数据库数据的动态匹配
  • 详解HTML5 window.postMessage与跨域
  • HTML5拖放API实现拖放排序的实例代码
  • 解决html5中video标签无法播放mp4问题的办法
  • HTML5新特性 多线程(Worker SharedWorker)
  • Html5新增标签有哪些

相关文章

  • 2017-08-06用HTML5实现网站在windows8中贴靠的方法
  • 2018-12-03苹果官网是怎么做到完美保证多平台浏览体验的?
  • 2018-12-03HTML5多媒体audio和video详细介绍(一)
  • 2018-12-03html5制作新增的定时器requestAnimationFrame实战进度条
  • 2018-12-03小程序中canvas如何实现图案在线定制的功能
  • 2018-12-03HTML5中pattern属性的用法详解
  • 2018-12-03HTML4和HTML5之间除了相似以外的10个主要不同_html5教程技巧
  • 2018-12-03HTML5实现留言和回复的页面
  • 2018-12-03如何提取图片的主题色?
  • 2018-12-03《css权威指南》与《html5与css3权威指南》那个更权威更先进?

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • canvas如何实现github404动态
    • HTML5 WebSocket实现聊天室的代码示例
    • HTML的基本结构与标签的初步了解
    • 避免常见的六种HTML5错误用法 (5-6)
    • HTML5+JS绘制流星雨的示例代码分享
    • html5全新的网络格局
    • H5怎样用绘制五角星
    • Range:HTML5中的新型Input类型
    • 为什么 360 浏览器会成为最后一家放弃 IE 默认内核的浏览器?
    • HTML5 新事件 小结_html5教程技巧

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有