rgba与十六进制的相互转换,以及rgba的校验

1、将rgba颜色值转换为十六进制(rgb转十六进制同理)

RGBToHex(rgba){
	let str = rgba.slice(5,rgba.length - 1),
		arry = str.split(','),
		opa = Number(arry[3].trim())*100,
		strHex = "#",
		r = Number(arry[0].trim()),
		g = Number(arry[1].trim()),
		b = Number(arry[2].trim());
	
	strHex += ((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1);
    
    return {color:strHex,opacity:opa};
}

2、将十六进制颜色值转换为rgba(十六进制转rgb同理)

HexToRGB(color,opacity){
	let newColor = 'rgba(';

	//判断是三位还是六位
	if(color.length === 4){
		let arry = [];

		for(let i = 1;i < color.length;i++){
			arry.push(parseInt("0x" + color[i] + color[i]));
		}

		arry.forEach(function(item){
			newColor += item + ', ';
		});
		newColor += opacity/100 + ')';

		return newColor;
	}else{
		let arry = [];

		for(let i = 1;i < color.length;i += 2){
			arry.push(parseInt("0x" + color.slice(i,i+2)));
		}

		arry.forEach(function(item){
			newColor += item + ', ';
		});
		newColor += opacity/100 + ')';

		return newColor;
	}
}

3、正则检测rgba格式是否正确(检测rgb同理)

checkRGBA(rgba){
	let str = rgba.slice(5,rgba.length - 1),
    	arry = str.split(','),
    	status = true,
		reg = /^rgba\(\d{1,3}(\,\s{0,1}\d{1,3}){2}\,\s{0,1}(0|(0(\.\d{1,2}))|1)\)$/;
	
	arry.forEach(function(item,index){
		if(index == arry.length - 1){
			if(Number(item.trim()) < 0 || Number(item.trim()) > 1){
				status = false;
			}
		}else{
			if(Number(item.trim()) < 0 || Number(item.trim()) > 255){
				status = false;
			}
		}
	});
	
	if(reg.test(rgba) && status){
		return true;
	}else{
		return false;
	}
}

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RGBA(Red, Green, Blue, Alpha)是一种用来描述颜色的表示方式,其中红色、绿色和蓝色的分量加上透明度的值共同确定了一个颜色。RGBA颜色可以通过将三原色的分量值和透明度的值转换十六进制表示来进行转换。 具体而言,对于一个十六进制颜色值,例如#RRGGBB,RR表示红色分量的值,GG表示绿色分量的值,BB表示蓝色分量的值,这些值的范围是0到255(或者00到FF)。而透明度的值以十六进制的方式表示为00到FF,其中00表示完全透明(即不可见),FF表示完全不透明(即完全可见)。 要将颜色值从RGBA转换十六进制颜色,我们可以简单地将红色、绿色和蓝色的分量值以及透明度的值转换十六进制表示,然后将它们连在一起即可。例如,如果我们有一个RGBA颜色为rgba(255, 0, 0, 0.5),那么它的十六进制表示为#FF000080。其中,FF表示红色的分量值255,00表示绿色的分量值0,00表示蓝色的分量值0,80表示透明度的值0.5(转换十六进制时乘以255)。 相反地,要将一个十六进制颜色转换RGBA颜色,我们需要将十六进制颜色值拆分为红色、绿色和蓝色的分量以及透明度的值,然后将它们转换为十进制表示。例如,一个十六进制颜色值为#00FF0080,我们可以将它分解为红色分量值00(转换为十进制时为0)、绿色分量值FF(转换为十进制时为255)、蓝色分量值00(转换为十进制时为0)和透明度的值80(转换为十进制时为128)。 通过以上方法我们可以实现RGBA与十六进制颜色的互相转换。如果需要进行这样的转换,可以使用各种在线工具或编程语言中提供的函数来帮助我们进行转换。这些工具或函数可以接受RGBA或十六进制颜色作为输入,并返回转换后的结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值