Src Pixesl: 源像素 : 指的是当前光栅化产生的值

    Dst Pixels 目标像素.指的是先前渲染存储在RT中的值

    可以用来实现那些效果,诸如水,玻璃 以及其他的,(后面在说)

    在光栅化ij 像素的时候,如果没有开启混合,那么新值将覆盖旧值(深度测试通过),如果开始混合,那么将通过D3D11_BLEND_DESC 的设置来融合新值和旧值,然后将融合后的值写入,让我们来看下这个DESC

typedef struct D3D11_BLEND_DESC {

BOOL AlphaToCoverageEnable;

BOOL IndependentBlendEnable;

D3D11_RENDER_TARGET_BLEND_DESC RenderTarget[8];

} D3D11_BLEND_DESC;

    抛去前两个项不讲,因为我们可以同时绑定多个RT,所以RT的DESC是个数组,用来纷纷对应,
IndependentBlendEnable项根据名字便可以得知,当其设置为true时,不同的RT使用对应的RT_DESC,而设置为false,便只会使用RenderTarget[0], D3D11_RENDER_TARGET_BLEND_DESC 会详细指定如何融合

    

typedef struct D3D11_RENDER_TARGET_BLEND_DESC {

BOOL BlendEnable;

D3D11_BLEND SrcBlend;

D3D11_BLEND DestBlend;

D3D11_BLEND_OP BlendOp;

D3D11_BLEND SrcBlendAlpha;

D3D11_BLEND DestBlendAlpha;

D3D11_BLEND_OP BlendOpAlpha;

UINT8 RenderTargetWriteMask;

} D3D11_RENDER_TARGET_BLEND_DESC;

    第二个项和第三个项用来设置源像素和目标像素的系数(权重),第四个项用来指定两个分别计算出来的值将如何计算的(一般的是D3D11_BLEND_OP_ADD
),最终颜色便是这样计算的

        OutputPixel = ( SourceColor.rgba * SrcBlend ) __BlendOp__ ( DestColor.rgba * DestBlend )

你可以看见alpha是另外计算的,计算方式同上

    那么D3D11_BLEND到底有那些系数了:

        D3D11_BLEND_ZERO /D3D11_BLEND_ONE 故名思意

        D3D11_BLEND_SRC_COLOR = (Rs, Gs, Bs, As) (注意,括号里是颜色值)

        既然有SRV_COLOR,那么也有对应 的INV_SRC,系数为1 – 对应的项,即: (1 - Rs, 1 - Gs, 1 - Bs, 1 - As),也有对应的DST_COLOR,INV_DST_COLOR

        那么还有SRC_ALPHA,INV_SRC_ALPHA,还有对应的DST_ALPHA

    还有一些比较特殊的就不写了

(一般的,我们很少需要DST的ALPHA,因为一般的算法只需要有SRC的ALPHA即可完成)

    有那些操作:

        相加,相减(dst-src),反向相减(src-dst),{最小和最大(这个时候忽略系数,直接对颜色操作)

(你可以为颜色和alpha指定不同的操作,否则两个op毫无存在意义)

    至于创建,所有的创建接口都在ID3D11Device哦,函数实在没什么好介绍的

至于AlphaToCoverageEnable 暂时设置为false

RenderTargetWriteMask 你可以用来控制颜色的写入,几个枚举量是enable_red,green,blue,alpha,你可以对他们使用 | 运算符

至于绑定一个BlendState,调用DeviceContext的接口即可(这函数可以接受系数,用来特定的系数计算,具体见D3D11_BLEND_BLEND_FACTOR 或者 D3D11_BLEND_INV_BLEND_FACTOR)

下面的代码创建,以及完成绑定

D3D11_BLEND_DESC
transparentDesc
=
{
0
};

    //transparentDesc.AlphaToCoverageEnable = false; 默认为false

    //transparentDesc.IndependentBlendEnable = false; 默认为false

    transparentDesc.RenderTarget[0].BlendEnable
=
true;

    transparentDesc.RenderTarget[0].SrcBlend
=
D3D11_BLEND_SRC_ALPHA;

    transparentDesc.RenderTarget[0].DestBlend
=
D3D11_BLEND_INV_SRC_ALPHA;

    transparentDesc.RenderTarget[0].BlendOp
=
D3D11_BLEND_OP_ADD;

    transparentDesc.RenderTarget[0].SrcBlendAlpha
=
D3D11_BLEND_ONE;

    transparentDesc.RenderTarget[0].DestBlendAlpha
=
D3D11_BLEND_ZERO;

    transparentDesc.RenderTarget[0].BlendOpAlpha
=
D3D11_BLEND_OP_ADD;

    transparentDesc.RenderTarget[0].RenderTargetWriteMask
=
D3D11_COLOR_WRITE_ENABLE_ALL;

    ID3D11BlendState*
TransparentBS;

    ID3D11Device->CreateBlendState(&transparentDesc,
&TransparentBS));

    float
blendFactors[]
=
{
0.0f,
0.0f,
0.0f,
0.0f
};

    ID3D11DeviceContext->OMSetBlendState(TransparentBS, blendFactor,
0xffffffff);

 

实际应用时,我们需要统一管理这些状态,这是很必要的,而且要避免状态的切换(这个也许说的不对)

