webgl+canvas生成三维线几何螺旋图形效果代码

代码语言:html

所属分类:三维

代码描述:webgl+canvas生成三维线几何螺旋图形效果代码

代码标签: webgl canvas 三维 线 几何 螺旋 图形

下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开

<!DOCTYPE html>
<html lang="en" >

<head>

  <meta charset="UTF-8">

  
  
<style>
body {
  margin: 0;
  overflow: hidden;
}
canvas {
  
  width: 100vw;
  height: 100vh;
}
</style>



</head>

<body  >
  <script type="text/fragment" id="vertShader">#version 300 es
  in vec3 position;
  
  uniform mat4 u_viewMatrix;
  uniform mat4 u_modelMatrix;
  uniform mat4 u_modelViewMatrix;
  uniform mat4 u_projectionMatrix;
  uniform mat3 u_normalMatrix;
  
  out vec3 vNormal;
  out vec3 vPosition;
  out vec3 vWorldPosition;
  out vec2 vUV;
  
  void main() {
    vec4 camPos = u_projectionMatrix * u_modelViewMatrix * vec4(position, 1.0);
    
    gl_Position = camPos;
    
    vWorldPosition = (u_modelMatrix * vec4(0,0,0, 1.0)).xyz;
    vPosition = (u_modelMatrix * vec4(position, 1.0)).xyz;
  }
</script>
<script type="text/fragment" id="fragShader">#version 300 es
  precision highp float;
  
  in vec3 vNormal;
  in vec2 vUV;
  in vec4 camPos;
  in vec3 vPosition;
  in vec3 vWorldPosition;
  
  out vec4 colour;
  
  void main() {
    colour = vec4(1,1,1,1);
  }
</script>

  
      <script type="module">
import {
Obj,
TransformFeedback,
Renderer,
Program,
Mesh,
Uniform,
PointCloud,
GeometryAttribute,
Camera,
Plane,
Texture,
Geometry,
DollyCamera } from
"https://cdn.skypack.dev/wtc-gl@1.0.0-beta.47";

import { Vec2, Vec3, Mat4 } from "https://cdn.skypack.dev/wtc-math@1.0.13";

console.clear();

const d = new Vec2(window.innerWidth, window.innerHeight);
d.update = function () {
  uniforms.u_resolution.value = this.array;
  renderer.dimensions = this;
  camera.........完整代码请登录后点击上方下载按钮下载查看

网友评论0