UNPKG

@whitesev/utils

Version:

一个常用的工具库

131 lines (127 loc) 3.08 kB
class ColorConversion { /** * 判断是否是16进制颜色 * @param str */ isHex(str: string): boolean { if (typeof str !== "string") { return false; } if (!str.match(/^(\#|)[0-9a-fA-F]{6}$/)) { return false; } return true; } /** * 16进制颜色转rgba * * #ff0000 转 rgba(123,123,123, 0.4) * @param hex * @param opacity */ hexToRgba(hex: string, opacity: number): string { if (!this.isHex(hex)) { // @ts-ignore throw new TypeError("输入错误的hex", hex); } return hex && hex.replace(/\s+/g, "").length === 7 ? "rgba(" + parseInt("0x" + hex.slice(1, 3)) + "," + parseInt("0x" + hex.slice(3, 5)) + "," + parseInt("0x" + hex.slice(5, 7)) + "," + opacity + ")" : ""; } /** * hex转rgb * @param str * @returns */ hexToRgb(str: string) { if (!this.isHex(str)) { // @ts-ignore throw new TypeError("输入错误的hex", str); } /* replace替换查找的到的字符串 */ str = str.replace("#", ""); /* match得到查询数组 */ let hxs = str.match(/../g); for (let index = 0; index < 3; index++) { // @ts-ignore hxs[index] = parseInt(hxs[index], 16); } return hxs; } /** * rgb转hex * @param redValue * @param greenValue * @param blueValue * @returns */ rgbToHex( redValue: string | number, greenValue: string | number, blueValue: string | number ): string { /* 验证输入的rgb值是否合法 */ let validPattern = /^\d{1,3}$/; if ( !validPattern.test(redValue.toString()) || !validPattern.test(greenValue.toString()) || !validPattern.test(blueValue.toString()) ) throw new TypeError("输入错误的rgb颜色值"); let hexs = [ redValue.toString(16), greenValue.toString(16), blueValue.toString(16), ]; for (let index = 0; index < 3; index++) if (hexs[index].length == 1) hexs[index] = "0" + hexs[index]; return "#" + hexs.join(""); } /** * 获取颜色变暗或亮 * @param color 颜色 * @param level 0~1.0 * @returns */ getDarkColor(color: string, level: string): string { if (!this.isHex(color)) { // @ts-ignore throw new TypeError("输入错误的hex", color); } let rgbc = this.hexToRgb(color); for (let index = 0; index < 3; index++) { // @ts-ignore rgbc[index] = Math.floor(rgbc[index] * (1 - level)); } // @ts-ignore return this.rgbToHex(rgbc[0], rgbc[1], rgbc[2]); } /** * 获取颜色变亮 * @param color 颜色 * @param level 0~1.0 * @returns */ getLightColor(color: string, level: number): string { if (!this.isHex(color)) { // @ts-ignore throw new TypeError("输入错误的hex", color); } let rgbc = this.hexToRgb(color); for (let index = 0; index < 3; index++) { // @ts-ignore rgbc[index] = Math.floor((255 - rgbc[index]) * level + rgbc[index]); } // @ts-ignore return this.rgbToHex(rgbc[0], rgbc[1], rgbc[2]); } } export { ColorConversion };