返回顶部
首页 > 资讯 > 精选 >glsl buffer如何实现渐变三角形
  • 132
分享到

glsl buffer如何实现渐变三角形

2023-07-05 19:07:55 132人浏览 安东尼
摘要

本文小编为大家详细介绍“glsl_buffer如何实现渐变三角形”,内容详细,步骤清晰,细节处理妥当,希望这篇“glsl_buffer如何实现渐变三角形”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。三角形我们通过

本文小编为大家详细介绍“glsl_buffer如何实现渐变三角形”,内容详细,步骤清晰,细节处理妥当,希望这篇“glsl_buffer如何实现渐变三角形”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

    三角形

    我们通过glsl画一个三角形需要的是三个坐标系中的点,三点成面。而我们在使用glsl画一个动态点用到的是vertexAttrib2fvertexShader传递位置坐标,通过drawArrays绘制点。绘制一个三角形也是类似的思想,但是多顶点我们就不能以vertexAttrib2f的形式传递参数,这时我们就要用到buffer。

    创建一个buffer

    第一步我们需要创建一个buffer容器并绑定它

    //创建一个bufferlet buffer = gl.createBuffer();//绑定buffergl.bindBuffer(gl.ARRAY_BUFFER, buffer);

    传递数据

    通过Float32Array对象创建一个点位信息组合,并传递到buffer中

    let vertices = [    ......];vertices = new Float32Array(vertices); //创建一个float对象//传数据gl.bufferData(gl.ARRAY_BUFFER, vertices, gl.STATIC_DRAW);

    分析

    我们实现一个三角形需要的是三个二维的坐标点,所以我们需将vertices中的数据以俩俩一组的形式呈现。如何实现渐变呢? 我们不仅要存顶点位置信息也要存颜色rab信息,所以我们在vertices中需以5个float为一组传递给attribute。

    三角形buffer数据及着色器信息

    let vertices = [  -0.5,  0.0,  1.0,  0.0,  0.0, //顶点1  0.0,  0.8,  0.0,  1.0,  0.0, //顶点2  0.5,  0.0,  0.0,  0.0,  1.0, //顶点3];//顶点着色器,声明a_position和a_Color的attribute属性,v_Color的varying属性let vertexShader = `   attribute vec2 a_position;  attribute vec3 a_Color;  varying vec3 v_Color;  void main(){    v_Color = a_Color;    gl_Position = vec4(a_position,0.0,1.0);  }`;//片源着色器let fragmentShader = `    precision mediump float;    varying vec3 v_Color;    void main() {     gl_FraGColor = vec4(v_Color,1.0);    }`;

    buffer赋值attribute

    这里用到了glsl通信相关知识,我就不做展开,不了解的可以查看我的第一篇glsl开篇文章中有详细介绍~ 这里需要获取到attribute的内存地址,并将buffer中的数据传递给attribute。这里面有一些注意点,由于我们采用5个float一组的形式,前两位是位置信息、后三位存储颜色rgb,所以在传递前我们需告知attribute一组有几位且从第几位开始拾取~

    let FSIZE = vertices.BYTES_PER_ELEMENT; //每一个值占用多少字节 float32为4字节

    //把buffer赋值给attributelet a_position = gl.getAttribLocation(webGL.program, "a_position");let a_Color = gl.getAttribLocation(WEBgl.program, "a_Color");gl.vertexAttribPointer(  a_position, //vertexshader里面的变量的地址  2, //size:attribute变量的长度(几个一组)  gl.FLOAT, //数据类型 float  false, //归一化 相当于length等于1  FSIZE * 5, //stride:每个点(组)的信息所占用的字节BYTES  0 // offset:偏移(从第几个开始));gl.vertexAttribPointer(a_Color, 3, gl.FLOAT, false, FSIZE * 5, FSIZE * 2);//确认赋值gl.enableVertexAttribArray(a_position);gl.enableVertexAttribArray(a_Color);

    绘制三角形

    完成上方的buffer绑定以及传递attribute后,我们只需最后绘制三角形就行了~

    //画三角形gl.drawArrays(gl.TRIANGLES, 0, 3);

    效果

    glsl buffer如何实现渐变三角形

    读到这里,这篇“glsl_buffer如何实现渐变三角形”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网精选频道。

    --结束END--

    本文标题: glsl buffer如何实现渐变三角形

    本文链接: https://lsjlt.com/news/354913.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    猜你喜欢
    • glsl buffer如何实现渐变三角形
      本文小编为大家详细介绍“glsl_buffer如何实现渐变三角形”,内容详细,步骤清晰,细节处理妥当,希望这篇“glsl_buffer如何实现渐变三角形”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。三角形我们通过...
      99+
      2023-07-05
    • css3线性渐变怎么实现三角形
      这篇文章主要介绍了css3线性渐变怎么实现三角形的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇css3线性渐变怎么实现三角形文章都会有所收获,下面我们一起来看看吧。 ...
      99+
      2024-04-02
    • glsl_buffer实现渐变三角形方法详解
      目录正文三角形创建一个buffer传递数据分析三角形buffer数据及着色器信息buffer赋值attribute绘制三角形效果结语正文 上篇文章我简单封装了一个glsl的程序类,...
      99+
      2023-05-14
      glsl buffer渐变三角形 glsl buffer渐变
    • css如何实现三角形
      css实现三角形的方法::1、创建html文件;2、添加html代码架构;3、在body标签中使用div标签来显示三角形;4、添加script标签并写入css样式代码来实现三角形;5、通过浏览器方式查看设计效果。具体操作方法:首先创建一个h...
      99+
      2024-04-02
    • 如何用css实现三角形
      本篇内容介绍了“如何用css实现三角形”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
      99+
      2024-04-02
    • 纯css如何实现三角形
      本篇内容介绍了“纯css如何实现三角形”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!css实现三角的原理:首先确定底边是哪个方向,并设置哪个...
      99+
      2023-07-04
    • 如何使用CSS实现三角形
      这篇文章将为大家详细讲解有关如何使用CSS实现三角形,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。相信大家在浏览网站的时候,经常看到各种下拉菜单,上面会有一个小小的三角形...
      99+
      2024-04-02
    • css3中渐变如何改变角度
      这篇文章主要讲解了“css3中渐变如何改变角度”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“css3中渐变如何改变角度”吧! 在...
      99+
      2024-04-02
    • java实现三角形分形山脉
      本文实例为大家分享了java实现三角形分形山脉的具体代码,供大家参考,具体内容如下 三角形分形山脉原理 原型图 如图,这是三角形分形山脉的一个原型图。首先我们让x1、x2、x3三个...
      99+
      2024-04-02
    • C++实现LeetCode(120.三角形)
      [LeetCode] 120.Triangle 三角形 Given a triangle, find the minimum path sum from top to bottom....
      99+
      2024-04-02
    • Android编程实现带渐变效果的圆角矩形示例
      本文实例讲述了Android编程实现带渐变效果的圆角矩形。分享给大家供大家参考,具体如下:public class RoundRectsActivity extends Activity { @Override protected vo...
      99+
      2023-05-30
      android 渐变 圆角矩形
    • web开发中如何实现空心三角形
      小编给大家分享一下web开发中如何实现空心三角形,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!背景: 项目过程中有个tab切换需...
      99+
      2024-04-02
    • css3如何实现三角形带边框效果
      这篇文章主要讲解了“css3如何实现三角形带边框效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“css3如何实现三角形带边框效果”吧! ...
      99+
      2024-04-02
    • CSS如何实现渐变
      这篇文章将为大家详细讲解有关CSS如何实现渐变,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、线性渐变这里需要大家先去看一下基本语法,再看接下来的例子。linear-g...
      99+
      2024-04-02
    • JavaScriptcanvas实现环形渐变进度条
      最近有个需求要做环形渐变色进度条,去网上找了半天没找到合适的,大多数渐变色都是径向渐变,所以自己用canvas写了个环形渐变的图: 这个渐变其实就是把圆环分成许多小块分别绘制的,所...
      99+
      2024-04-02
    • css如何实现三角形列表项目符号
      这篇文章主要为大家展示了“css如何实现三角形列表项目符号”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css如何实现三角形列表项目符号”这篇文章吧。三角形列表项目符号ul {&nbs...
      99+
      2023-06-27
    • css如何写一个直角三角形
      这篇“css如何写一个直角三角形”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“css如何写一个直角三角形”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望大家通过这篇文章有所收获,下面让我们一起...
      99+
      2023-06-06
    • css如何实现三角
      小编给大家分享一下css如何实现三角,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!css实现三角的原理:首先确定底边是哪个方向,并设置哪个方向有颜色值;然后将其相...
      99+
      2023-06-15
    • 怎么用css实现直接画出三角形以及对话形式的三角形
      这篇文章主要为大家展示了“怎么用css实现直接画出三角形以及对话形式的三角形”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么用css实现直接画出三角形以及对话...
      99+
      2024-04-02
    • C++OpenGL实现三角形的绘制
      目录一、绘制三角形1、初始化2、顶点输入3、数据处理4、顶点着色器和片段着色器5、渲染二、完整代码代码输出修改尺寸修改三角形颜色修改背景颜色线框模式一、绘制三角形 1、初始化 (1)...
      99+
      2024-04-02
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作