# HG changeset patch # User Sebastien Jodogne # Date 1575910134 -3600 # Node ID e99e09143c64852cfb1296bdc57b29ad34da6b28 # Parent f621b57c9f373428bc56c4a41e37cfd1d911d13a# Parent 8154350aa1958e4f263791c4f588170a691aff9a integration mainline->broker diff -r f621b57c9f37 -r e99e09143c64 Framework/Radiography/RadiographyAlphaLayer.cpp --- a/Framework/Radiography/RadiographyAlphaLayer.cpp Mon Dec 09 17:48:14 2019 +0100 +++ b/Framework/Radiography/RadiographyAlphaLayer.cpp Mon Dec 09 17:48:54 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 f621b57c9f37 -r e99e09143c64 Framework/Toolbox/TextRenderer.cpp --- a/Framework/Toolbox/TextRenderer.cpp Mon Dec 09 17:48:14 2019 +0100 +++ b/Framework/Toolbox/TextRenderer.cpp Mon Dec 09 17:48:54 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(); }