Blending(融合)
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(融合)的更多相关文章
- Three.js开发指南---粒子和粒子系统(第七章)
使用粒子可以很容易的创建很多细小的物体,例如雨滴雪花等 本章主要内容: 1 使用ParticleBasicMaterial(基础粒子材质)来创建和设计粒子 2 使用ParticleSystem来创建一 ...
- Unity3D学习笔记(十六):Animator新动画
新动画系统: 给模型选择动画类型 普通动画:Generic 人形动画:Humanoid 建立动画控制器 - 在Project右击 - 选择Create-AnimatorContorller 将对应动画 ...
- 模型融合之blending和stacking
1. blending 需要得到各个模型结果集的权重,然后再线性组合. """Kaggle competition: Predicting a Biological Re ...
- 图像融合之拉普拉斯融合(laplacian blending)
一.拉普拉斯融合基本步骤 1. 两幅图像L,R,以及二值掩模mask,给定金字塔层数level. 2. 分别根据L,R构建其对应的拉普拉斯残差金字塔(层数为level),并保留高斯金字塔下采样最顶端的 ...
- DirectX基础学习系列5 融合技术
7.1融合方程 1概念 融合技术将当前光栅化像素的颜色与以前已光栅化并处于同一个位置的像素颜色进行合成,即将当前要进行光栅化的三角形单元与已写入后台的像素进行融合 2需要遵循的原则: (1)先绘制不需 ...
- Poisson Blending(Seamless clone)研究和实现
Poisson Blending 实现了非常棒的效果,可以看 <自己动手,实现“你的名字”滤镜> http://www.cnblogs.com/jsxyhelu/p/7216795.htm ...
- 使用liner、feather、multiband对已经拼接的数据进行融合
所谓"blend",英文解释为“vt. 混合vi. 混合:协调n. 混合:掺合物”这里应该理解为是图像数据的融合.这是“识别->对准->融合”的最后一步.融合是决定拼接 ...
- 机器学习技法之Aggregation方法总结:Blending、Learning(Bagging、AdaBoost、Decision Tree)及其aggregation of aggregation
本文主要基于台大林轩田老师的机器学习技法课程中关于使用融合(aggregation)方法获得更好性能的g的一个总结.包含从静态的融合方法blending(已经有了一堆的g,通过uniform:voti ...
- Unity---动画系统学习(6)---Avatar Mask动画融合、Layers动画分层、IK反向动力学
1. 介绍 Avatar Mask(动画融合) 前面我们一直介绍的都是动画混合,一般用于解决边跑边转弯的问题.而动画融合一般用于解决例如边跑边挥手的问题. 简单说就是让跑步去控制腿的骨骼,挥手控制手的 ...
随机推荐
- Primitive Objects
[Primitive Objects] Unity can work with 3D models of any shape that can be created with modelling so ...
- C++11类型推导
[C++11类型推导] auto 关键字.这会依据该初始化子(initializer)的具体类型产生参数: 除此之外,decltype 能够被用来在编译期决定一个表示式的类型. 参考:http://z ...
- esb异常20160322_1948
异常1. Failed to find entry point for component, the following resolvers tried but failed: [ 2016-03-2 ...
- vim中大小写转化
@(编程) gu或者gU 形象一点的解释就是小u意味着转为小写:大U意味着转为大写. 整篇文章大写转化为小写 打开文件后,无须进入命令行模式.键入: ggguG 解释一下: ggguG分作三段gg g ...
- spring mvc中的valid
当你希望在spring mvc中直接校验表单参数时,你可以采用如下操作: 声明Validator的方式: 1.为每一个Controller声明一个Validator @Controller publi ...
- 【转载】Windows/Office“神key的来源”(附win8神key)
凡是没有经过微软授权的渠道激活Windows/Office的全部是"D版"!但由于密钥激活更方便快捷,因此很受欢迎.从百度博客到现在,很多网友询问:"神key&q ...
- unigui TUniTreeView demo
unit untTree; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, For ...
- MEF(Managed Extensibility Framework)依赖注入学习
MSDN官方资料,并且微软还提供了SimpleCalculator sample学习样例 http://msdn.microsoft.com/en-us/library/dd460648(v=vs.1 ...
- CCF 201403-2 窗口 (STL模拟)
问题描述 在某图形操作系统中,有 N 个窗口,每个窗口都是一个两边与坐标轴分别平行的矩形区域.窗口的边界上的点也属于该窗口.窗口之间有层次的区别,在多于一个窗口重叠的区域里,只会显示位于顶层的窗口里的 ...
- Windows x86 x64使用SetThreadContext注入shellcode的方式加载DLL
一.前言 注入DLL的方式有很多,在R3就有远程线程CreateRemoteThread.SetWindowsHookEx.QueueUserApc.SetThreadContext 在R0可以使用a ...