# HG changeset patch # User Alain Mazy # Date 1575905882 -3600 # Node ID 8154350aa1958e4f263791c4f588170a691aff9a # Parent 355dba5352d7aa2d1ace612a93a3c17c65a5d591# Parent 04fd875b91f400e3e4d71b3333f27ef79908b961 merge diff -r 04fd875b91f4 -r 8154350aa195 Framework/Radiography/RadiographyAlphaLayer.cpp --- a/Framework/Radiography/RadiographyAlphaLayer.cpp Sat Dec 07 18:41:54 2019 +0100 +++ b/Framework/Radiography/RadiographyAlphaLayer.cpp Mon Dec 09 16:38:02 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 04fd875b91f4 -r 8154350aa195 Framework/Toolbox/TextRenderer.cpp --- a/Framework/Toolbox/TextRenderer.cpp Sat Dec 07 18:41:54 2019 +0100 +++ b/Framework/Toolbox/TextRenderer.cpp Mon Dec 09 16:38:02 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(); }