LearnGL - 11 - 光与颜色前置篇

    技术2025-01-16  12

    文章目录

    光子眼球大脑接收物体颜色总结References LearnGL - 学习笔记目录

    前些篇:

    LearnGL -10 - 添加各种封装便于后续管理、添加Hierarchy、Inspector 面板LearnGL - 09 - Include IMGUI - Dear ImGui - 添加Dashboard、Debugging PanelIMGUI 系统 - Dear ImGUI

    我们介绍了 IMGUI 系统,这是为了以后能制作一些类似引擎中方便制作、调试用的 GUI 系统。

    但有点偏离了 GL 的主题,所以这篇将会的是 GL 相关话题的内容。

    这篇:我们在后续几篇会开始讲到着色,但在此之前,请允许我再卖个关子(实际上还真的学习了解一下后,对光学就可以有一丢丢了解,3D渲染大多数是光学的经验模型,就是用了简化的方式来模拟的,不然现在的机器要计算比较真实的算法会卡到爆,就连我们现在最真实的PBR基于物理的渲染,或是 RT 光线追踪都只是目前光学总结的经验来计算的,随着以后对光学有了进一步的研究成果,说不了这些模型又会有所更新 )。

    本人才疏学浅,如有什么错误,望不吝指出。


    说到颜色,就会联系到光。

    个人理解:颜色,就是我们的大脑对某种生物信号的识别,这种生物信号是由:眼球感光后的视网神经编码的生物电信号。

    #mermaid-svg-5OS91dwK6hGLOiGp .label{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);fill:#333;color:#333}#mermaid-svg-5OS91dwK6hGLOiGp .label text{fill:#333}#mermaid-svg-5OS91dwK6hGLOiGp .node rect,#mermaid-svg-5OS91dwK6hGLOiGp .node circle,#mermaid-svg-5OS91dwK6hGLOiGp .node ellipse,#mermaid-svg-5OS91dwK6hGLOiGp .node polygon,#mermaid-svg-5OS91dwK6hGLOiGp .node path{fill:#ECECFF;stroke:#9370db;stroke-width:1px}#mermaid-svg-5OS91dwK6hGLOiGp .node .label{text-align:center;fill:#333}#mermaid-svg-5OS91dwK6hGLOiGp .node.clickable{cursor:pointer}#mermaid-svg-5OS91dwK6hGLOiGp .arrowheadPath{fill:#333}#mermaid-svg-5OS91dwK6hGLOiGp .edgePath .path{stroke:#333;stroke-width:1.5px}#mermaid-svg-5OS91dwK6hGLOiGp .flowchart-link{stroke:#333;fill:none}#mermaid-svg-5OS91dwK6hGLOiGp .edgeLabel{background-color:#e8e8e8;text-align:center}#mermaid-svg-5OS91dwK6hGLOiGp .edgeLabel rect{opacity:0.9}#mermaid-svg-5OS91dwK6hGLOiGp .edgeLabel span{color:#333}#mermaid-svg-5OS91dwK6hGLOiGp .cluster rect{fill:#ffffde;stroke:#aa3;stroke-width:1px}#mermaid-svg-5OS91dwK6hGLOiGp .cluster text{fill:#333}#mermaid-svg-5OS91dwK6hGLOiGp div.mermaidTooltip{position:absolute;text-align:center;max-width:200px;padding:2px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);font-size:12px;background:#ffffde;border:1px solid #aa3;border-radius:2px;pointer-events:none;z-index:100}#mermaid-svg-5OS91dwK6hGLOiGp .actor{stroke:#ccf;fill:#ECECFF}#mermaid-svg-5OS91dwK6hGLOiGp text.actor>tspan{fill:#000;stroke:none}#mermaid-svg-5OS91dwK6hGLOiGp .actor-line{stroke:grey}#mermaid-svg-5OS91dwK6hGLOiGp .messageLine0{stroke-width:1.5;stroke-dasharray:none;stroke:#333}#mermaid-svg-5OS91dwK6hGLOiGp .messageLine1{stroke-width:1.5;stroke-dasharray:2, 2;stroke:#333}#mermaid-svg-5OS91dwK6hGLOiGp #arrowhead path{fill:#333;stroke:#333}#mermaid-svg-5OS91dwK6hGLOiGp .sequenceNumber{fill:#fff}#mermaid-svg-5OS91dwK6hGLOiGp #sequencenumber{fill:#333}#mermaid-svg-5OS91dwK6hGLOiGp #crosshead path{fill:#333;stroke:#333}#mermaid-svg-5OS91dwK6hGLOiGp .messageText{fill:#333;stroke:#333}#mermaid-svg-5OS91dwK6hGLOiGp .labelBox{stroke:#ccf;fill:#ECECFF}#mermaid-svg-5OS91dwK6hGLOiGp .labelText,#mermaid-svg-5OS91dwK6hGLOiGp .labelText>tspan{fill:#000;stroke:none}#mermaid-svg-5OS91dwK6hGLOiGp .loopText,#mermaid-svg-5OS91dwK6hGLOiGp .loopText>tspan{fill:#000;stroke:none}#mermaid-svg-5OS91dwK6hGLOiGp .loopLine{stroke-width:2px;stroke-dasharray:2, 2;stroke:#ccf;fill:#ccf}#mermaid-svg-5OS91dwK6hGLOiGp .note{stroke:#aa3;fill:#fff5ad}#mermaid-svg-5OS91dwK6hGLOiGp .noteText,#mermaid-svg-5OS91dwK6hGLOiGp .noteText>tspan{fill:#000;stroke:none}#mermaid-svg-5OS91dwK6hGLOiGp .activation0{fill:#f4f4f4;stroke:#666}#mermaid-svg-5OS91dwK6hGLOiGp .activation1{fill:#f4f4f4;stroke:#666}#mermaid-svg-5OS91dwK6hGLOiGp .activation2{fill:#f4f4f4;stroke:#666}#mermaid-svg-5OS91dwK6hGLOiGp .mermaid-main-font{font-family:"trebuchet ms", verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-5OS91dwK6hGLOiGp .section{stroke:none;opacity:0.2}#mermaid-svg-5OS91dwK6hGLOiGp .section0{fill:rgba(102,102,255,0.49)}#mermaid-svg-5OS91dwK6hGLOiGp .section2{fill:#fff400}#mermaid-svg-5OS91dwK6hGLOiGp .section1,#mermaid-svg-5OS91dwK6hGLOiGp .section3{fill:#fff;opacity:0.2}#mermaid-svg-5OS91dwK6hGLOiGp .sectionTitle0{fill:#333}#mermaid-svg-5OS91dwK6hGLOiGp .sectionTitle1{fill:#333}#mermaid-svg-5OS91dwK6hGLOiGp .sectionTitle2{fill:#333}#mermaid-svg-5OS91dwK6hGLOiGp .sectionTitle3{fill:#333}#mermaid-svg-5OS91dwK6hGLOiGp .sectionTitle{text-anchor:start;font-size:11px;text-height:14px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-5OS91dwK6hGLOiGp .grid .tick{stroke:#d3d3d3;opacity:0.8;shape-rendering:crispEdges}#mermaid-svg-5OS91dwK6hGLOiGp .grid .tick text{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-5OS91dwK6hGLOiGp .grid path{stroke-width:0}#mermaid-svg-5OS91dwK6hGLOiGp .today{fill:none;stroke:red;stroke-width:2px}#mermaid-svg-5OS91dwK6hGLOiGp .task{stroke-width:2}#mermaid-svg-5OS91dwK6hGLOiGp .taskText{text-anchor:middle;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-5OS91dwK6hGLOiGp .taskText:not([font-size]){font-size:11px}#mermaid-svg-5OS91dwK6hGLOiGp .taskTextOutsideRight{fill:#000;text-anchor:start;font-size:11px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-5OS91dwK6hGLOiGp .taskTextOutsideLeft{fill:#000;text-anchor:end;font-size:11px}#mermaid-svg-5OS91dwK6hGLOiGp .task.clickable{cursor:pointer}#mermaid-svg-5OS91dwK6hGLOiGp .taskText.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-5OS91dwK6hGLOiGp .taskTextOutsideLeft.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-5OS91dwK6hGLOiGp .taskTextOutsideRight.clickable{cursor:pointer;fill:#003163 !important;font-weight:bold}#mermaid-svg-5OS91dwK6hGLOiGp .taskText0,#mermaid-svg-5OS91dwK6hGLOiGp .taskText1,#mermaid-svg-5OS91dwK6hGLOiGp .taskText2,#mermaid-svg-5OS91dwK6hGLOiGp .taskText3{fill:#fff}#mermaid-svg-5OS91dwK6hGLOiGp .task0,#mermaid-svg-5OS91dwK6hGLOiGp .task1,#mermaid-svg-5OS91dwK6hGLOiGp .task2,#mermaid-svg-5OS91dwK6hGLOiGp .task3{fill:#8a90dd;stroke:#534fbc}#mermaid-svg-5OS91dwK6hGLOiGp .taskTextOutside0,#mermaid-svg-5OS91dwK6hGLOiGp .taskTextOutside2{fill:#000}#mermaid-svg-5OS91dwK6hGLOiGp .taskTextOutside1,#mermaid-svg-5OS91dwK6hGLOiGp .taskTextOutside3{fill:#000}#mermaid-svg-5OS91dwK6hGLOiGp .active0,#mermaid-svg-5OS91dwK6hGLOiGp .active1,#mermaid-svg-5OS91dwK6hGLOiGp .active2,#mermaid-svg-5OS91dwK6hGLOiGp .active3{fill:#bfc7ff;stroke:#534fbc}#mermaid-svg-5OS91dwK6hGLOiGp .activeText0,#mermaid-svg-5OS91dwK6hGLOiGp .activeText1,#mermaid-svg-5OS91dwK6hGLOiGp .activeText2,#mermaid-svg-5OS91dwK6hGLOiGp .activeText3{fill:#000 !important}#mermaid-svg-5OS91dwK6hGLOiGp .done0,#mermaid-svg-5OS91dwK6hGLOiGp .done1,#mermaid-svg-5OS91dwK6hGLOiGp .done2,#mermaid-svg-5OS91dwK6hGLOiGp .done3{stroke:grey;fill:#d3d3d3;stroke-width:2}#mermaid-svg-5OS91dwK6hGLOiGp .doneText0,#mermaid-svg-5OS91dwK6hGLOiGp .doneText1,#mermaid-svg-5OS91dwK6hGLOiGp .doneText2,#mermaid-svg-5OS91dwK6hGLOiGp .doneText3{fill:#000 !important}#mermaid-svg-5OS91dwK6hGLOiGp .crit0,#mermaid-svg-5OS91dwK6hGLOiGp .crit1,#mermaid-svg-5OS91dwK6hGLOiGp .crit2,#mermaid-svg-5OS91dwK6hGLOiGp .crit3{stroke:#f88;fill:red;stroke-width:2}#mermaid-svg-5OS91dwK6hGLOiGp .activeCrit0,#mermaid-svg-5OS91dwK6hGLOiGp .activeCrit1,#mermaid-svg-5OS91dwK6hGLOiGp .activeCrit2,#mermaid-svg-5OS91dwK6hGLOiGp .activeCrit3{stroke:#f88;fill:#bfc7ff;stroke-width:2}#mermaid-svg-5OS91dwK6hGLOiGp .doneCrit0,#mermaid-svg-5OS91dwK6hGLOiGp .doneCrit1,#mermaid-svg-5OS91dwK6hGLOiGp .doneCrit2,#mermaid-svg-5OS91dwK6hGLOiGp .doneCrit3{stroke:#f88;fill:#d3d3d3;stroke-width:2;cursor:pointer;shape-rendering:crispEdges}#mermaid-svg-5OS91dwK6hGLOiGp .milestone{transform:rotate(45deg) scale(0.8, 0.8)}#mermaid-svg-5OS91dwK6hGLOiGp .milestoneText{font-style:italic}#mermaid-svg-5OS91dwK6hGLOiGp .doneCritText0,#mermaid-svg-5OS91dwK6hGLOiGp .doneCritText1,#mermaid-svg-5OS91dwK6hGLOiGp .doneCritText2,#mermaid-svg-5OS91dwK6hGLOiGp .doneCritText3{fill:#000 !important}#mermaid-svg-5OS91dwK6hGLOiGp .activeCritText0,#mermaid-svg-5OS91dwK6hGLOiGp .activeCritText1,#mermaid-svg-5OS91dwK6hGLOiGp .activeCritText2,#mermaid-svg-5OS91dwK6hGLOiGp .activeCritText3{fill:#000 !important}#mermaid-svg-5OS91dwK6hGLOiGp .titleText{text-anchor:middle;font-size:18px;fill:#000;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-5OS91dwK6hGLOiGp g.classGroup text{fill:#9370db;stroke:none;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family);font-size:10px}#mermaid-svg-5OS91dwK6hGLOiGp g.classGroup text .title{font-weight:bolder}#mermaid-svg-5OS91dwK6hGLOiGp g.clickable{cursor:pointer}#mermaid-svg-5OS91dwK6hGLOiGp g.classGroup rect{fill:#ECECFF;stroke:#9370db}#mermaid-svg-5OS91dwK6hGLOiGp g.classGroup line{stroke:#9370db;stroke-width:1}#mermaid-svg-5OS91dwK6hGLOiGp .classLabel .box{stroke:none;stroke-width:0;fill:#ECECFF;opacity:0.5}#mermaid-svg-5OS91dwK6hGLOiGp .classLabel .label{fill:#9370db;font-size:10px}#mermaid-svg-5OS91dwK6hGLOiGp .relation{stroke:#9370db;stroke-width:1;fill:none}#mermaid-svg-5OS91dwK6hGLOiGp .dashed-line{stroke-dasharray:3}#mermaid-svg-5OS91dwK6hGLOiGp #compositionStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-5OS91dwK6hGLOiGp #compositionEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-5OS91dwK6hGLOiGp #aggregationStart{fill:#ECECFF;stroke:#9370db;stroke-width:1}#mermaid-svg-5OS91dwK6hGLOiGp #aggregationEnd{fill:#ECECFF;stroke:#9370db;stroke-width:1}#mermaid-svg-5OS91dwK6hGLOiGp #dependencyStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-5OS91dwK6hGLOiGp #dependencyEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-5OS91dwK6hGLOiGp #extensionStart{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-5OS91dwK6hGLOiGp #extensionEnd{fill:#9370db;stroke:#9370db;stroke-width:1}#mermaid-svg-5OS91dwK6hGLOiGp .commit-id,#mermaid-svg-5OS91dwK6hGLOiGp .commit-msg,#mermaid-svg-5OS91dwK6hGLOiGp .branch-label{fill:lightgrey;color:lightgrey;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-5OS91dwK6hGLOiGp .pieTitleText{text-anchor:middle;font-size:25px;fill:#000;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-5OS91dwK6hGLOiGp .slice{font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-5OS91dwK6hGLOiGp g.stateGroup text{fill:#9370db;stroke:none;font-size:10px;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-5OS91dwK6hGLOiGp g.stateGroup text{fill:#9370db;fill:#333;stroke:none;font-size:10px}#mermaid-svg-5OS91dwK6hGLOiGp g.statediagram-cluster .cluster-label text{fill:#333}#mermaid-svg-5OS91dwK6hGLOiGp g.stateGroup .state-title{font-weight:bolder;fill:#000}#mermaid-svg-5OS91dwK6hGLOiGp g.stateGroup rect{fill:#ECECFF;stroke:#9370db}#mermaid-svg-5OS91dwK6hGLOiGp g.stateGroup line{stroke:#9370db;stroke-width:1}#mermaid-svg-5OS91dwK6hGLOiGp .transition{stroke:#9370db;stroke-width:1;fill:none}#mermaid-svg-5OS91dwK6hGLOiGp .stateGroup .composit{fill:white;border-bottom:1px}#mermaid-svg-5OS91dwK6hGLOiGp .stateGroup .alt-composit{fill:#e0e0e0;border-bottom:1px}#mermaid-svg-5OS91dwK6hGLOiGp .state-note{stroke:#aa3;fill:#fff5ad}#mermaid-svg-5OS91dwK6hGLOiGp .state-note text{fill:black;stroke:none;font-size:10px}#mermaid-svg-5OS91dwK6hGLOiGp .stateLabel .box{stroke:none;stroke-width:0;fill:#ECECFF;opacity:0.7}#mermaid-svg-5OS91dwK6hGLOiGp .edgeLabel text{fill:#333}#mermaid-svg-5OS91dwK6hGLOiGp .stateLabel text{fill:#000;font-size:10px;font-weight:bold;font-family:'trebuchet ms', verdana, arial;font-family:var(--mermaid-font-family)}#mermaid-svg-5OS91dwK6hGLOiGp .node circle.state-start{fill:black;stroke:black}#mermaid-svg-5OS91dwK6hGLOiGp .node circle.state-end{fill:black;stroke:white;stroke-width:1.5}#mermaid-svg-5OS91dwK6hGLOiGp #statediagram-barbEnd{fill:#9370db}#mermaid-svg-5OS91dwK6hGLOiGp .statediagram-cluster rect{fill:#ECECFF;stroke:#9370db;stroke-width:1px}#mermaid-svg-5OS91dwK6hGLOiGp .statediagram-cluster rect.outer{rx:5px;ry:5px}#mermaid-svg-5OS91dwK6hGLOiGp .statediagram-state .divider{stroke:#9370db}#mermaid-svg-5OS91dwK6hGLOiGp .statediagram-state .title-state{rx:5px;ry:5px}#mermaid-svg-5OS91dwK6hGLOiGp .statediagram-cluster.statediagram-cluster .inner{fill:white}#mermaid-svg-5OS91dwK6hGLOiGp .statediagram-cluster.statediagram-cluster-alt .inner{fill:#e0e0e0}#mermaid-svg-5OS91dwK6hGLOiGp .statediagram-cluster .inner{rx:0;ry:0}#mermaid-svg-5OS91dwK6hGLOiGp .statediagram-state rect.basic{rx:5px;ry:5px}#mermaid-svg-5OS91dwK6hGLOiGp .statediagram-state rect.divider{stroke-dasharray:10,10;fill:#efefef}#mermaid-svg-5OS91dwK6hGLOiGp .note-edge{stroke-dasharray:5}#mermaid-svg-5OS91dwK6hGLOiGp .statediagram-note rect{fill:#fff5ad;stroke:#aa3;stroke-width:1px;rx:0;ry:0}:root{--mermaid-font-family: '"trebuchet ms", verdana, arial';--mermaid-font-family: "Comic Sans MS", "Comic Sans", cursive}#mermaid-svg-5OS91dwK6hGLOiGp .error-icon{fill:#522}#mermaid-svg-5OS91dwK6hGLOiGp .error-text{fill:#522;stroke:#522}#mermaid-svg-5OS91dwK6hGLOiGp .edge-thickness-normal{stroke-width:2px}#mermaid-svg-5OS91dwK6hGLOiGp .edge-thickness-thick{stroke-width:3.5px}#mermaid-svg-5OS91dwK6hGLOiGp .edge-pattern-solid{stroke-dasharray:0}#mermaid-svg-5OS91dwK6hGLOiGp .edge-pattern-dashed{stroke-dasharray:3}#mermaid-svg-5OS91dwK6hGLOiGp .edge-pattern-dotted{stroke-dasharray:2}#mermaid-svg-5OS91dwK6hGLOiGp .marker{fill:#333}#mermaid-svg-5OS91dwK6hGLOiGp .marker.cross{stroke:#333} :root { --mermaid-font-family: "trebuchet ms", verdana, arial;} #mermaid-svg-5OS91dwK6hGLOiGp { color: rgba(0, 0, 0, 0.75); font: ; } 分不同光波 编码可见光 大脑接收解码 光子 眼球 大脑接收 呈像

    光子

    光是什么?是如何产生的?用通俗之言解读,让你瞬间走进光的世界 - 说的是能量溢出

    也就是说光子是基本上是从一个物质上能量溢出后而喷发出来的微粒子

    而光子是按一定的波形运动的微粒子,所以具有波粒二象性

    而光子的波形运动的频率一般取决于它拥有的能量强度,所以能量强的光子波形运动频率很高,能量低的光子波形运动频率比较低。

    用这个频率划分,我们得到一个光谱,我们人类能看见的光,在光谱中只有一部分的区域

    我们平时看到的光基本是复合光,就是不是单一的频率的光子,而是有N而不同频率(波段)的光子几乎一起并排前行的光束,这在1666年,被牛顿的三棱镜实验所发现 三棱镜,是 按照一定的光入射角度,一定的光折射率,一定的光出射角度 来制作的,这样一道光入射三棱镜后,按角度和折射将复合光波(多个波段),折射角度偏差出多个不同波频的光波物质内部传递,在出射时按表面角度再折射出偏差更大的角度,这些复合光被折射出不同的单一光波,如下图所示

    弄个GIF会更容易理解

    目前这是以我们可见光波的散射的示意图

    可以看到上面折射角度比较小的是红色的(波频比较低)的光波,折射角度比较大的是紫色的(波频比较大)的光波

    所以我们日常说的:

    红外线:比红色可见光更低波频的光线,这些光波因为超出我们肉眼能识别的波段,所以 看不见紫外线:比紫色可见光更高波频的光线,这些光波因为超出我们肉眼能识别的波段,所以 看不见

    (为何紫外线对人、或部分生物有害,因为能量大,波频大,一般物质,如我们的皮肤物质挡不了这种波频的高能光子就会不断撞击我们皮肤、血、肉、骨头,还有叫 X 射线、伽马射线 就是非常高能的光子、光线,高到可以对我们的细胞 DNA 结构进行破坏的程度,所以一般做了 X 光等高能射线的医疗设备检查是不能太长时间的,而且如果有备孕计划的话,就不要去做,如果要做,就要等至少半年以上,等一些被这些高能射线破坏的 DNA 结构的细胞慢慢的修复或是消灭了,恢复正常了,再进行造人计划,这样可以避免因高能射线引用胎儿畸形)


    眼球

    先来看看,我们的眼球结构 眼球里的 视网膜 是大量感光细胞所在的地方

    人的视网膜上有两种光感受细胞,分别是视锥细胞和视杆细胞。其中,视锥细胞主要与光视觉有关,具有分辨能力高、清晰度高的特点。能分辨三种不同的视色素(红绿蓝),是识别颜色的主要细胞

    目前科学实验人的眼睛最低能识别 2~7 个光子

    视网膜就是下图所示的部分

    如果一道光要射入、碰撞到我们眼球视网膜,那么肯定会经过下图的路径:

    空气或其他外界介质(空气或水,在水底)眼睛表面液体角膜前房瞳孔晶状体玻璃体视网膜

    所谓困难重重的才到达我们的眼球视网膜

    每个阶段可能发生吸收、折射、等,而达到不了视网膜(看不见)

    而我们的视网膜上的视锥细胞能识别的光波波段是有限的,上面有讲到,再看看下图:

    然后眼球视网膜的视锥细胞将感受到的可见光波撞击到的强弱的信号编码处理通过 视觉神经 传输,最终传输到大脑,视觉神经如下图


    大脑接收

    大脑接收到上面的视觉神经传递过来的生物电信号后,再进行解码或处理后,最后我们就感知到整个图像


    物体颜色

    而不同的物体为何有何这不同的颜色呢?

    按上面理解的就是这个物体的这个位置有光子向着我们的眼球撞击过来

    这个光子是物体发射出来的吗?还是怎么来的?

    前面有讲到,它是因为物质能的能量溢出而发射出来的,但是否这个物体本身发射出来的光子

    我们可以通过开灯、关灯实验

    在一个完全密封的房间里,装有一个灯管,等我们关灯后,如果还能看见的物体,那就说明这个物体本身在发光(发射光子),否则没有发光(也不一定没有发射,有可能也有发射光子,只不过这些光子波频太低,以至于超出我们肉眼视锥细胞能感光的范围)。

    但为什么那些自身不发光的物体,我们开灯后它就可以看见了?而且有些还和灯光不一样的颜色。

    如,我们的 灯管是白光,开灯后看到一个 红色的苹果,为何会这样呢?再关灯后,又看不见这个红色的苹果了。

    那么只有一种可能,这个红色的苹果因为在接收到一个 白光(复合光)后,因为吸收了部分光线(光子) ,而没有吸收成功的,可能最终被苹果表面物质微粒子反弹了,最后这些剩余没被苹果吸收的光子反弹到我们的眼球。

    而且你再细心观察苹果的每一个细小的地方你会发现,每一处的颜色都可能未必是相同的(albedo 反射率,在目前常规的 3D 渲染中,我们通常用一张纹理来表示表面的不同吸收率,或是反射率),苹果与灯光不同角度有些地方暗一些,有些地方亮一些(diffuse 漫反射),有些地方亮到和灯管发光的颜色一样(specular 反射高光),在白天时将苹果拿到户外又不一样,整体比较亮(ambient 环境光,室外的 ambient 比室内的丰富),这些都是简化过的经验光照模型 Phong,都是经过观察得到的规律总结。另外,PBR(Physical Base Rendering 基于物理的渲染) 的光照模型比较复杂。

    而我们在 OpenGL 等渲染系统中,一般只会处理可见光部分(部分不可见的或超过 1 的通道光,我们会来用处理 HDR 效果,可以让一些 Bloom 数据容易,合理的提取到),在 fragment shader 着色器中,通常可以以 RGB (R红色,G绿色,B蓝色)的三个 BYTE 字节来模拟复合光,每个 BYTE 可以用 0~255 的范围,三个 BYTE 就可以模拟出 255 * 255 * 255 = 16581375,可以模拟 1658W+ 中颜色,但一般我们会有归一化的0.0~1.0的浮点数值来表示 RGB 颜色通道的值,后面也会也这个归一化的值来描述。


    总结

    最后思考一下,如果没有光,我们就感受不到光这种信号吗?

    如果我们对这种信号数据了解足够清楚,我们可以使用机器来生成这种信号,并且对大脑信号输入了解足够清楚,我们也可以使用人机连接(大脑连接机器设备)后,用设备生成我们人类呈像的信号,传入大脑,那就不用眼球也能脑部感受到类型光子撞击我们的视网膜的生物电信息,就可以让一个人的大脑感光、呈像。


    References

    颜色
    Processed: 0.010, SQL: 9