vue3&TS中使用 colorthief 实现背景色随着当前图片变化

前言

今天发现个有意思的库colorthief, 它可以获取到图片或者svg中主要的颜色以及辅色,上手简单使用了一下发现挺有意思,于是决定写个3D轮播 ,根据当前轮播图片来改变背景色。技术栈依然是使用 vue3 + ts。这里贴一个项目源码以及项目预览,感兴趣的可以下载源码看看或者去看看效果预览,想自己动手试试的可以跟着我实现一遍效果

项目初期搭建

sql 复制代码
npm create vue@latest
npm i colorthief

根据提示结合自身习惯创建项目即可,接着简单的清理一下初始无用的代码,就可以开始准备写代码了

colorthief 简单介绍

colorthief 翻译过来就是颜色小偷,其作用就是获取图片或者svg中的颜色点,并罗列出来,它支持浏览器环境以及node环境,这里我们只介绍浏览器环境,在浏览器环境中使用非常简单, 导入 colorthief 后实例化即可, 有两个实例方法,getColor & getPalette

getColor接受两个参数,第一个是图像元素,第二个是质量(质量是一个可选参数,必须是值 1 或更大的整数,默认为 10。该数字决定在采样下一个像素之前跳过多少像素。我们很少需要对图像中的每个像素进行采样才能获得良好的结果。数字越大,返回值的速度越快)

getPalette接受三个参数,第一个是图像元素,第二个是颜色计数,第三个是质量

在项目中使用 colorthief

在TS中使用colorthief的话, 由于colorthief并没有@types/colorthief, 所以需要我们自己写声明文件, 在根目录下创建colorthief.d.ts:

typescript 复制代码
// colorthief.d.ts

declare module 'colorthief' {
  class ColorThief {
    constructor()
    getColor(sourceImage: HTMLImageElement, quality?: number): Promise<[number, number, number]>
    getPalette(
      sourceImage: HTMLImageElement,
      colorCount?: number,
      quality?: number
    ): Promise<[number, number, number][]>
  }

  export default ColorThief
}

这样就声明好了,接着就可以愉快的去使用了,首先构建一个轮播组件, 轮播没啥好说的, 基本上前端都会写,这里不多赘述了,图片来源可以是本地图片,我使用了图片api:picsum 每次请求都是一张不同的图片,关于picsum的使用可以点击去官网看看说明,很简单这里也不多说了, 轮播和图片准备就绪之后,就可以开始使用 colorthief 了。

javascript 复制代码
import ColorThief from 'colorthief'

const colorthief = new ColorThief()

实例化之后就可以调用实例方法了, 上面两个实例方法都简单的介绍过了,这里不多赘述, 关于必传参数的image元素, 可以通过ref来传值, 这样就能获得一个数组,这个数组就是 rgb的三个值,getColorgetPalette 的区别就在于获取几个颜色,如果你想获取多个颜色,就使用getPalette,这两个方法都会返回一个 Promise , 我们可以这样来获取他们的返回值

ini 复制代码
colorthief.getColor(ImageRef).then(res=>{
  console.log(res)
})

拿到返回值改变元素背景即可, 这一步还是很简单的,以上就是colorthief的全部使用了。

结尾

如果对3D轮播感兴趣的可以留言让我可以写一篇介绍它的实现,也可以自己拿到源码下载看看具体的实现

相关推荐
计算机-秋大田1 小时前
基于Spring Boot的兴顺物流管理系统设计与实现(LW+源码+讲解)
java·vue.js·spring boot·后端·spring·课程设计
禾苗种树2 小时前
在 Vue 3 中使用 ECharts 制作多 Y 轴折线图时,若希望 **Y 轴颜色自动匹配折线颜色**且无需手动干预,可以通过以下步骤实现:
前端·vue.js·echarts
小盼江3 小时前
水果生鲜农产品推荐系统 协同过滤余弦函数推荐水果生鲜农产品 Springboot Vue Element-UI前后端分离 代码+开发文档+视频教程
vue.js·spring boot·ui
初遇你时动了情4 小时前
react module.scss 避免全局冲突类似vue中scoped
vue.js·react.js·scss
烂蜻蜓4 小时前
Uniapp 设计思路全分享
前端·css·vue.js·uni-app·html
bin91535 小时前
DeepSeek 助力 Vue 开发:打造丝滑的二维码生成(QR Code)
前端·javascript·vue.js·ecmascript·deepseek
浪九天9 小时前
Vue 不同大版本与 Node.js 版本匹配的详细参数
前端·vue.js·node.js
qianmoQ10 小时前
第五章:工程化实践 - 第三节 - Tailwind CSS 大型项目最佳实践
前端·css
尚学教辅学习资料10 小时前
基于SpringBoot+vue+uniapp的智慧旅游小程序+LW示例参考
vue.js·spring boot·uni-app·旅游
~废弃回忆 �༄11 小时前
CSS中伪类选择器
前端·javascript·css·css中伪类选择器