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上做出更多关于色彩渲染的效果。

相关推荐
有梦想的刺儿11 分钟前
webWorker基本用法
前端·javascript·vue.js
cy玩具31 分钟前
点击评论详情,跳到评论页面,携带对象参数写法:
前端
qq_390161771 小时前
防抖函数--应用场景及示例
前端·javascript
John.liu_Test2 小时前
js下载excel示例demo
前端·javascript·excel
Yaml42 小时前
智能化健身房管理:Spring Boot与Vue的创新解决方案
前端·spring boot·后端·mysql·vue·健身房管理
PleaSure乐事2 小时前
【React.js】AntDesignPro左侧菜单栏栏目名称不显示的解决方案
前端·javascript·react.js·前端框架·webstorm·antdesignpro
哟哟耶耶2 小时前
js-将JavaScript对象或值转换为JSON字符串 JSON.stringify(this.SelectDataListCourse)
前端·javascript·json
getaxiosluo2 小时前
react jsx基本语法,脚手架,父子传参,refs等详解
前端·vue.js·react.js·前端框架·hook·jsx
理想不理想v2 小时前
vue种ref跟reactive的区别?
前端·javascript·vue.js·webpack·前端框架·node.js·ecmascript
知孤云出岫2 小时前
web 渗透学习指南——初学者防入狱篇
前端·网络安全·渗透·web