# HG changeset patch # User Alain Mazy # Date 1575905859 -3600 # Node ID 355dba5352d7aa2d1ace612a93a3c17c65a5d591 # Parent e2435a5240293801c5ed04d67013e47625aad2a0 TestRenderer: Add a blank line on top of the text to improve bilinera filtering of the topmost line diff -r e2435a524029 -r 355dba5352d7 Framework/Radiography/RadiographyAlphaLayer.cpp --- a/Framework/Radiography/RadiographyAlphaLayer.cpp Sat Dec 07 17:47:35 2019 +0100 +++ b/Framework/Radiography/RadiographyAlphaLayer.cpp Mon Dec 09 16:37:39 2019 +0100 @@ -91,6 +91,7 @@ return; // layer is outside the buffer } + printf("rendering alpha: %d \n", y1); t.Apply(tmp, cropped, interpolation, true /* clear */); float value = foreground_; diff -r e2435a524029 -r 355dba5352d7 Framework/Toolbox/TextRenderer.cpp --- a/Framework/Toolbox/TextRenderer.cpp Sat Dec 07 17:47:35 2019 +0100 +++ b/Framework/Toolbox/TextRenderer.cpp Mon Dec 09 16:37:39 2019 +0100 @@ -57,7 +57,22 @@ posInString += utf8CharLength; } - return alphabet->RenderText(utf8String); + + std::auto_ptr renderedText(alphabet->RenderText(utf8String)); + + // add a blank line on top of the text (to improve bilinear filtering of the topmost line) + std::auto_ptr renderedTextExtended(new Orthanc::Image(renderedText->GetFormat(), renderedText->GetWidth(), renderedText->GetHeight() + 1, true)); + + Orthanc::ImageAccessor textRegion; + Orthanc::ImageAccessor firstLineRegion; + + renderedTextExtended->GetRegion(firstLineRegion, 0, 0, renderedText->GetWidth(), 1); + Orthanc::ImageProcessing::Set(firstLineRegion, 0); + + renderedTextExtended->GetRegion(textRegion, 0, 1, renderedText->GetWidth(), renderedText->GetHeight()); + Orthanc::ImageProcessing::Copy(textRegion, *renderedText); + + return renderedTextExtended.release(); }