webgl(二)绘制两种颜色的竖条纹

绘制两种颜色的竖条纹的方式:

一、在webgl中通过坐标分界线分割颜色

在顶点着色器中将gl_PointSize的值加大,看到的效果会明显一些。

glsl 复制代码
let vertexSource = /*glsl*/`
void main() {
    gl_Position = vec4(0.0, 0.0, 0.0, 1.0);
    gl_PointSize = 200.0;
}
`

首先,得知道绘制颜色是在着色器程序当中使用。片元着色器的代码如下所示

glsl 复制代码
let fragmentShader = /*glsl*/ `
precision mediump float;
void main() {
//400 * 400对应的是canvas画布的尺寸
	float x = (gl_FragCoord.x / 400.0 - 0.5) * 2.0;
	if(x > 0.0) {
		gl_FragColor = vec4(1.0, 0.0, 0.0, 1.0);//红色
	} else {
		gl_FragColor = vec4(0.0, 0.0, 1.0, 1.0);//蓝色
	}
}
`

如上述代码所示,当x的坐标大于0的时候,显示红色;反之显示蓝色。这个判断很简单,但是如何去判断x的坐标的呢?也就是float x = (gl_FragCoord.x / 400.0 - 0.5) * 2.0;这行代码得好好解读一下。

  1. gl_FragCoord.x:这是一个内建变量,用户获取当前片段(像素)的横坐标(x坐标)。
  2. 400.0:这个数值代表的是canvas画布的宽度,所以要先检查下自己的画布的宽度是多少像素,默认是512px的哦。
  3. gl_FragCoord.x / 400.0 - 0.5:这一部分将当前像素的横坐标值转换为介于[-0.5, 0.5]范围内的值。它通过将gl_FragCoord.x除以画布的宽度,并从结果中减去0.5来实现。(不难理解,gl_FragCoord.x / 400.0的值的范围在[0,1])
  4. *2:这一部分将前一步中计算得到的值缩放到[-1, 1]的范围内。将[-0.5, 0.5]的值乘以2.0,可以将其映射到[-1, 1]的范围内。

二、通过threejs中的自动UV 映射

UV映射(也称为纹理坐标)用于将二维纹理映射到三维物体表面。UV坐标定义了纹理图像上的位置,他们与三维模型的顶点一一对应。 通过在顶点着色器中使用UV坐标,并将它们传递给片元着色器,在片元着色器中可以使用这些坐标来从纹理图像中获取对应位置的颜色或其他纹理信息。这样,就可以在渲染过程中将纹理贴图应用于三维模型,实现更加真实和丰富的表面效果。

在threejs中自动生成的uv坐标是根据几何体的拓扑结构和顶点位置来计算的(讲人话就是:根据几何体的形状生成的)。如果要在webgl中实现这个计算,emmmm......应该还是蛮复杂的,需要进行一些遍历和插值等等,这难道是八青妹这种菜鸟能够理解的吗?

这个步骤分两步.

第一步,在顶点着色器中赋值uv

ini 复制代码
const vertexShader = /* GLSL */ `
	uniform float uTime;
	varying vec2 vUv;
	void main() {
		vUv = uv;//这里给vUv赋值默认的uv
		gl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);
	}
`;

第二步,在片元着色器中接收uv

csharp 复制代码
const fragmentShader = /* GLSL */ `
varying vec2 vUv;
void main() {
	gl_FragColor = vec4(vUv.y, 0.0, 0.0, 1.0);//下边黑,上边红
}
`

在这段代码中vUv.y是在渲染的时候,这个值从0.0→1.0 ,显示图为下边黑,上边红;

那么,如果将上述的vUv.y改为vUv.X,这个值也是从0.0→1.0 ,但是在图像是显示的是左边黑,右边红; UV坐标中,(0, 0)表示纹理的左下角,而(1, 1)表示右上角。为0的情况,结合后面的两个颜色通道都为0就是黑色,为1的时候,就是红色。

总结

如果已经使用了threejs库,第二种方式要优雅的多,甚至可以在shader上做出更多关于色彩渲染的效果。

相关推荐
gqkmiss14 分钟前
Chrome 浏览器插件获取网页 iframe 中的 window 对象
前端·chrome·iframe·postmessage·chrome 插件
m0_748247552 小时前
Web 应用项目开发全流程解析与实战经验分享
开发语言·前端·php
m0_748255023 小时前
前端常用算法集合
前端·算法
真的很上进3 小时前
如何借助 Babel+TS+ESLint 构建现代 JS 工程环境?
java·前端·javascript·css·react.js·vue·html
web130933203983 小时前
vue elementUI form组件动态添加el-form-item并且动态添加rules必填项校验方法
前端·vue.js·elementui
NiNg_1_2344 小时前
Echarts连接数据库,实时绘制图表详解
前端·数据库·echarts
如若1234 小时前
对文件内的文件名生成目录,方便查阅
java·前端·python
滚雪球~5 小时前
npm error code ETIMEDOUT
前端·npm·node.js
沙漏无语5 小时前
npm : 无法加载文件 D:\Nodejs\node_global\npm.ps1,因为在此系统上禁止运行脚本
前端·npm·node.js
supermapsupport5 小时前
iClient3D for Cesium在Vue中快速实现场景卷帘
前端·vue.js·3d·cesium·supermap