/** * @description 颜色相关工具函数 * @license Apache License Version 2.0 * @Copyright (c) 2022-Now 少林寺驻北固山办事处大神父王喇嘛 * @remarks * SimpleAdmin 基于 Apache License Version 2.0 协议发布,可用于商业项目,但必须遵守以下补充条款: * 1.请不要删除和修改根目录下的LICENSE文件。 * 2.请不要删除和修改SimpleAdmin源码头部的版权声明。 * 3.分发源码时候,请注明软件出处 https://gitee.com/dotnetmoyu/SimpleAdmin * 4.基于本软件的作品,只能使用 SimpleAdmin 作为后台服务,除外情况不可商用且不允许二次分发或开源。 * 5.请不得将本软件应用于危害国家安全、荣誉和利益的行为,不能以任何形式用于非法为目的的行为不要删除和修改作者声明。 * 6.任何基于本软件而产生的一切法律纠纷和责任,均于我司无关 * @see https://gitee.com/dotnetmoyu/SimpleAdmin */ import { ElMessage } from "element-plus"; /** * @description hex颜色转rgb颜色 * @param {String} str 颜色值字符串 * @returns {String} 返回处理后的颜色值 */ export function hexToRgb(str: any) { let hexs: any = ""; let reg = /^\#?[0-9A-Fa-f]{6}$/; if (!reg.test(str)) return ElMessage.warning("输入错误的hex"); str = str.replace("#", ""); hexs = str.match(/../g); for (let i = 0; i < 3; i++) hexs[i] = parseInt(hexs[i], 16); return hexs; } /** * @description rgb颜色转Hex颜色 * @param {*} r 代表红色 * @param {*} g 代表绿色 * @param {*} b 代表蓝色 * @returns {String} 返回处理后的颜色值 */ export function rgbToHex(r: any, g: any, b: any) { let reg = /^\d{1,3}$/; if (!reg.test(r) || !reg.test(g) || !reg.test(b)) return ElMessage.warning("输入错误的rgb颜色值"); let hexs = [r.toString(16), g.toString(16), b.toString(16)]; for (let i = 0; i < 3; i++) if (hexs[i].length == 1) hexs[i] = `0${hexs[i]}`; return `#${hexs.join("")}`; } /** * @description 加深颜色值 * @param {String} color 颜色值字符串 * @param {Number} level 加深的程度,限0-1之间 * @returns {String} 返回处理后的颜色值 */ export function getDarkColor(color: string, level: number) { let reg = /^\#?[0-9A-Fa-f]{6}$/; if (!reg.test(color)) return ElMessage.warning("输入错误的hex颜色值"); let rgb = hexToRgb(color); for (let i = 0; i < 3; i++) rgb[i] = Math.round(20.5 * level + rgb[i] * (1 - level)); return rgbToHex(rgb[0], rgb[1], rgb[2]); } /** * @description 变浅颜色值 * @param {String} color 颜色值字符串 * @param {Number} level 加深的程度,限0-1之间 * @returns {String} 返回处理后的颜色值 */ export function getLightColor(color: string, level: number) { let reg = /^\#?[0-9A-Fa-f]{6}$/; if (!reg.test(color)) return ElMessage.warning("输入错误的hex颜色值"); let rgb = hexToRgb(color); for (let i = 0; i < 3; i++) rgb[i] = Math.round(255 * level + rgb[i] * (1 - level)); return rgbToHex(rgb[0], rgb[1], rgb[2]); }