排列三近200期试机号: 士郎 Dual Paraboloid Shadow Maps(DPSM)

14
回复
1249
查看
打印 上一主题 下一主题
[ 复制链接 ]
排名
1
昨日变化

排列三2014079期正版藏机图 www.d0po.cn 7615

主题

8162

帖子

3万

积分

Rank: 16

UID
1231
好友
186
蛮牛币
10064
威望
30
注册时间
2013-7-29
在线时间
3930 小时
最后登录
2019-4-26

活力之星原创精华达人突出贡献奖财富之证游戏蛮牛QQ群会员蛮牛妹VIP

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?注册帐号

x
今天给大家分享的是点光shadow map的绘制方法。
emm,最古老的点光阴影生成方式是cubemap,这个怎么操作我就略过了,不会的读者也不是这个专栏的目标群体吧?然而这玩意画一个点光的阴影要用6个不同的视口矩阵画6遍不同朝向的shadowmap,明显是令人沮丧的操作,所以就有了今天讲的这玩意儿:Dual paraboloid shadow maps

什么是Dual paraboloid shadow maps?
朋友你见过世界地图吗?其实画点光SM的时候和画地图的时候遇到的难题是一样的:由于球面的高斯曲率为正,我们无法在完全无损的状态下把它投影到一个平面上。因而我们的任务就是找到一个较为优质的映射,可以将单位球面上的点坐标转化为平面上的点坐标。
如下图,是一个凸透镜投影的例子,可以为半球面上的任意一个点找到其对应的二维坐标。如果用这样的投影方式来代替普通的透视投影,则只需要对两个相反的半球分别进行一次绘制就可以完成点光的SM。(存在一张RG32的贴图里还不是美滋滋)。

下面给出的公式就是该投影变换的结果:

式中pos为V在light坐标系下已经normalize过的3维坐标(单位方向向量),uv为经过投影映射后的平面坐标。
前一个版本这里写错了,现已更正。
推导如下:(1维)
1. 根据抛物线的性质,反射方向为(0,1)
2. 设入射方向的反方向,单位化之后为(a,b)
3. 则入射点处的抛物线法线方向为(a,b+1)
4. 该抛物线的导数用x坐标表示为-x
5. 则该抛物线的法线为(x,1)
6. 故交点x坐标,即投影坐标为a/(b+1)
分析一下这个映射(这台电脑上没matlab,python又不会...),设为从光源到待变换顶点V的向量,N为第一张shadowmap的投影正方向, 与N的夹角。则实际shadowmap上投影像素的分布与角的关系为:

横轴为theta,纵轴为像素坐标
可以看到这个映射整体较为线性,且在接近90度时分配了更多的像素,而且计算量很小??!十分符合需求。
下面看一下代码实现:
[AppleScript] 纯文本查看 复制代码
S_v2f PS_vert(S_a2v i)
{
	//获得light space下坐标
	S_v2f o;
	o.pos = mul(_Shadow_mat, mul(unity_ObjectToWorld, i.vert));

	//特殊投影变换
	float z = length(o.pos.xyz);
	o.pos.xyz = normalize(o.pos.xyz);
	o.pos.xy /= -o.pos.z + 1;

	//将点投影到uv坐标系
	o.pos.xy *= 2 * _Shadow_Range;
	o.pos.z = -z;
	o.pos = mul(_Shadow_mat2, o.pos);

	return o;
}

是不是超简单...都没啥好说的。
我们来看一下这玩意生成的shadowmap长啥样:

左下角第二张就是了,RG通道分别存了东西半球的SM,128x128分辨率?;褂械憧犰?。

Tessellation
为什么要做tessellation呢,其实也很好理解。不同于普通的正交或是透视投影,直线经过这种特殊投影之后,在uv空间中将不再是直线。



这样的效应在角大或者物体接近光源时会十分明显,因此我们需要对物体进行细分以确保在uv空间中的投影有足够的段数来近似曲线。


这时只需要勾选"enable tessellation"选项,boom!SM里Quad的边缘变成了曲线,阴影也回归了正常,美滋滋。

然后贴一下细分的代码就跑路了:
[AppleScript] 纯文本查看 复制代码
S_v2f PS_vert(S_a2v i)
{
	S_v2f o;

	o.pos = mul(_Shadow_mat, mul(unity_ObjectToWorld, i.vert));

	float z = length(o.pos.xyz);
	o.pos.xyz = normalize(o.pos.xyz);
	o.pos.xy /= -o.pos.z + 1;

	o.pos.xy *= 2 * _Shadow_Range;
	o.pos.z = -z;
	o.pos = mul(_Shadow_mat2, o.pos);

	return o;
}

