平安校园
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

74 lines
3.0 KiB

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