k-colors
v0.1.0
Published
[demo](https://ppzreboot.github.io/k-colors.js/) | [github](https://github.com/ppzreboot/k-colors.js) | [npm](https://www.npmjs.com/package/k-colors)
Downloads
18
Maintainers
Readme
k-colors.js
A JavaScript library for extracting dominant colors from images using the k-means/k-means++ algorithm.
This lib is based on k-means-pp.js.
Install
npm install k-colors
basic
import { KCPP } from 'k-colors'
const kcpp = new KCPP(img) // the `img` is a HTMLImageElement or HTMLCanvasElement or OffscreenCanvas or ImageData
const result = kcpp.k_colors_pp(3)
const dataurl = result.get_clustered_dataurl()
console.log(result.colors) // [ [255,255,255,200], [100,200,200,255], [0,10,20,255] ]
web worker (vite)
import KCPP_worker from 'k-colors/worker?worker'
import { KCPP_worker_wrapper } from 'k-colors/worker/wrapper'
const worker = new KCPP_worker()
const kcpp = new KCPP_worker_wrapper(worker, img)
// perform k-means++
const result = await kcpp.dominant(3)
// perform k-means
// const result = await kcpp.dominant(3, 'k_means')
// get dominant colors
const colors = result.colors
// get dataurl of the clustered image
const dataurl = result.get_clustered_dataurl()