float4 DS_frag(S_v2f i) : SV_TARGET {
	return i.pos.z;
}

struct PS_a2t {
	float4 vertex : INTERNALTESSPOS;
	float z : TEXCOORD0;
};

PS_a2t PS_tessvert(S_a2v i) {
	PS_a2t o;
	o.vertex = i.vert;
	float3 pos = mul(_Shadow_mat, mul(unity_ObjectToWorld, i.vert));
	float z = max(length(pos),0.0001);//avoid NaN
	z = 1 - z / _Shadow_Range;
	o.z = lerp(0, 32, z);
	return o;
}

UnityTessellationFactors PS_hsconst(InputPatch<PS_a2t, 3> v) {
	UnityTessellationFactors o;
	float4 tf;
	tf = max(max(v[0].z, v[1].z), v[2].z);
	o.edge[0] = tf.x;
	o.edge[1] = tf.y;
	o.edge[2] = tf.z;
	o.inside = tf.w;
	return o;
}

[UNITY_domain("tri")]
[UNITY_partitioning("fractional_odd")] //截断在[1,max]范围内,然后取整到下一个奇数整数值
[UNITY_outputtopology("triangle_cw")] //cw顺时针,ccw逆时针
[UNITY_patchconstantfunc("PS_hsconst")]
[UNITY_outputcontrolpoints(3)]
PS_a2t PS_hs(InputPatch<PS_a2t, 3> v, uint id : SV_OutputControlPointID) {
	return v[id];
}

[UNITY_domain("tri")]
S_a2v PS_ds(UnityTessellationFactors tessFactors, const OutputPatch<PS_a2t, 3> vi, float3 bary : SV_DomainLocation) {
	S_a2v v;

	v.vert = vi[0].vertex*bary.x + vi[1].vertex*bary.y + vi[2].vertex*bary.z;

	S_v2f o = PS_vert(v);
	return o;
}

哦,值得一提的是,由于硬件插值是线性的,在shadow collection时,如果你在vertex shader里仅传递线性坐标系的坐标(如世界坐标),并将这个特殊投影推迟到pixel shader里执行,就不需要进行细分了,否则同样也必须进行细分。
最后最后再贴一下对比图:




知乎@头像是狐狸吗


7日久生情
2233/5000
排名
1394
昨日变化

0

主题

693

帖子

2233

积分

Rank: 7Rank: 7Rank: 7Rank: 7

UID
135463
好友
0
蛮牛币
174
威望
0
注册时间
2016-1-23
在线时间
650 小时
最后登录
2019-4-25
沙发
2019-1-21 15:27:47 只看该作者
54654653464235234234324
7日久生情
2151/5000
排名
2613
昨日变化

2

主题

1089

帖子

2151

积分

Rank: 7Rank: 7Rank: 7Rank: 7

UID
209046
好友
0
蛮牛币
2954
威望
0
注册时间
2017-3-30
在线时间
506 小时
最后登录
2019-4-26
板凳
2019-1-21 16:06:02 只看该作者
7日久生情
1582/5000
排名
1199
昨日变化

0

主题

216

帖子

1582

积分

Rank: 7Rank: 7Rank: 7Rank: 7

UID
137070
好友
0
蛮牛币
3211
威望
0
注册时间
2016-2-20
在线时间
390 小时
最后登录
2019-4-26
地板
2019-1-21 18:00:40 只看该作者
感谢楼主分享!
6蛮牛粉丝
1052/1500
排名
5543
昨日变化

0

主题

659

帖子

1052

积分

Rank: 6Rank: 6Rank: 6

UID
300432
好友
1
蛮牛币
1452
威望
0
注册时间
2018-10-18
在线时间
133 小时
最后登录
2019-3-27
5#
2019-1-22 09:36:59 只看该作者
6666666666
7日久生情
1747/5000
排名
1366
昨日变化

2

主题

154

帖子

1747

积分

Rank: 7Rank: 7Rank: 7Rank: 7

UID
148089
好友
0
蛮牛币
2665
威望
0
注册时间
2016-5-10
在线时间
683 小时
最后登录
2019-4-26
6#
2019-1-22 09:50:26 只看该作者
看起来很厉害,但我表示看不懂,还没达到这个程度
7日久生情
2695/5000
排名
2230
昨日变化

1

主题

1721

帖子

2695

积分

Rank: 7Rank: 7Rank: 7Rank: 7

UID
119154
好友
0
蛮牛币
2778
威望
0
注册时间
2015-8-21
在线时间
343 小时
最后登录
2019-4-23
7#
2019-1-22 10:15:18 只看该作者
谢谢楼主大大。
6蛮牛粉丝
1355/1500
排名
1981
昨日变化

0

主题

269

帖子

1355

积分

