IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> CocosCreator2.4 Shader学习 -> 正文阅读

[游戏开发]CocosCreator2.4 Shader学习

CocosCreator2.4 Shader学习

模板

路径
不同版本就进入不同版本的路径
D:\CocosDashboard_1.0.9\resources.editors\Creator\2.4.6\resources\engine\cocos2d\renderer\build\chunks
模板路径
input-standard.inc
获取模板
想要拿到什么参数可以从这里复制

面板

面板

源码

// Copyright (c) 2017-2018 Xiamen Yaji Software Co., Ltd.
// cocos描述
CCEffect %{
  techniques:
  - passes:
      # 顶点
    - vert: vs
      # 面
      frag: fs
      blendState:
        targets:
        - blend: true
      rasterizerState:
        cullMode: none
      # 属性列表
      properties:
        texture: { value: white }
        alphaThreshold: { value: 0.5 }
        # 新增属性
        my_runTime: { value: 0 ,editor: { type: number ,tooltip: "时间"}}
        my_diffuseColor: { value: [1, 1, 1, 1], editor: { type: color ,tooltip: "叠加颜色"} }
}%

// 顶点Shader
CCProgram vs %{
  // GLSL 精度 高精度:highp 中精度:mediump 低精度 lowp
  precision highp float;

  #include <cc-global>
  #include <cc-local>

  //in 就是渲染管道传进来的数据

  //顶点位置数据
  in vec3 a_position;
  //顶点颜色数据
  in vec4 a_color;
  out vec4 v_color;

  #if USE_TEXTURE
  //顶点纹理坐标
  in vec2 a_uv0;
  out vec2 v_uv0;
  #endif

  // #if USE_ATTRIBUTE_NORMAL
  // //顶点法线
  // in vec3 a_normal;
  // #endif

  void main () {
    vec4 pos = vec4(a_position, 1);

    #if CC_USE_MODEL
    //cc_matViewProj 模型=》世界坐标 每次绘制时引擎自动传递 
    //cc_matWorld 世界=》透视坐标 
    pos = cc_matViewProj * cc_matWorld * pos;
    #else
    pos = cc_matViewProj * pos;
    #endif

    #if USE_TEXTURE
    v_uv0 = a_uv0;
    #endif

    v_color = a_color;

    gl_Position = pos;
  }
}%

// 面Shader
CCProgram fs %{
  precision highp float;

  #include <alpha-test>
  #include <texture>

  in vec4 v_color;

  #if USE_TEXTURE
  in vec2 v_uv0;
  uniform sampler2D texture;

  //自定义字段
  uniform block{
    float my_runTime;
  };
  uniform blocktwo{
    vec4 my_diffuseColor;
  };
  #endif

  void main () {
    // vec4 o = vec4(1, 1, 1, 1);
    //修改颜色为变量颜色
    vec4 o = my_diffuseColor;
    vec2 myoffset=vec2(0,my_runTime);
    #if USE_TEXTURE
      CCTexture(texture, v_uv0+myoffset, o);
    #endif

    o *= v_color;

    ALPHA_TEST(o);

    #if USE_BGRA
      gl_FragColor = o.bgra;
    #else
      gl_FragColor = o.rgba;
    #endif
  }
}%

  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2021-11-14 22:03:23  更:2021-11-14 22:03:37 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/27 22:32:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码