[√]creator对color处理的细节逻辑

简介: [√]creator对color处理的细节逻辑

color的val

this._val = ((a << 24) >>> 0) + (b << 16) + (g << 8) + (r|0);

使用4字节整数表示rgba, 从低位到高位依次是rgba

var vfmtPosUvColor = new gfx.VertexFormat([
    { name: gfx.ATTR_POSITION, type: gfx.ATTR_TYPE_FLOAT32, num: 2 },
    { name: gfx.ATTR_UV0, type: gfx.ATTR_TYPE_FLOAT32, num: 2 },
    { name: gfx.ATTR_COLOR, type: gfx.ATTR_TYPE_UINT8, num: 4, normalize: true },
]);

为啥看到了蓝色

image.png

const red = new cc.Color(255, 0, 0, 255);
red._val = 4278190335   // 白色 4294967295
vbuf[index]=red._val 

4278190335 使用float32Array存储,4字节刚好是01007F4F, 对应的颜色刚好是#01007F4F,这个颜色刚好是带有透明度的暗蓝色,这也解释了为啥我看到的是蓝色

所以颜色是不能这么设置的。

createData (index, verticesFloats, indicesCount) {
   let vertices = new Float32Array(verticesFloats);// 注意这里是Float32Array
   let indices = new Uint16Array(indicesCount);
   this.updateMesh(index, vertices, indices);
},
updateMesh (index, vertices:Float32Array, indices) {
    // 指向的都是同一个vertices
   this.vDatas[index] = vertices;
   this.uintVDatas[index] = new Uint32Array(vertices.buffer, 0, vertices.length); // 但是这个使用的是Uint32Array
   //这个类型非常重要,如果还是Float32Array,会导致存储的数据异常,因为整数和浮点数的存储方式是不同的
   // 所以看到这里转接了一层,这样方便再updateColor中设置4字节整数的时候正常
   this.iDatas[index] = indices;
   this.meshCount = this.vDatas.length;
},
// assembler-2d 
updateColor (comp, color) {
   let uintVerts:Uint32Array = this._renderData.uintVDatas[0];
   if (!uintVerts) return;
   color = color != null ? color : comp.node.color._val;
   let floatsPerVert = this.floatsPerVert;
   let colorOffset = this.colorOffset;
   for (let i = colorOffset, l = uintVerts.length; i < l; i += floatsPerVert) {
       uintVerts[i] = color;
   }
}

image.png

engine

每个meshbuffer都有对应的vertexformat,决定了这个buffer的数据如何解析填充到gpu

function _commitTextures(gl, cur, next) {
  for (let i = 0; i < next.maxTextureSlot + 1; ++i) {
    if (cur.textureUnits[i] !== next.textureUnits[i]) {
      let texture = next.textureUnits[i];// 取纹理
      if (texture && texture._glID !== -1) {
        gl.activeTexture(gl.TEXTURE0 + i);
        gl.bindTexture(texture._target, texture._glID);
      }
    }
  }
}

textureUnits是通过外部设置的

  setTexture(name, texture, slot) {
    if (slot >= this._caps.maxTextureUnits) {
      console.warn(`Can not set texture ${name} at stage ${slot}, max texture exceed: ${this._caps.maxTextureUnits}`);
      return;
    }
    this._next.textureUnits[slot] = texture;// 这里设置新的纹理
    this.setUniform(name, slot);
    if (this._next.maxTextureSlot < slot) {
      this._next.maxTextureSlot = slot;
    }
  }

往上溯源,发现

  _setProperty (prop) {
  // 省略了好多的代码
      device.setTexture(prop.name, param, this._allocTextureUnit());
  }

又见到了熟悉的_draw函数

  _draw (item) {
      // for each pass
    for (let i = 0; i < passes.length; ++i) {
          let program = programLib.getProgram(pass, defines, effect.name);
      device.setProgram(program);
      let uniforms = program._uniforms;// 对应effect里面对应的所有uniform变量
      let variants = pass._properties; // 对应effect里面的pass定义的properties
      for (let j = 0; j < uniforms.length; j++) {
        let prop = variants[uniforms[j].name];
        if (prop !== undefined){
          this._setProperty(prop);
        }
      }
    }
  }

builtin-2d-sprite.mtl

{
  "__type__": "cc.Material",
  "_name": "builtin-2d-sprite",
  "_objFlags": 0,
  "_native": "",
  "_effectAsset": {
    "__uuid__": "2874f8dd-416c-4440-81b7-555975426e93"
  },
  "_techniqueData": {
    "0": {
      "defines": {
        "USE_TEXTURE": true
      }
    }
  }
}

