29 lines
1.3 KiB
Python
29 lines
1.3 KiB
Python
import lnx.utils
|
|
|
|
if lnx.is_reload(__name__):
|
|
lnx.utils = lnx.reload_module(lnx.utils)
|
|
else:
|
|
lnx.enable_reload(__name__)
|
|
|
|
def morph_pos(vert):
|
|
rpdat = lnx.utils.get_rp()
|
|
vert.add_include('compiled.inc')
|
|
vert.add_include('std/morph_target.glsl')
|
|
vert.add_uniform('sampler2D morphDataPos', link='_morphDataPos', included=True)
|
|
vert.add_uniform('sampler2D morphDataNor', link='_morphDataNor', included=True)
|
|
vert.add_uniform('vec4 morphWeights[8]', link='_morphWeights', included=True)
|
|
vert.add_uniform('vec2 morphScaleOffset', link='_morphScaleOffset', included=True)
|
|
vert.add_uniform('vec2 morphDataDim', link='_morphDataDim', included=True)
|
|
vert.add_uniform('float texUnpack', link='_texUnpack')
|
|
vert.add_uniform('float posUnpack', link='_posUnpack')
|
|
vert.write_attrib('vec2 texCoordMorph = morph * texUnpack;')
|
|
vert.write_attrib('spos.xyz *= posUnpack;')
|
|
vert.write_attrib('getMorphedVertex(texCoordMorph, spos.xyz);')
|
|
vert.write_attrib('spos.xyz /= posUnpack;')
|
|
|
|
def morph_nor(vert, is_bone, prep):
|
|
vert.write_attrib('vec3 morphNor = vec3(0, 0, 0);')
|
|
vert.write_attrib('getMorphedNormal(texCoordMorph, vec3(nor.xy, pos.w), morphNor);')
|
|
if not is_bone:
|
|
vert.write_attrib(prep + 'wnormal = normalize(N * morphNor);')
|