Cocos2dx Shader 使用系列之一:OpenGL Shader Language介绍

它是一种类似于C语言的专门为GPU设计的语言,它可以放在GPU里面被并行运行。
对于第一次使用 shader程序的人来说,看到网上一大堆的介绍.vsh,.fsh文件代码,但是就是不知道从哪里下手,(我就是这样滴),这里我就讲述下我的学习使用过程。

  1. 认识.vsh,.fsh 这两个文件在被编译和链接后就可以产生可执行程序与GPU交互。 .vsh 是 vertex shader,用与顶点计算,可以理解为控制顶点的位置,在这个文件中我们通常会传入当前顶点的位置,和纹理的坐标。 .fsh
    是片段shader,或者叫片元shader。在这里面我可以对于每一个像素点进行重新计算。

  2. .vsh和.fsh在opengl 渲染的流程是怎样的?
    那我们就要先看一下:
    着色器对象关联着色器代码,glShaderSource
    把着色器源代码编译成目标代码,glCompileShader
    验证着色器是否已经变异通过, glGetShaderivgl GetShaderInfoLog
    创建一个着色器程序,glCreatePragram
    把着色器链接到着色器程序中, glAttachShader
    链接着色器程序, glLinkProgram
    验证着色器程序是否链接成功, glGetProgramiv glGetProgramInfoLog

    3.cocos2dx中使用shader 下面是简单的示例:

    auto sprite = Sprite::create("afei.png");
    sprite->setPosition(vec2(300, 400)); fNode->addChild(sprite); auto
    program = GLProgram::createWithFilenames("afei.vsh", "afei.fsh");
    program->bindAttribLocation(GLProgram::ATTRIBUTE_NAME_POSITION,
    GLProgram::VERTEX_ATTRIB_POSITION);
    program->bindAttribLocation(GLProgram::ATTRIBUTE_NAME_COLOR,
    GLProgram::VERTEX_ATTRIB_COLOR);
    program->bindAttribLocation(GLProgram::ATTRIBUTE_NAME_TEX_COORD,
    GLProgram::VERTEX_ATTRIB_TEX_COORD); program->link();
    program->updateUniforms(); sprite->setGLProgram(program);

    简单解释下,每个Node 对象都会 有一个GLProgram
    对象,设定一系列的OPGL参数之后,在Node渲染函数里面进行渲染,无外乎就是颜色,位置,透明度,uv等一系列的变换。
    比如dota传奇里面的冰霜效果,具体的渲染原理就是,顶点不变,将纹理(对应着图片)的颜色值改变,说白了就是修改r,g,b值。(当然,你也可以直接使用Sprite的接口进行更改了,但是
    这里使用的OpenGL进行修改的,使用的仅仅是
    GPU,如果你使用接口去改,需要写很多逻辑代码,就会占用大量的CPU了!)。冰霜效果实在片元shader里面进行修改的,通过宿主程序,如Cocos2dx封装好的接口,传入参数,然后shader里面判断非透明的地方就修改冰冻效果的rgb值,这样出来的效果就是冰霜效果了

    既然使用了 这门语言当然就需要了解下其中的语法和内建变亮了,下片文章我们继续介绍。谢谢

推荐文章:
http://www.cnblogs.com/slysky/p/3949718.html
http://zhidao.baidu.com/link?url=Aas_sRAAGRzOJvEb65BMo9JupMfp74iPBf-PWv1DIAmqaceG2IFC7KjN3ds8LOO9XHEWNWLMBACxJBVM_SGRSEm3c0tk_mzh7H35Ir8Cqpy


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值