color.js 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. /**
  2. * Copyright [2022] [https://www.xiaonuo.vip]
  3. * Snowy采用APACHE LICENSE 2.0开源协议,您在使用过程中,需要注意以下几点:
  4. * 1.请不要删除和修改根目录下的LICENSE文件。
  5. * 2.请不要删除和修改Snowy源码头部的版权声明。
  6. * 3.本项目代码可免费商业使用,商业使用请保留源码和相关描述文件的项目出处,作者声明等。
  7. * 4.分发源码时候,请注明软件出处 https://www.xiaonuo.vip
  8. * 5.不可二次分发开源参与同类竞品,如有想法可联系团队xiaonuobase@qq.com商议合作。
  9. * 6.若您的项目无法满足以上几点,需要更多功能代码,获取Snowy商业授权许可,请在官网购买授权,地址为 https://www.xiaonuo.vip
  10. */
  11. /* eslint-disable eqeqeq */
  12. export default {
  13. // 加深
  14. darken(color, level) {
  15. const rgbc = this.hexToRgb(color)
  16. for (let i = 0; i < 3; i++) rgbc[i] = Math.floor(rgbc[i] * (1 - level))
  17. return this.rgbToHex(rgbc[0], rgbc[1], rgbc[2])
  18. },
  19. // 变淡
  20. lighten(color, level) {
  21. const rgbc = this.hexToRgb(color)
  22. for (let i = 0; i < 3; i++) rgbc[i] = Math.floor((255 - rgbc[i]) * level + rgbc[i])
  23. return this.rgbToHex(rgbc[0], rgbc[1], rgbc[2])
  24. },
  25. // rgb颜色转hex颜色
  26. rgbToHex(rgb) {
  27. const bg = rgb.match(/^rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/)
  28. // 返回空字符串
  29. if (!bg) {
  30. return ''
  31. }
  32. return '#' + toHex(bg[1]) + toHex(bg[2]) + toHex(bg[3])
  33. },
  34. // hex颜色转rgb颜色
  35. hexToRgb(hex) {
  36. // 去除开头 #
  37. if (hex.startsWith('#')) {
  38. hex = hex.substring(1)
  39. }
  40. // 如果当前传入的是 3 位小数值,直接转换为 6 位进行处理
  41. if (hex.length === 3) {
  42. hex = [hex[0], hex[0], hex[1], hex[1], hex[2], hex[2]].join('')
  43. }
  44. if (hex.length !== 6) {
  45. throw new Error('invalid hex:' + hex)
  46. }
  47. const r = parseInt(hex.slice(0, 2), 16)
  48. const g = parseInt(hex.slice(2, 4), 16)
  49. const b = parseInt(hex.slice(4, 6), 16)
  50. if ([r, g, b].some((x) => Number.isNaN(x))) {
  51. throw new Error('invalid hex:' + hex)
  52. }
  53. return [r, g, b]
  54. },
  55. // 透明度
  56. alpha(color, alpha = 1) {
  57. let hex = color.length > 7 ? color.rgbToHex(color) : color
  58. const { r, g, b } = color.hexToRgb(hex)
  59. return `rgba(${r}, ${g}, ${b}, ${alpha})`
  60. }
  61. }
  62. // 转Hex
  63. const toHex = (x) => ('0' + parseInt(x).toString(16)).slice(-2)