屏幕色彩(一)-已知混色光色点求配色比

news2025/1/31 11:25:15

文章目录

  • 计算公式
  • html源码
  • 运行结果

计算公式

[ W x W y W z ] = [ M ] [ R G B ] \begin{gather} \begin{bmatrix} W_x\\ W_y\\W_z \end{bmatrix}= \begin{bmatrix} M \end{bmatrix} \begin{bmatrix} R\\G\\B \end{bmatrix} \end{gather} WxWyWz =[M] RGB
其中, W x = w x / w y , W y = w y / w y , W z = w z / w y , w x 、 w y 、 w z W_x = w_x/w_y,W_y = w_y/w_y,W_z = w_z/w_y,w_x、w_y、w_z Wx=wx/wy,Wy=wy/wy,Wz=wz/wy,wxwywz为目标混色光色坐标, [ R G B ] \begin{bmatrix} R\\G\\B \end{bmatrix} RGB 分别为红绿蓝对应的亮度配比,
[ M ] = [ X r X g X b Y r Y g Y b Z r Z g Z b ] \begin{gather} \begin{bmatrix} M \end{bmatrix}= \begin{bmatrix} X_r&X_g&X_b\\ Y_r&Y_g&Y_b\\ Z_r&Z_g&Z_b\\ \end{bmatrix} \end{gather} [M]= XrYrZrXgYgZgXbYbZb
R x = r x / r y R y = 1 R z = ( 1 − r x − r y ) / r y G x = g x / g y G y = 1 G y = ( 1 − g x − g y ) / g y B x = b x / b y B y = 1 B z = ( 1 − b x − b y ) / b y \begin{gather} R_x= r_x/r_y \\ R_y= 1 \\ R_z = (1-r_x-r_y)/r_y\\ G_x= g_x/g_y \\ G_y= 1 \\ G_y = (1-g_x-g_y)/g_y\\ B_x = b_x/b_y \\ B_y = 1 \\ B_z = (1-b_x-b_y)/b_y\\ \end{gather} Rx=rx/ryRy=1Rz=(1rxry)/ryGx=gx/gyGy=1Gy=(1gxgy)/gyBx=bx/byBy=1Bz=(1bxby)/by
其中 ( r x , r y ) , ( g x , g y ) , ( b x , b y ) (r_x,r_y),(g_x,g_y),(b_x,b_y) (rx,ry),(gx,gy),(bx,by)分别为红绿蓝三色的单色色坐标。

html源码

<!DOCTYPE html>
<html>
<head>
	<title>Calculation Matrix</title>
	<link rel="stylesheet" href="style.css">
<script type="text/javascript" src="math.js"></script>
<script type="text/javascript">
function XYZ2RGB(){
	var x_r,y_r,x_g,y_g,x_b,y_b,X_W,Y_W,Z_W,White_CIEx,White_CIEy,White_CIEz;
	
	x_r = Number(document.getElementById("Red_CIEx").value);
	y_r = Number(document.getElementById("Red_CIEy").value);
	x_g = Number(document.getElementById("Green_CIEx").value);
	y_g = Number(document.getElementById("Green_CIEy").value);
	x_b = Number(document.getElementById("Blue_CIEx").value);
	y_b = Number(document.getElementById("Blue_CIEy").value);
	White_CIEx = document.getElementById("White_CIEx").value;
	White_CIEy = document.getElementById("White_CIEy").value;
	White_CIEz = 1-White_CIEx-White_CIEy;
	
	
	X_W = White_CIEx/White_CIEy;
	Y_W = White_CIEy/White_CIEy;
	Z_W = White_CIEz/White_CIEy;
	M = Creat_TranMatrix(x_r,y_r,x_g,y_g,x_b,y_b);
	const White_XYZ = math.matrix([X_W, Y_W, Z_W]);
	var RGB_ratio = math.matrix();
	RGB_ratio = math.multiply(M,White_XYZ);
	const RGB_ratio_array = RGB_ratio.valueOf();
	document.getElementById('Red').value=RGB_ratio_array[0].toFixed(4);
	document.getElementById('Green').value=RGB_ratio_array[1].toFixed(4);
	document.getElementById('Blue').value=RGB_ratio_array[2].toFixed(4);
}
function Creat_TranMatrix(x_r,y_r,x_g,y_g,x_b,y_b){
	X_r = x_r/y_r;
	Y_r = 1;
	Z_r = (1-x_r-y_r)/y_r;
	
	X_g = x_g/y_g;
	Y_g = 1;
	Z_g = (1-x_g-y_g)/y_g;
	
	X_b = x_b/y_b;
	Y_b = 1;
	Z_b = (1-x_b-y_b)/y_b;
	const X_rgb = math.matrix([[X_r, X_g, X_b], [Y_r, Y_g, Y_b],[Z_r, Z_g, Z_b]]);
	return math.inv(X_rgb);
}
</script>
</head>
<body>
	
	<!-- 显示结果信息 -->
	<div id = "ResultTable"><table align = "left" border = "1" cellpadding = "20">
		<tr>	<th>Color</th><th>CIEx</th><th>CIEy</th><th>ratio</th></tr>
		<tr>	<td>White</td>
		<td><input id = "White_CIEx" border:none type = "TEXT" value = "0.305"/></td>
		<td><input id = "White_CIEy" border:none type = "TEXT" value = "0.310"/></td>
		<td>-</td></tr>
		<tr>	<td>Red</td>  
		<td><input id = "Red_CIEx" border:none type = "TEXT" value = "0.64"/></td>
		<td><input id = "Red_CIEy" border:none type = "TEXT" value = "0.33"/></td>
		<td><input id = "Red" border:none type = "TEXT" value = "0.42"/></td></tr>
		<tr>	<td>Green</td>
		<td><input id = "Green_CIEx" border:none type = "TEXT" value = "0.30"/></td>
		<td><input id = "Green_CIEy" border:none type = "TEXT" value = "0.6"/></td> 
		<td><input id = "Green" border:none type = "TEXT" value = "0.36"/></td></tr>
		<tr>	<td>Blue</td> 
		<td><input id = "Blue_CIEx" border:none type = "TEXT" value = "0.15"/></td>
		<td><input id = "Blue_CIEy" border:none type = "TEXT" value = "0.08"/></td>
		<td><input id = "Blue" border:none type = "TEXT" value = "0.22"/></td></tr>
	</table>
	</div>
	<div>
		<ul>
			<li onclick="XYZ2RGB()"><a href="#">XYZ2RGB</a></li>
		</ul>
	</div>
