color.js 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  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. // hex颜色转rgb颜色
  14. HexToRgb(str) {
  15. str = str.replace('#', '')
  16. const hxs = str.match(/../g)
  17. for (let i = 0; i < 3; i++) hxs[i] = parseInt(hxs[i], 16)
  18. return hxs
  19. },
  20. // rgb颜色转hex颜色
  21. RgbToHex(a, b, c) {
  22. const hexs = [a.toString(16), b.toString(16), c.toString(16)]
  23. for (let i = 0; i < 3; i++) {
  24. if (hexs[i].length == 1) hexs[i] = `0${hexs[i]}`
  25. }
  26. return `#${hexs.join('')}`
  27. },
  28. // 加深
  29. darken(color, level) {
  30. const rgbc = this.HexToRgb(color)
  31. for (let i = 0; i < 3; i++) rgbc[i] = Math.floor(rgbc[i] * (1 - level))
  32. return this.RgbToHex(rgbc[0], rgbc[1], rgbc[2])
  33. },
  34. // 变淡
  35. lighten(color, level) {
  36. const rgbc = this.HexToRgb(color)
  37. for (let i = 0; i < 3; i++) rgbc[i] = Math.floor((255 - rgbc[i]) * level + rgbc[i])
  38. return this.RgbToHex(rgbc[0], rgbc[1], rgbc[2])
  39. }
  40. }