typescript 实现sRGBA色值进制转换

时间: 2023-07-28 13:20:06 浏览: 54
以下是 TypeScript 实现 sRGBA 色值进制转换的示例代码: ```typescript class SrgbaColor { constructor(public r: number, public g: number, public b: number, public a: number) {} // 将 sRGBA 转换为 RGBA toRgba(): RgbaColor { const r = Math.round(this.r * this.a + 255 * (1 - this.a)); const g = Math.round(this.g * this.a + 255 * (1 - this.a)); const b = Math.round(this.b * this.a + 255 * (1 - this.a)); const a = this.a; return new RgbaColor(r, g, b, a); } // 将 sRGBA 转换为十六进制字符串 toHexString(): string { const r = Math.round(this.r * this.a + 255 * (1 - this.a)); const g = Math.round(this.g * this.a + 255 * (1 - this.a)); const b = Math.round(this.b * this.a + 255 * (1 - this.a)); const a = Math.round(this.a * 255); const hexR = r.toString(16).padStart(2, '0'); const hexG = g.toString(16).padStart(2, '0'); const hexB = b.toString(16).padStart(2, '0'); const hexA = a.toString(16).padStart(2, '0'); return `#${hexR}${hexG}${hexB}${hexA}`; } // 将 sRGBA 转换为 CSS 格式的字符串 toCssString(): string { const r = Math.round(this.r * this.a + 255 * (1 - this.a)); const g = Math.round(this.g * this.a + 255 * (1 - this.a)); const b = Math.round(this.b * this.a + 255 * (1 - this.a)); const a = this.a; return `rgba(${r}, ${g}, ${b}, ${a})`; } } class RgbaColor { constructor(public r: number, public g: number, public b: number, public a: number) {} // 将 RGBA 转换为 sRGBA toSrgba(): SrgbaColor { const alpha = this.a; const r = this.r / 255; const g = this.g / 255; const b = this.b / 255; const max = Math.max(r, g, b); const min = Math.min(r, g, b); const chroma = max - min; let s = 0; if (chroma > 0) { s = chroma / max; } const v = max; const a = alpha; const l = (max + min) / 2; const gamma = 2.2; const lsrgb = l ** gamma; const vsrgb = v ** gamma; const m = (lsrgb + vsrgb) / 2; const msrgb = m ** (1 / gamma); let rSrgb = 0; let gSrgb = 0; let bSrgb = 0; if (chroma > 0) { const c = (vsrgb - lsrgb) / chroma; const h = (() => { if (r === max) { return (g - b) / chroma; } else if (g === max) { return 2 + (b - r) / chroma; } else { return 4 + (r - g) / chroma; } })(); const hDegrees = h * 60; const hRadians = (hDegrees * Math.PI) / 180; const x = chroma * (1 - Math.abs((h % 2) - 1)); if (hDegrees >= 0 && hDegrees < 60) { rSrgb = vsrgb; gSrgb = x + lsrgb; bSrgb = lsrgb; } else if (hDegrees >= 60 && hDegrees < 120) { rSrgb = x + lsrgb; gSrgb = vsrgb; bSrgb = lsrgb; } else if (hDegrees >= 120 && hDegrees < 180) { rSrgb = lsrgb; gSrgb = vsrgb; bSrgb = x + lsrgb; } else if (hDegrees >= 180 && hDegrees < 240) { rSrgb = lsrgb; gSrgb = x + lsrgb; bSrgb = vsrgb; } else if (hDegrees >= 240 && hDegrees < 300) { rSrgb = x + lsrgb; gSrgb = lsrgb; bSrgb = vsrgb; } else if (hDegrees >= 300 && hDegrees < 360) { rSrgb = vsrgb; gSrgb = lsrgb; bSrgb = x + lsrgb; } } else { rSrgb = v; gSrgb = v; bSrgb = v; } const r = rSrgb ** (1 / gamma); const g = gSrgb ** (1 / gamma); const b = bSrgb ** (1 / gamma); return new SrgbaColor(r, g, b, a); } // 将 RGBA 转换为十六进制字符串 toHexString(): string { const hexR = this.r.toString(16).padStart(2, '0'); const hexG = this.g.toString(16).padStart(2, '0'); const hexB = this.b.toString(16).padStart(2, '0'); const hexA = Math.round(this.a * 255) .toString(16) .padStart(2, '0'); return `#${hexR}${hexG}${hexB}${hexA}`; } // 将 RGBA 转换为 CSS 格式的字符串 toCssString(): string { return `rgba(${this.r}, ${this.g}, ${this.b}, ${this.a})`; } } ``` 使用示例: ```typescript const srgba = new SrgbaColor(0.2, 0.3, 0.4, 0.5); const rgba = srgba.toRgba(); // RGBA {r: 77, g: 115, b: 153, a: 0.5} const hex = srgba.toHexString(); // "#4d739980" const css = srgba.toCssString(); // "rgba(77, 115, 153, 0.5)" ```

相关推荐

最新推荐

recommend-type

TypeScript中的方法重载详解

虽然语言层面无法自动进行重载,但借助其动态的特性,我们可以在代码中手动检查入参的类型,或者通过 arguments 获取到参数个数,从而实现根据不同的入参做不同的操作。 比如有一个获取聊天消息的方法,根据传入的...
recommend-type

vue+ts下对axios的封装实现

主要介绍了vue+ts下对axios的封装实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

vue中typescript装饰器的使用方法超实用教程

1,data 值的声明   在这里 public 声明的是公有属性, private 声明的是私有属性,私有属性要带 下划线 蓝色框里的内容是声明组件,在每个组件创建时都要带上, Components 中的写法如下   上面是 普通写法 ,...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解释minorization-maximization (MM) algorithm,并给出matlab代码编写的例子

Minorization-maximization (MM) algorithm是一种常用的优化算法,用于求解非凸问题或含有约束的优化问题。该算法的基本思想是通过构造一个凸下界函数来逼近原问题,然后通过求解凸下界函数的最优解来逼近原问题的最优解。具体步骤如下: 1. 初始化参数 $\theta_0$,设 $k=0$; 2. 构造一个凸下界函数 $Q(\theta|\theta_k)$,使其满足 $Q(\theta_k|\theta_k)=f(\theta_k)$; 3. 求解 $Q(\theta|\theta_k)$ 的最优值 $\theta_{k+1}=\arg\min_\theta Q(
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

实现实时监控告警系统:Kafka与Grafana整合

![实现实时监控告警系统:Kafka与Grafana整合](https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X2pwZy9BVldpY3ladXVDbEZpY1pLWmw2bUVaWXFUcEdLT1VDdkxRSmQxZXB5R1lxaWNlUjA2c0hFek5Qc3FyRktudFF1VDMxQVl3QTRXV2lhSWFRMEFRc0I1cW1ZOGcvNjQw?x-oss-process=image/format,png) # 1.1 Kafka集群架构 Kafka集群由多个称为代理的服务器组成,这