</body>
</html>

运行结果

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/413358.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

STM-32:串口收发数据包—串口收发HEX数据包/串口收发文本数据包

目录一、发送HEX数据包1.1固定包长&#xff0c;含包头包尾&#xff08;包尾不是必须的&#xff09;1.2可变包长&#xff0c;含包头包尾二、接收HEX数据包三、发送文本数据包3.1固定包长&#xff0c;含包头包尾3.2可变包长&#xff0c;含包头包尾四、接收文本数据包五、HEX数据包…

73-Linux_线程安全

线程安全一.什么是线程安全二.strtok和strtok_r1.strtok2.strtok_r三.多线程中执行fork1.多线程中某个线程调用 fork()&#xff0c;子进程会有和父进程相同数量的线程吗&#xff1f;2.父进程被加锁的互斥锁 fork 后在子进程中是否已经加锁 ?一.什么是线程安全 线程安全即就是…

【数据结构】时间复杂度详解

首先我们要知道学习数据结构时都会讨论到算法&#xff0c;数据结构中的问题多数都有算法解决&#xff0c;两者是你中有我&#xff0c;我中有你的关系&#xff0c;所以在数据结构中的学习中算法也是必不可少的。 为方便阅读&#xff0c;以下为本片目录 目录 1.算法效率 1.1 …

JavaScript的学习理解

文章目录一、JavaScript 对象二、JavaScript 函数三、JavaScript 作用域总结一、JavaScript 对象 JavaScript 对象是拥有属性和方法的数据。 真实生活中的对象&#xff0c;属性和方法 在 JavaScript中&#xff0c;几乎所有的事物都是对象。 在 JavaScript 中&#xff0c;对象…

Spring5学习笔记01

一、课程介绍 Spring是什么呢&#xff1f; 它是一个轻量级的、开源的JavaEE框架&#xff0c;它的出现是为了解决企业繁琐的开发包括复杂代码&#xff0c;它可以用很优雅、很简洁的方式进行实现&#xff0c;也就是说它为了简化企业开发而生&#xff0c;而它在目前的企业中应用…

大规模MySQL运维陷阱之基于MyCat的伪分布式架构

引子 分布式数据库&#xff0c;已经进入了全面快速发展阶段&#xff0c;这种发展&#xff0c;是与时俱进的&#xff0c;与人的需求是分不开的&#xff0c;因为现在信息时代的高速发展&#xff0c;导致数据量和交易量越来越大。这种现象首先导致的就是存储瓶颈&#xff0c;因为…

(排序10)归并排序的外排序应用(文件排序)

TIPS 在一些文件操作函数当中&#xff0c;fputc与fgetc这两个函数都是针对字符的&#xff0c;如果说你需要往文件里面去放入整形啊等等&#xff0c;不是字符的类型&#xff0c;这时候就用fprintf&#xff0c;fscanf在参数里面数据类型控制一下就可以。但是话说回来&#xff0c…

自动化测试怎么学?这绝对是全网最系统的教程

目录 1、什么是自动化测试 2、自动化测试的发展前景怎么样 3、自动化测试难不难&#xff1f; 4、目前市场上自动化测试岗位的薪资是多少&#xff1f; 5、自动化测试学习方法好渠道 6、自动化测试怎么学&#xff1f; 学习基础知识 选择自动化测试框架 开始编写测试脚本 …