builtin-2d-sprite.effect

CCEffect %{
  techniques:
  - passes:
    - vert: vs
      frag: fs
      blendState:
        targets:
        - blend: true
      rasterizerState:
        cullMode: none
      properties:
        texture: { value: white }
        alphaThreshold: { value: 0.5 }
}%
CCProgram vs %{
  precision highp float;
  #include <cc-global>
  #include <cc-local>
  in vec3 a_position;
  in vec4 a_color;
  out vec4 v_color;
  #if USE_TEXTURE
  in vec2 a_uv0;
  out vec2 v_uv0;
  #endif
  void main () {
    vec4 pos = vec4(a_position, 1);
    #if CC_USE_MODEL
    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;
  }
}%
CCProgram fs %{
  precision highp float;
  #include <alpha-test>
  #include <texture>
  in vec4 v_color;
  #if USE_TEXTURE
  in vec2 v_uv0;
  uniform sampler2D texture;
  #endif
  void main () {
    vec4 o = vec4(1, 1, 1, 1);
    #if USE_TEXTURE
      CCTexture(texture, v_uv0, o);
    #endif
    o *= v_color;
    ALPHA_TEST(o);
    #if USE_BGRA
      gl_FragColor = o.bgra;
    #else
      gl_FragColor = o.rgba;
    #endif
  }
}%
目录
相关文章
|
8月前
|
Android开发 开发者
Android UI设计: 请解释Activity的Theme是什么,如何更改应用程序的主题?
Android UI设计: 请解释Activity的Theme是什么,如何更改应用程序的主题?
183 1
|
8月前
|
存储 vr&ar
大师学SwiftUI第6章 - 声明式用户界面 Part 1
在上一章,我们介绍了SwiftUI的主要特性,声明式语法。借助SwiftUI,我们可以按希望在屏幕上显示的方式声明视图,余下交由系统来创建所需的代码。但声明式语法不只用于组织视图,还可在应用状态发生变化时更新视图。
87 1
|
Android开发
Android开发教程 - 使用Data Binding(七)使用BindingAdapter简化图片加载
本系列目录 使用Data Binding(一)介绍 使用Data Binding(二)集成与配置 使用Data Binding(三)在Activity中的使用 使用Data Binding(四)在Fragment中的使用 ...
1167 0
|
5月前
Flutter更改主题颜色报错:type ‘Color‘ is not a subtype of type ‘MaterialColor‘
Flutter更改主题颜色报错:type ‘Color‘ is not a subtype of type ‘MaterialColor‘
57 4
|
8月前
|
存储 安全 vr&ar
大师学SwiftUI第6章 - 声明式用户界面 Part 3
SwiftUI还内置了创建安全文本框的视图。这一视图会把用户输入的字符替换成点以及隐藏敏感信息,比如密码。 •
66 0
|
8月前
|
存储 vr&ar Swift
大师学SwiftUI第6章 - 声明式用户界面 Part 4
Stepper视图创建一个带递增和递减按钮的控件。该结构体提供了多个初始化方法,包含不同的配置参数组合。以下是最常用的一部分。 •
59 0
|
8月前
|
存储 Go vr&ar
大师学SwiftUI第6章 - 声明式用户界面 Part 2
控件是交互工具,用户通过交互修改界面状态、选取选项或插入、修改或删除信息。我们实现过其中的一部分,如前例中的Button视图以及TextField视图。要定义一个有用的接口,需要学习有关视图的更多知识以及其它由SwiftUI所提供的控制视图。
59 0
|
8月前
|
前端开发
Flutter TextPainter如何使用
TextPainter是Flutter中用于高级文本布局和渲染的强大工具。它允许你更精细地控制文本的样式、布局、绘制和测量。以下是关于TextPainter的一些细节讲解:
|
Android开发
Android 使用DataBinding时 将布局页面转换为数据绑定布局(Convert to data binding layout) 不出现提示解决办法
Android 使用DataBinding时 将布局页面转换为数据绑定布局(Convert to data binding layout) 不出现提示解决办法
175 0
|
缓存 前端开发 Java
手写一个Flutter State Widget,来让你彻底理解State的来龙去脉
手写一个Flutter State Widget,来让你彻底理解State的来龙去脉
231 0
手写一个Flutter State Widget,来让你彻底理解State的来龙去脉

热门文章

最新文章