Rank: 6Rank: 6Rank: 6

UID
68040
好友
0
蛮牛币
1895
威望
0
注册时间
2015-1-13
在线时间
402 小时
最后登录
2019-4-26
8#
2019-1-23 09:18:27 只看该作者
这里是真的完全看不懂
5熟悉之中
522/1000
排名
6836
昨日变化

0

主题

191

帖子

522

积分

Rank: 5Rank: 5

UID
300324
好友
0
蛮牛币
154
威望
0
注册时间
2018-10-17
在线时间
137 小时
最后登录
2019-4-26
9#
2019-1-24 10:30:41 只看该作者
站长妹纸萌萌哒!
7日久生情
4939/5000
排名
1669
昨日变化

0

主题

3510

帖子

4939

积分

Rank: 7Rank: 7Rank: 7Rank: 7

UID
185339
好友
1
蛮牛币
3556
威望
0
注册时间
2016-11-20
在线时间
651 小时
最后登录
2019-4-26
10#
2019-1-28 15:27:51 只看该作者
{:106:}
排名
24126
昨日变化

2

主题

18

帖子

54

积分

Rank: 2Rank: 2

UID
281743
好友
0
蛮牛币
110
威望
0
注册时间
2018-5-18
在线时间
12 小时
最后登录
2019-2-1
11#
2019-1-31 13:10:15 只看该作者
33333333333333333333333333333
5熟悉之中
615/1000
排名
10816
昨日变化

2

主题

416

帖子

615

积分

Rank: 5Rank: 5

UID
310426
好友
0
蛮牛币
505
威望
0
注册时间
2019-1-2
在线时间
101 小时
最后登录
2019-4-26
12#
2019-2-1 09:48:11 只看该作者
{:104:}{:104:}
5熟悉之中
508/1000
排名
7132
昨日变化

4

主题

238

帖子

508

积分

Rank: 5Rank: 5

UID
234982
好友
0
蛮牛币
1159
威望
0
注册时间
2017-7-30
在线时间
96 小时
最后登录
2019-3-27
13#
2019-2-10 13:34:08 只看该作者
dddddddddddddddddddddddddddddddddddddddd
2初来乍到
136/150
排名
19336
昨日变化

0

主题

50

帖子

136

积分

Rank: 2Rank: 2

UID
131276
好友
0
蛮牛币
9
威望
0
注册时间
2015-12-9
在线时间
56 小时
最后登录
2019-4-19
14#
2019-2-11 14:48:33 只看该作者
实现shadow的 方法的值得学习 可以看出在灯光道路上的效果一直很好的祥子 实现shadow的 方法的值得学习 可以看出在灯光道路上的效果一直很好的祥子实现shadow的 方法的值得学习 可以看出在灯光道路上的效果一直很好的祥子
排名
34881
昨日变化

0

主题

11

帖子

26

积分

Rank: 1

UID
133099
好友
0
蛮牛币
4
威望
0
注册时间
2015-12-30
在线时间
7 小时
最后登录
2019-3-13
QQ
15#
2019-3-13 11:47:39 只看该作者
您需要登录后才可以回帖 登录 | 注册帐号

本版积分规则

  • 【人事】中共临汾市委组织部公示3名拟任职干部 2019-05-18
  • 习近平与人民日报那些事 2019-05-10
  • 很多常用药同属一家族 2019-04-30
  • 小牛犊天生两条腿 走起路来像袋鼠 2019-04-30
  • 就因为“阶级亲”,才应把这些难民送到欧洲。欧洲生活水平高呀,让亲人生活的更好。不能让他们到中国受苦受难呀。 2019-04-27
  • 资管新规来了!打破刚兑  投资者怎么办? 2019-04-27
  • 紫光阁中共中央国家机关工作委员会 2019-04-24
  • 图解:习近平主席这12个金句振奋人心! 2019-04-24
  • 您访问的页面找不回来了 2019-04-07
  • 五莲科技局以“三大”助力动能转换 2019-04-07
  • 匹夫有责之一百一十二—道义大义的博客—强国博客—人民网 2019-03-30
  • 守住青山不放松 护好绿水不辞难——在渝全国人大代表聚焦“共抓大保护、不搞大开发”专题调研记略 2019-03-28
  • 经营者要想“我心换你心”,就要未雨绸缪,让不诚信的诱惑少一点,如此才能在市场中生存下来。反过来说,承担不起亏损就关门歇业,是否也是一种不诚信呢? 2019-03-21
  • 追风上市公司“跌落神坛”-热门标签-华商网数码 2019-03-21
  • 文化艺术交易场所沙龙第一期活动在京顺利举行 2019-03-16
  • 648| 435| 67| 963| 452| 479| 615| 350| 900| 644|