用HTTP proxy module配置一个反向代理服务器

反向代理与正向代理 摘抄&#xff1a;https://cloud.tencent.com/developer/article/1418457 正向代理 正向代理&#xff08;forward proxy&#xff09;&#xff1a;是一个位于客户端和目标服务器之间的服务器(代理服务器)&#xff0c;为了从目标服务器取得内容&#xff0c;…

“数实融合 元力觉醒”,苏州市元宇宙生态大会圆满召开!

为贯彻落实《苏州市培育元宇宙产业创新发展指导意见》&#xff0c;抢抓数字经济发展新机遇&#xff0c;加速培育与元宇宙发展相关的技术底座&#xff0c;“数实融合 元力觉醒——苏州市软件行业协会元宇宙专委会成立大会暨元宇宙生态大会”于4月14日成功举办。 苏州和数智能软件…

五金件装备不良、视觉检测零件是否缺失硬件方案

【检测目的】 检测不良品 【检测要求】 检测速度&#xff1a;13S一个 【拍摄效果图一】&#xff08;正面&#xff09; 【拍摄效果图二】正面 【拍摄效果图三】正面 【拍摄效果图四】&#xff08;正面&#xff09; 【拍摄效果图五】&#xff08;正面&#xff09; 【拍摄效果图…

如何写好付费专栏之开宗明义篇

大家好,我是herosunly。985院校硕士毕业,现担任算法研究员一职,热衷于机器学习算法研究与应用。曾获得阿里云天池比赛第一名,CCF比赛第二名,科大讯飞比赛第三名。拥有多项发明专利。对机器学习和深度学习拥有自己独到的见解。 本文主要介绍了写好付费专栏的开宗明义篇,希…

电脑上删除的文件可以恢复吗 如何恢复电脑上删除的文件

电脑早已走进千家万户&#xff0c;成为我们不可或缺的家庭设备&#xff0c;我们用电脑来学习、工作&#xff0c;处理各种数据。在使用电脑处理数据时&#xff0c;可能会失误操作&#xff0c;删除重要文件。那么&#xff0c;电脑上删除的文件可以恢复吗&#xff0c;如何恢复电脑…

Python学习笔记--函数进阶

&#xff08;一&#xff09; 函数多返回值 按照返回值的顺序&#xff0c;写对顺序的多个变量接收即可变量之间用逗号隔开支持不同类型的数据return def test_return():return 1,2x,y test_return() print(x) print(y)&#xff08;二&#xff09; 函数的多种传参方式 函数参数…

MySQL批量更新的常用实践

MySQL批量更新的常用实践 批量更新一般在批处理系统或者定时任务中比较常见&#xff0c;常见的诉求就是对表中多条数据进行更新&#xff08;待更新的值是不一样的&#xff0c;这个区别于update … where in(…)&#xff09; 1.利用case … when … 方式批量更新 特点&#x…

5年碌碌无为,我终于从功能测试转到了自动化测试,薪资暴涨8K......

目录&#xff1a;导读前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09;前言 自动化测试现已悄然…

JavaEE企业级应用开发教程——第十二章 Spring MVC数据绑定和相应(黑马程序员第二版)(SSM)

第十二章 Spring MVC数据绑定和相应 12.1 数据绑定 在 Spring MVC 中&#xff0c;当接收到客户端的请求时&#xff0c;会根据请求参数和请求头等信息&#xff0c;将参数以特定的方式转换并绑定到处理器的形参中&#xff0c;这个过程称为数据绑定。数据绑定的流程大致如下&…

Golang每日一练(leetDay0035) 二叉树专题(4)

目录 103. 二叉树的锯齿形层序遍历 Binary Tree Zigzag Level Order Traversal &#x1f31f;&#x1f31f; 104. 二叉树的最大深度 Maximum Depth of Binary-tree] &#x1f31f; 105. 从前序与中序遍历序列构造二叉树 Construct-binary-tree-from-preorder-and-inorder-…

MySQL8.0的安装和配置

&#x1f389;&#x1f389;&#x1f389;点进来你就是我的人了 博主主页&#xff1a;&#x1f648;&#x1f648;&#x1f648;戳一戳,欢迎大佬指点!人生格言&#xff1a;当你的才华撑不起你的野心的时候,你就应该静下心来学习! 欢迎志同道合的朋友一起加油喔&#x1f9be;&am…

结合实际谈谈个人对代码优化的感想以及java优化

前言 本来想写一篇结合在实际工作中&#xff0c;自己去优化java代码的文章&#xff0c;用于记录便于复习提升自己的&#xff1b;但是在回想起自己在实际工作中诸多因素导致存在的问题&#xff08;仅针对我个人&#xff09;&#xff0c;个人总结以及去证实了&#xff0c;所悟&am…