Hex hsl 转换 php,关于 RGB,HEX,HSL 颜色相互转换

最近一段时间在折腾一个微信在线编辑器的项目,使用 UEditor 进行二次开发。

关于 UEditor 的定制,用到的都太粗浅,官方文档上都能找得到。主题使用的样式表是 ueditor.css 而不是ueditor.min.css,定制主题要注意这一点。而对整个项目来讲,感觉难度最大的,应该是素材换色的功能。

牵扯到

网上找到了 张鑫旭 大神以前写的代码,改了bug 稍微改写了一下。

// HEX 颜色正则

var hexReg = /^\#([0-9a-f]{3}|[0-9a-f]{6})$/gi;

// RGB 转 HEX

String.prototype.colorHex = function () {

var that = this;

if (/^(rgb|RGB)/.test(that)) {

var aColor = that.replace(/(?:\(|\)|rgb)*/gi,'').split(',');

var strHex = '#';

for (var i = 0; i < aColor.length; i++) {

var hex = Number(aColor[i]).toString(16);

hex = hex.length == 1 ? "0" + hex : hex

strHex += hex

}

return strHex.toUpperCase();

} else if (hexReg.test(that)) {

var aNum = that.replace(/#/, '').split('');

if (aNum.length === 6) {

return that.toUpperCase();

} else if (aNum.length === 3) {

var numHex = '#';

for (var i = 0; i < aNum.length; i += 1) {

numHex += (aNum[i] + aNum[i])

}

return numHex.toUpperCase();

}

}

}

// HEX 转 RGB

String.prototype.colorRgb = function () {

var sColor = this.toLowerCase();

if (sColor && hexReg.test(sColor)) {

if (sColor.length === 4) {

var sColorNew = '#';

for (var i = 1; i < 4; i += 1) {

sColorNew += sColor.slice(i, i + 1).concat(sColor.slice(i, i + 1));

}

sColor = sColorNew

}

//处理六位的颜色值

var sColorChange = [];

for (var i = 1; i < 7; i += 2) {

sColorChange.push(parseInt('0x' + sColor.slice(i, i + 2)))

}

return 'rgb(' + sColorChange.join(', ') + ')';

} else {

return sColor;

}

}

关于色彩空间中的

概念问题我就不说太多了,HSB 与 HSV 是同一个概念,只是叫法不同。PhotoShop 的调色板里看到的就是HSB颜色模型。

在 CSS 中,使用的是

两个模型中,H (Hue) 都是色相的意思,取值范围为 0 – 360 指的是圆心角,每个角度代表一种颜色;

S (Saturation) 代表饱和度,但在两种模型中两个饱和度的定义并不一样,但可以相互转换,取值范围都是 0 – 1 (在 CSS 中,要写成百分数形式 ;

在 L(Lightness) 代表 亮度,是作为“白的量”来理解的;

而在 HSB 模型中,B (Brightness) 指的是 明度,被认为是“光的量”,可以是任何颜色。

下面的代码统一用原型链改写了一下,

// HSL 颜色正则

var hslReg = /^hsl\(.+?\)$/gi;

// RGB 转 HSL

String.prototype.rgb2Hsl = function () {

var c = this.colorHex();

var r = parseInt(c.substring(1, 3), 16) / 255;

var g = parseInt(c.substring(3, 5), 16) / 255;

var b = parseInt(c.substring(5, 7), 16) / 255;

var max = Math.max(r, g, b),

min = Math.min(r, g, b);

var h, s, l = (max + min) / 2;

if (max == min) {

h = s = 0; // achromatic

} else {

var d = max - min;

s = l > 0.5 ? d / (2 - max - min) : d / (max + min);

switch (max) {

case r:

h = (g - b) / d + (g < b ? 6 : 0);

break;

case g:

h = (b - r) / d + 2;

break;

case b:

h = (r - g) / d + 4;

break;

}

h /= 6;

}

h = Math.round(h * 360)

s = Math.round(s * 100)

l = Math.round(l * 100)

return 'hsl(' + h + ', ' + s + '%, ' + l +'%)';

}

// HSL 转 RGB

String.prototype.hsl2Rgb = function () {

var r, g, b;

var o = this.replace(/hsl\(|\)|\s/gi, '').split(',');

h = parseInt(o[0]) / 360;

s = parseInt(o[1]) / 100;

l = parseInt(o[2]) / 100;

if (hslReg.test(this)) {

if (s == 0) {

r = g = b = l; // achromatic

} else {

var hue2rgb = function hue2rgb(p, q, t) {

if (t < 0) t += 1; if (t > 1) t -= 1;

if (t < 1 / 6) return p + (q - p) * 6 * t;

if (t < 1 / 2) return q;

if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;

return p;

}

var q = l < 0.5 ? l * (1 + s) : l + s - l * s;

var p = 2 * l - q;

r = hue2rgb(p, q, h + 1 / 3);

g = hue2rgb(p, q, h);

b = hue2rgb(p, q, h - 1 / 3);

}

return 'rgb(' + Math.round(r * 255) + ', ' + Math.round(g * 255) + ', ' + Math.round(b * 255) + ')';

}

END.

关于 RGB,HEX,HSL 颜色相互转换

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
背景色的HSL是指使用HSL(色相、饱和度、明度)颜色模型来指定背景颜色HSL中的H代表色相,S代表饱和度,L代表明度。色相表示颜色的名称,饱和度表示颜色的纯度,明度表示颜色的明亮程度。通过指定HSL的值,可以创建出各种不同的背景颜色。例如,hsl(9, 100%, 64%)表示色相为9,饱和度为100%,明度为64%的背景颜色。\[2\]\[3\] #### 引用[.reference_title] - *1* [【CSS Zoro 02】CSS引用 CSS注释 CSS颜色颜色RGB HEX HSL 背景色 背景图像 背景重复 背景附着 背景简写](https://blog.csdn.net/m0_62629457/article/details/131033910)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [CSS颜色RGB颜色/HEX颜色/HSL颜色(网页颜色完全总结)](https://blog.csdn.net/m0_59180666/article/details/128748711)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [HSV(HSB)和HSL颜色空间](https://blog.csdn.net/studyeboy/article/details/112230919)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值