plasmo开发浏览器插件动态setIcon修改插件图标和setBadgeText显示徽标

动态修改图标和设置徽标主要用到action这个api,官网地址:developer.chrome.com/docs/extens...

如果你使用官方原生的方式开发,加载和修改图标应该是比较简单的,但是如果你使用的是plasmo框架开发浏览器插件的话,就会遇到加载图片的路径不正确,导致设置图标错误的问题。这里就说一下在plasmo框架里面加载图标并动态设置。

动态设置图标

因为动态设置图标只能填写两种方式,一个是imageData,另外一个就是加载一个path,使用imageData的方式可以使用canvas画一张图,然后加载上去:

javascript 复制代码
 // change action icon
    const setIcon = () => {
        const canvas = new OffscreenCanvas(16, 16)
        const context = canvas.getContext('2d')
        context.clearRect(0, 0, 16, 16)
        context.fillStyle = '#00FF00' // Green
        context.fillRect(0, 0, 16, 16)
        const imageData = context.getImageData(0, 0, 16, 16)
        chrome.action.setIcon({ imageData: imageData }, () => {
            console.log('set icon callback')
        })
    }

这是一种比较简单的方式,但是如果你想加载一张本地的图片,动态设置为图标该怎么办?

plasmo官方文档加载资源的方式:Import Resolution -- Plasmo

可以加载scss的文件:

javascript 复制代码
import styleText from "data-text:~/assets/style.scss"

// 会自动转成css
console.log(styleText)

也可以加载原始图片路径:

javascript 复制代码
import imageUrl from "raw:~/assets/image.png"
 
console.log(imageUrl) // chrome-extension://<extension-id>/image.<hashA>.png

也可以加载base64格式的图片:

javascript 复制代码
import iconBase64 from "data-base64:~/assets/icon.png"
 
console.log(iconBase64) // data:image/png;base64,etc...

我们这个使用setIcon动态设置图标的时候,只能使用imageData的格式,因为原始图片路径和base64格式的都不行,所以需要将base64/图片路径格式的转为imageData格式的才可以:

javascript 复制代码
import someImage from 'data-base64:~assets/icon.png'

// set custom icon
    const setPngIcon = () => {
        var img = new Image()
        img.onload = function () {
            const canvas = new OffscreenCanvas(16, 16)
            const context = canvas.getContext('2d')
            context.drawImage(img, 0, 0, 16, 16)
            const imageData = context.getImageData(0, 0, 16, 16)
            chrome.action.setIcon({ imageData: imageData }, () => {
                console.log('set icon callback')
            })
        }
        img.src = someImage
    }

这样设置完就可以修改了:

图标也更换了:

更换后的图标:

相关推荐
夏子曦4 小时前
webpack 的工作流程
前端·webpack·node.js
麻芝汤圆4 小时前
在 Sheel 中运行 Spark:开启高效数据处理之旅
大数据·前端·javascript·hadoop·分布式·ajax·spark
yrldjsbk4 小时前
uniapp开发09-设置一个tabbar底部导航栏且配置icon图标
前端·uni-app
源码方舟5 小时前
【HTML5】显示-隐藏法 实现网页轮播图效果
前端·javascript·html·css3·html5
二川bro5 小时前
依赖注入详解与案例(前端篇)
前端
神秘代码行者7 小时前
Vue项目Git提交流程集成
前端·vue.js·git
阿黄学技术8 小时前
Vite简单介绍
前端·前端框架·vue
264玫瑰资源库9 小时前
网狐飞云娱乐三端源码深度实测:组件结构拆解与部署Bug复盘指南(附代码分析)
java·开发语言·前端·bug·娱乐
济南壹软网络科技-专注源码开发数十年!9 小时前
盲盒源码_盲盒系统_盲盒定制开发 盲盒搭建前端教程
开发语言·前端·uni-app·php
哟哟耶耶10 小时前
react-13react中外部css引入以及style内联样式(动态className与动态style)
前端·css·react.js