3、绘制线

绘制线

相关讲解

效果

webgl.LINE_LOOP

webgl.LINES

webgl.LINE_STRIP

代码

复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>绘制点坐标</title>
    <script src="./glMatrix-0.9.6.min.js"></script>
    <script>
        var webgl;
        var projMat4;
        var projMat4 = mat4.create()
        // 顶点着色器
        var vertexString = `
        attribute vec4 a_posiiton;
        uniform mat4 proj;
        void main(){
            gl_Position=proj*a_posiiton;
        }
        `
        // 片元着色器
        var fragmentString = `
        void main(){
            gl_FragColor=vec4(1.0,0,1.0,1.0);
        }
        `
        // 入口函数
        function init() {
            initWebgl()
            initShader()
            initBuffer()
            draw()
        }
        // webgl初始化函数
        function initWebgl() {
            let webglDiv = document.getElementById("webglCanvas")
            // 获取webgl的上下文            
            webgl = webglDiv.getContext("webgl")
            // 设置webgl的视觉区域
            webgl.viewport(0, 0, webglDiv.clientWidth, webglDiv.clientHeight)
            // 设置webgl的投影
            mat4.ortho(0, webglDiv.clientWidth, webglDiv.clientHeight, 0, -1.0, 1.0, projMat4)

        }
        // shader初始化函数
        function initShader() {
            let vsshader = webgl.createShader(webgl.VERTEX_SHADER)
            let fsshader = webgl.createShader(webgl.FRAGMENT_SHADER)
            webgl.shaderSource(vsshader, vertexString)
            webgl.shaderSource(fsshader, fragmentString)
            // 将shader编译进行打包
            webgl.compileShader(vsshader)
            webgl.compileShader(fsshader)
            let program = webgl.createProgram()
            webgl.attachShader(program, vsshader)
            webgl.attachShader(program, fsshader)

            webgl.linkProgram(program)
            webgl.useProgram(program)
            webgl.program = program
        }
        // 数据缓冲区初始化函数
        function initBuffer() {
            let aPosition = webgl.getAttribLocation(webgl.program, "a_posiiton")
            let arr = [
                100.0, 100.0, 0, 1.0,
                200.0, 200.0, 0, 1.0,
                300.0, 200.0, 0, 1.0,
                400.0, 600.0, 0, 1.0
            ]
            let pointPosition = new Float32Array(arr)
            let lineBuffer = webgl.createBuffer()
            webgl.bindBuffer(webgl.ARRAY_BUFFER, lineBuffer)
            webgl.bufferData(webgl.ARRAY_BUFFER, pointPosition, webgl.STATIC_DRAW)
            webgl.enableVertexAttribArray(aPosition)
            //把值赋给shader
            webgl.vertexAttribPointer(aPosition, 4, webgl.FLOAT, false, 4 * 4, 0 * 4)
            // webgl.vertexAttrib4fv(aPosition, pointPosition)
            let uniformproj = webgl.getUniformLocation(webgl.program, "proj")
            webgl.uniformMatrix4fv(uniformproj, false, projMat4)
        }
        // webgl的绘制函数
        function draw() {
            webgl.clearColor(0.0, 0.0, 0.0, 1.0)
            //  颜色检测
            webgl.clear(webgl.COLOR_BUFFER_BIT | webgl.DEPTH_BUFFER_BIT)
            // webgl.drawArrays(webgl.LINE_LOOP, 0, 4)
            webgl.drawArrays(webgl.LINE_STRIP, 0, 4)
            // webgl.drawArrays(webgl.LINES, 0, 4)
        }
    </script>
</head>

<body onload="init()">
    <canvas id="webglCanvas" width="1000" height="800"></canvas>
</body>

</html>
相关推荐
qiao若huan喜3 天前
12、webgl 基本概念 +满天星星眨眼睛
前端·信息可视化·webgl
threelab4 天前
Vue3 + Trilab:打造高扩展性三维可视化插件化框架实战指南
javascript·3d·webgl
qq_12084093715 天前
Vue3 + Three.js 入门实战:从 0 到 1 搭建可交互的 3D 场景(含模型加载与性能优化)
javascript·3d·vue3·交互·webgl·gltf
a1117765 天前
Three.js 的前端 WebGL 页面合集(日本 开源项目)
前端·javascript·webgl
GISer_Jing5 天前
前端图片、动图与动画全解析(含PNG/APNG/Lottie/GIF/Canvas/WebGL/WebGPU)
前端·3d·动画·webgl
GISer_Jing6 天前
前端动画技术全解析:从GIF到WebGPU
前端·ai·动画·webgl
烛阴8 天前
Three.js 材质完全入门指南:让你的 3D 物体「活」起来
webgl·three.js
cTz6FE7gA9 天前
WebGL实战:用Three.js创建3D场景,实现沉浸式Web体验
前端·javascript·webgl
三维搬砖者14 天前
AI 解密大厂 Three.js 三维引擎开发 03|从经纬度到三维世界的坐标解码
webgl·three.js
threelab18 天前
引擎案例分析 02|GeoLayer 大厂地理可视化方案深度拆解
javascript·3d·webgl