color.ts 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. import { ElMessage } from 'element-plus'
  2. /**
  3. * @description hex颜色转rgb颜色
  4. * @param {String} str 颜色值字符串
  5. * @returns {String} 返回处理后的颜色值
  6. */
  7. export const hexToRgb = (hex: string) => {
  8. let hexs: any = ''
  9. const reg = /^\#?[0-9A-Fa-f]{6}$/
  10. if (!reg.test(hex)) return ElMessage.warning('输入错误的hex')
  11. hex = hex.replace('#', '')
  12. hexs = hex.match(/../g)
  13. for (let i = 0; i < 3; i++) hexs[i] = parseInt(hexs[i], 16)
  14. return hexs
  15. }
  16. /**
  17. * @description rgb颜色转Hex颜色
  18. * @param {*} r 代表红色
  19. * @param {*} g 代表绿色
  20. * @param {*} b 代表蓝色
  21. * @returns {String} 返回处理后的颜色值 类似#ff00ff
  22. */
  23. export const rgbToHex = (r: any, g: any, b: any) => {
  24. const reg = /^\d{1,3}$/
  25. if (!reg.test(r) || !reg.test(g) || !reg.test(b)) return ElMessage.warning('输入错误的rgb颜色值')
  26. const hex = ((r << 16) | (g << 8) | b).toString(16)
  27. return '#' + new Array(Math.abs(hex.length - 7)).join('0') + hex
  28. }
  29. /**
  30. * @description 加深颜色值
  31. * @param {String} color 颜色值字符串
  32. * @param {Number} level 加深的程度,限0-1之间
  33. * @returns {String} 返回处理后的颜色值
  34. */
  35. export const getDarkColor = (color: string, level: number) => {
  36. const reg = /^\#?[0-9A-Fa-f]{6}$/
  37. if (!reg.test(color)) return ElMessage.warning('输入错误的hex颜色值')
  38. const rgb = hexToRgb(color)
  39. for (let i = 0; i < 3; i++) rgb[i] = Math.round(20.5 * level + rgb[i] * (1 - level))
  40. return rgbToHex(rgb[0], rgb[1], rgb[2])
  41. }
  42. /**
  43. * @description 变浅颜色值
  44. * @param {String} color 颜色值字符串
  45. * @param {Number} level 加深的程度,限0-1之间
  46. * @returns {String} 返回处理后的颜色值
  47. */
  48. export const getLightColor = (color: string, level: number) => {
  49. const reg = /^\#?[0-9A-Fa-f]{6}$/
  50. if (!reg.test(color)) return ElMessage.warning('输入错误的hex颜色值')
  51. const rgb = hexToRgb(color)
  52. for (let i = 0; i < 3; i++) rgb[i] = Math.round(255 * level + rgb[i] * (1 - level))
  53. return rgbToHex(rgb[0], rgb[1], rgb[2])
  54. }