题外话:

    渲染状态大概有以下:

        世界,观察,投影矩阵,光源,纹理绑定,纹理寻址和过滤方式,深度测试,融合(blend),

    有意思的是,路过在提交图元之间,我们忘记设置某方面的状态,上一图元的设置便会泄露到下一图元.这是个重要的暗示,因为切换状态总是需要代价的

 

    下一篇文章将实现一些具体效果

Blending(融合)的更多相关文章

  1. Three.js开发指南---粒子和粒子系统(第七章)

    使用粒子可以很容易的创建很多细小的物体,例如雨滴雪花等 本章主要内容: 1 使用ParticleBasicMaterial(基础粒子材质)来创建和设计粒子 2 使用ParticleSystem来创建一 ...

  2. Unity3D学习笔记(十六):Animator新动画

    新动画系统: 给模型选择动画类型 普通动画:Generic 人形动画:Humanoid 建立动画控制器 - 在Project右击 - 选择Create-AnimatorContorller 将对应动画 ...

  3. 模型融合之blending和stacking

    1. blending 需要得到各个模型结果集的权重,然后再线性组合. """Kaggle competition: Predicting a Biological Re ...

  4. 图像融合之拉普拉斯融合(laplacian blending)

    一.拉普拉斯融合基本步骤 1. 两幅图像L,R,以及二值掩模mask,给定金字塔层数level. 2. 分别根据L,R构建其对应的拉普拉斯残差金字塔(层数为level),并保留高斯金字塔下采样最顶端的 ...

  5. DirectX基础学习系列5 融合技术

    7.1融合方程 1概念 融合技术将当前光栅化像素的颜色与以前已光栅化并处于同一个位置的像素颜色进行合成,即将当前要进行光栅化的三角形单元与已写入后台的像素进行融合 2需要遵循的原则: (1)先绘制不需 ...

  6. Poisson Blending(Seamless clone)研究和实现

    Poisson Blending 实现了非常棒的效果,可以看 <自己动手,实现“你的名字”滤镜> http://www.cnblogs.com/jsxyhelu/p/7216795.htm ...

  7. 使用liner、feather、multiband对已经拼接的数据进行融合

    所谓"blend",英文解释为“vt. 混合vi. 混合:协调n. 混合:掺合物”这里应该理解为是图像数据的融合.这是“识别->对准->融合”的最后一步.融合是决定拼接 ...

  8. 机器学习技法之Aggregation方法总结:Blending、Learning(Bagging、AdaBoost、Decision Tree)及其aggregation of aggregation

    本文主要基于台大林轩田老师的机器学习技法课程中关于使用融合(aggregation)方法获得更好性能的g的一个总结.包含从静态的融合方法blending(已经有了一堆的g,通过uniform:voti ...

  9. Unity---动画系统学习(6)---Avatar Mask动画融合、Layers动画分层、IK反向动力学

    1. 介绍 Avatar Mask(动画融合) 前面我们一直介绍的都是动画混合,一般用于解决边跑边转弯的问题.而动画融合一般用于解决例如边跑边挥手的问题. 简单说就是让跑步去控制腿的骨骼,挥手控制手的 ...

随机推荐

  1. c#与vb.net在App_Code里面编译要通过,需要以下web.config的配置

    web.config的配置: <system.web> <codeSubDirectories> <add directoryName="VB"/&g ...

  2. [iOS微博项目 - 2.2] - 在app中获取授权

    github: https://github.com/hellovoidworld/HVWWeibo   A.发送授权请求 1.使用UIWebView加载请求页面 自定义一个继承UIViewContr ...

  3. SpringMVC3.2+JPA使用注解的方式环境搭建

    ==============================entity=========================================================package ...

  4. InvocationHandler

    ====================================================================== 代理类生成之后再调用目标方法时就会调用invoke方法 p ...

  5. ThreadPool for Delphi

    http://sourceforge.net/projects/threadpoolpas/ http://hivelocity.dl.sourceforge.net/project/threadpo ...

  6. Android Volley框架的使用(三)

     此博文源码下载地址  https://github.com/Javen205/VolleyDemo.git Image Request 为了更方便的使用Volley中的图片请求,我们同样先在Voll ...

  7. Java多线程技术学习笔记(二)

    目录: 线程间的通信示例 等待唤醒机制 等待唤醒机制的优化 线程间通信经典问题:多生产者多消费者问题 多生产多消费问题的解决 JDK1.5之后的新加锁方式 多生产多消费问题的新解决办法 sleep和w ...

  8. Nazo解密游戏攻略

    啊,终于腾出时间来玩这个游戏了,顺手写一下攻略吧…… 第0关:http://cafebabe.cc/nazo/ 第一关:第一关很简单 点一下就好了 http://cafebabe.cc/nazo/le ...

  9. TP第2个项目总结

    1.参数尼玛传接受要非数字方法 $id = $this->_get('id','intval',0); $field_wc = $this->_get('wc_field'); 2.参数不 ...

  10. 都是类型惹的祸——小心unsigned

    正如我们所知道的,编程语句都有很多的基本数据类型,如char,inf,float等等,而在C和C++中还有一个特殊的类型就是无符号数,它由unsigned修饰,如unsigned int等.大家有没想 ...