当前位置: 首页 > article >正文

微信小程序的图片色彩分析,窃取网络图片的主色调

1、安装 Mini App Color Thief 包 

包括下载包,简单使用都有,之前写了,这里就不写了

网址:微信小程序的图片色彩分析,窃取主色调,调色板-CSDN博客

2、 问题和解决方案

  • 问题:由于我们的窃取图片的是需要画布的,我需要使用网络图片去用画布时,微信小程序会报错,最后发现,需要本地图片才行,用网络图片会出问题
  • 解决方案:我们使用wx.downloadFile去下载该图片,然后获取临时路径去使用画布和Mini App Color Thief 包 窃取图片颜色,防止图片重复下载的话,我们去用微信小程序中的另一个api,FileSystemManager.access(Object object)去判断临时文件是否存在

 3、配置downloadFile.js文件【放置在utils文件夹下】

export default (url, path = "") => {
  return new Promise((resolve, reject) => {
    const fs = wx.getFileSystemManager()
    // 判断文件/目录是否存在
    fs.access({
      path,
      success(res) {
        // 文件存在,复用
        console.log(res)
        resolve(path)
      },
      fail(res) {
        // 文件不存在或其他错误,下载为临时文件
        console.log(res)

        wx.downloadFile({
          url,
          success(res) {
            if (res.statusCode === 200) {
              resolve(res.tempFilePath)
              wx.setStorageSync('bgcUrl', res.tempFilePath)
            }
          },
          fail: (err) => {
            reject(err)
          }
        })
      }
    })
  })
}

4、获取图片临时路径,开始窃取

注意:wxml中需要放置

<canvas canvas-id="myCanvas" />
import downloadFile from '../../utils/downloadFile'

Page({
  data: {
    palette: "",

    // 用户信息
    userInfo: {},
  },

  // 判断是否有背景图片的缓存文件,没有就下载为临时文件,最后绘画出来
  async bgcDownload() {
    let bgcUrl = wx.getStorageSync('bgcUrl')
    let result = await downloadFile(this.data.userInfo.backgroundUrl, bgcUrl)
    console.log(result);

    const ctx = wx.createCanvasContext('myCanvas')
    ctx.drawImage(result, 0, 0, 100, 100);
    ctx.draw(false, () => {
      wx.canvasGetImageData({
        canvasId: "myCanvas",
        x: 0,
        y: 0,
        width: 100,
        height: 100,
        success: res => {
          let palette = colorThief(res.data).color().getHex();
          this.setData({ palette })
        }
      });
    })
  },
  onReady: function () {
    this.bgcDownload()
  },
})


http://www.kler.cn/a/233049.html

相关文章:

  • 远离生成式AI大乱斗,SAS公司揭示亚太区千亿AI市场蓝图
  • MQTT协议解析 : 物联网领域的最佳选择
  • 【MySQL】约束
  • 软件工程概论项目(二),node.js的配置,npm的使用与vue的安装
  • leetcode hot100【LeetCode 114.二叉树展开为链表】java实现
  • 浅谈C#之内存管理
  • Python中使用opencv-python库进行颜色检测
  • 【芯片设计- RTL 数字逻辑设计入门 7 -- 同步复位与异步复位详细介绍】
  • 使用Collections.singletonList()遇到的问题
  • Unity学习笔记之【IK反向动力学操作】
  • 20240209-最大可整分子集
  • c#: 表达式树的简化
  • 科研绘图-半小提琴图-
  • List 差集
  • 【开源】JAVA+Vue+SpringBoot实现房屋出售出租系统
  • vue父子组件通讯的几种方式总结学习
  • 基于SpringBoot的记账系统项目
  • Vagrant 虚拟机工具基本操作指南
  • echarts 一条折线图上显示不同颜色
  • 【Android】GridLayout实现等比布局
  • DC-9靶机渗透详细流程
  • 每日五道java面试题之java基础篇(一)
  • 飞桨自然语言处理框架 paddlenlp的 trainer
  • openssl3.2 - exp - buffer to BIO
  • HarmonyOS SDK 助力新浪新闻打造精致易用的新闻应用
  • 【ETOJ P1046】斐波那契数列 题解(数学+动态规划)