|
- /**
- * @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]);
- }
|