From 56169b70016e3491bed91b55d69390b65ae75b7d Mon Sep 17 00:00:00 2001 From: fgenesis Date: Fri, 29 Dec 2023 22:43:05 +0100 Subject: [PATCH 1/2] fix Li's head missing. broke in cf2dc71a341b00f6463 rq=0 used to hide the base head gfx to only show frames. but rq=0 is not what we want after consolidating those extra quads into the base quad. so in order to keep backwards compat, unhide a bone if it has frame tiles. --- BBGE/SkeletalSprite.cpp | 38 ++++++++++++++++++++------------------ 1 file changed, 20 insertions(+), 18 deletions(-) diff --git a/BBGE/SkeletalSprite.cpp b/BBGE/SkeletalSprite.cpp index 43da5bc..abee635 100644 --- a/BBGE/SkeletalSprite.cpp +++ b/BBGE/SkeletalSprite.cpp @@ -1460,24 +1460,6 @@ void SkeletalSprite::loadSkeletal(const std::string &fn) e->load(pfile); } } - XMLElement *fr=0; - fr = bone->FirstChildElement("Frame"); - int frc=0; - while(fr) - { - std::string gfx; - if (fr->Attribute("gfx")) - { - gfx = fr->Attribute("gfx"); - newb->addFrame(gfx); - } - fr = fr->NextSiblingElement("Frame"); - frc++; - } - if (frc) - { - newb->showFrame(0); - } if (bone->Attribute("pass")) { int pass = atoi(bone->Attribute("pass")); @@ -1587,6 +1569,26 @@ void SkeletalSprite::loadSkeletal(const std::string &fn) grid->drawOrder = (GridDrawOrder)ord; } } + if(XMLElement *fr = bone->FirstChildElement("Frame")) + { + int frc = 0; + while(fr) + { + std::string gfx; + if (fr->Attribute("gfx")) + { + gfx = fr->Attribute("gfx"); + newb->addFrame(gfx); + } + fr = fr->NextSiblingElement("Frame"); + frc++; + } + if (frc) + { + newb->showFrame(0); + } + newb->renderQuad = true; + } bone = bone->NextSiblingElement("Bone"); } // attach bones From 49ffcf227b0dfcf3658fcc4b4060ee4ebfd60d80 Mon Sep 17 00:00:00 2001 From: fgenesis Date: Thu, 11 Jan 2024 00:05:45 +0100 Subject: [PATCH 2/2] FrameBuffer: change glTexImage2D to use more a compatible format reported by pbarzena -- apparently causes problems with newer nvidia gpus on win11 but i'm not sure if this is really the problem --- BBGE/DarkLayer.cpp | 2 +- BBGE/FrameBuffer.cpp | 5 ++--- 2 files changed, 3 insertions(+), 4 deletions(-) diff --git a/BBGE/DarkLayer.cpp b/BBGE/DarkLayer.cpp index 53b9faf..23acfe8 100644 --- a/BBGE/DarkLayer.cpp +++ b/BBGE/DarkLayer.cpp @@ -112,7 +112,7 @@ void DarkLayer::preRender() if (useFrameBuffer) frameBuffer.startCapture(); - glClearColor(1,1,1,1); + glClearColor(1,1,1,0); glClear(GL_COLOR_BUFFER_BIT); core->render(layer, layer, false); diff --git a/BBGE/FrameBuffer.cpp b/BBGE/FrameBuffer.cpp index 2da51d9..4fd998a 100644 --- a/BBGE/FrameBuffer.cpp +++ b/BBGE/FrameBuffer.cpp @@ -118,10 +118,9 @@ bool FrameBuffer::init(int width, int height, bool fitToScreen) glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR ); glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR ); - // FIXME: check for GL_ARB_texture_float; otherwise stick with old format - glTexImage2D( GL_TEXTURE_2D, 0, GL_RGBA16F_ARB, + glTexImage2D( GL_TEXTURE_2D, 0, GL_RGBA, width, height, - 0, GL_RGBA, GL_FLOAT, 0 ); + 0, GL_RGBA, GL_UNSIGNED_BYTE, 0 ); // Put together