From 919a8a42c74ec989ad7c7234aa960a485c60d144 Mon Sep 17 00:00:00 2001 From: Darryl Pogue Date: Mon, 27 Feb 2023 19:32:07 -0800 Subject: [PATCH] WIP fix clothing blending --- Sources/Plasma/FeatureLib/pfGLPipeline/plGLPipeline.cpp | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/Sources/Plasma/FeatureLib/pfGLPipeline/plGLPipeline.cpp b/Sources/Plasma/FeatureLib/pfGLPipeline/plGLPipeline.cpp index edb3efab31..e51723c2d1 100644 --- a/Sources/Plasma/FeatureLib/pfGLPipeline/plGLPipeline.cpp +++ b/Sources/Plasma/FeatureLib/pfGLPipeline/plGLPipeline.cpp @@ -1649,6 +1649,8 @@ void plGLPipeline::IPreprocessAvatarTextures() glUniform1i(0, 0); glUniform4f(1, 1.f, 1.f, 1.f, 1.f); glActiveTexture(GL_TEXTURE0); + glDepthFunc(GL_LEQUAL); + glDepthMask(GL_TRUE); float uOff = 0.5f / rt->GetWidth(); float vOff = 0.5f / rt->GetHeight(); @@ -1667,7 +1669,11 @@ void plGLPipeline::IPreprocessAvatarTextures() if (k >= plClothingElement::kLayerSkinBlend1 && k <= plClothingElement::kLayerSkinLast) tint.a = co->fSkinBlends[k - plClothingElement::kLayerSkinBlend1]; - // TODO: Set up state based on base layer + if (k == plClothingElement::kLayerBase) { + glBlendFunc(GL_ONE, GL_ZERO); + } else { + glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); + } glUniform4f(1, tint.r, tint.g, tint.b, tint.a);