Summary: | Krita text appears to be drawn at incorrect point size | ||
---|---|---|---|
Product: | [Applications] krita | Reporter: | john@ridgwaydesign.fsnet.co.uk <johnridgwaydesign> |
Component: | Tool/Text | Assignee: | Dmitry Kazakov <dimula73> |
Status: | RESOLVED FIXED | ||
Severity: | normal | CC: | ghevan, griffinvalley, info, kathryncook126, tamtamy.tymona, tysontanx |
Priority: | NOR | Keywords: | release_blocker, triaged |
Version: | unspecified | ||
Target Milestone: | --- | ||
Platform: | Microsoft Windows | ||
OS: | Microsoft Windows | ||
Latest Commit: | https://invent.kde.org/graphics/krita/commit/91625c4ae311e5293dbee54eb2e6a04a5a53d6dd | Version Fixed In: | |
Sentry Crash Report: | |||
Attachments: |
Three samples of text. Krita, Photoshop, Painter in descending order.
Chilanka font, 18 points on 300 ppi canvas Gimp and Krita 72ppi vs 300ppi comparison Gimp, Krita and LibreOffice 72ppi vs 300ppi comparison Gimp and Krita 72ppi 20points comparison Krita font test.jpg attachment-18245-0.html |
Happens to me as well. I can confirm this in Photoshop CC. And I clearly remembered how small 9pt letters were when I was using PS back in the days. setting to confirmed then. Take 9pt for example. Back in the days we actually matched 9pt with 12px for webpages. You can see how small 9pt really is in Microsoft Word and LibreOffice as well. I migrated from Photoshop, and 9pt was tiny in a PS document with similar settings. 9pt letters in Krita's default A4 template is substantially larger than what I observed in other applications. I guess the problem is that officially, pt is 'points' that is 1/72th of an inch, and I am not sure if that is also the case in ps... *** This bug has been marked as a duplicate of bug 397616 *** I'm unduplicating it from bug 397616 because it is about a bit different issue (read bug 397616 comment 6 for details). It's still present, so I'm reopening it as well. Created attachment 131675 [details]
Chilanka font, 18 points on 300 ppi canvas
Krita text:
- create a 1000x1000 canvas 300ppi
- make a text shape using a specific font (I used Chilanka) - set the size to 18 points
Gimp text:
- create a 1000x1000 canvas 300ppi
- make a text shape using the same font and the same size like in Krita
- export to png
- import to Krita
LibreOffice Writer:
- Write text using the same font and size
- Export to PDF (make sure it's 300 ppi!)
- import in Krita as image (make sure it's 300 ppi here as well!)
Scribus:
- create new project, make sure it's 300 ppi
- create a text shape, write text using the same font and size
- export to pdf
- import in Krita as image (make sure it's 300 ppi here as well!)
Even though there is lots of steps for all other programs, Scribus, Gimp and LibreOffice Writer give the same results while Krita's text is bigger.
Created attachment 131699 [details]
Gimp and Krita 72ppi vs 300ppi comparison
Created attachment 131700 [details]
Gimp, Krita and LibreOffice 72ppi vs 300ppi comparison
Note that LibreOffice couldn't be set to 72ppi, so it's 75ppi, but the size is still much more Gimp-like than Krita-like, so I believe that at 72ppi it would be just the same.
Created attachment 131702 [details]
Gimp and Krita 72ppi 20points comparison
It looks like Krita is counting the font size only using the middle and higher parts of the characters, dismissing the lower parts. So "Ch" (20 points) text in Krita is exactly 20 pixels high in 72ppi, while in Gimp it would be 14 pixels. "Chy" however in Krita has 28 pixels, while in Gimp it's 20 pixels.
*** Bug 412070 has been marked as a duplicate of this bug. *** Assigning Dmitry, relevant MR: https://invent.kde.org/graphics/krita/-/merge_requests/716 I'm marking it as "release_blocker" because we really need to fix it before Krita 5, otherwise we'd have to wait until Krita 6 (because it will change the way text is rendered on the canvas) and this is a serious issue. Created attachment 137625 [details] Krita font test.jpg Dear sirs, Re:- -- Comment #13 from Tiar <tamtamy.tymona@gmail.com> --- I'm marking it as "release_blocker" because we really need to fix it before Krita 5, otherwise we'd have to wait until Krita 6 (because it will change the way text is rendered on the canvas) and this is a serious issue. Having reported the bug in text height I felt I must report a possibly connected bug regarding the inclination of text in italic which I came across yesterday when working on a picture I had originally lettered using Photoshop. I noticed an omission in the original text and replaced it with text using Krita. The original text was with an opening capital of 12 pts and the remainder in 8 points with 8 point line spacing and font kerning of +25%. In checking that the Krita text matched the size of the original text, I adjusted the font sizes, kerning and line spacing, but I was surprised to find that the angle of the italic text did not match as can be seen in the attached pic.. Below is svg code as generated by Krita. I hope this helps. Best regards, John Ridgway <text style="fill:#ffff7d; letter-spacing:0.25; word-spacing:0; kerning:auto; font-family:Laffayette Comic Pro; font-size:6pt; font-size-adjust:0.235294; font-weight:400; font-style:italic; baseline-shift:baseline; stroke-width:0; font-stretch:0"><tspan x="0"><tspan style="font-size:8pt; font-size-adjust:0.294118; font-weight:700">A</tspan><tspan style="fill:#000000">nd from within the splintered </tspan></tspan><tspan style="fill:#000000" x="0" dy="7.8pt">remains of the dark tower, a demon </tspan><tspan style="fill:#000000" x="0" dy="8.01pt">was released...</tspan></text> On Wed, 14 Apr 2021 at 03:50, Tiar <bugzilla_noreply@kde.org> wrote: > https://bugs.kde.org/show_bug.cgi?id=404011 > > Tiar <tamtamy.tymona@gmail.com> changed: > > What |Removed |Added > > ---------------------------------------------------------------------------- > Keywords| |release_blocker > > --- Comment #13 from Tiar <tamtamy.tymona@gmail.com> --- > I'm marking it as "release_blocker" because we really need to fix it before > Krita 5, otherwise we'd have to wait until Krita 6 (because it will change > the > way text is rendered on the canvas) and this is a serious issue. > > -- > You are receiving this mail because: > You reported the bug. Git commit cb06cfb2c037db6c51a0569ab59940e7e93a729a by Dmitry Kazakov. Committed on 28/04/2021 at 09:05. Pushed by dkazakov into branch 'master'. Fix size of the rendered fonts in Krita Qt has a bug. When requesting font from the font database (in QFontDatabase::load()), Qt scales its size by the current primary display DPI. The only official way to disable that is to assign QTextDocument to QTextLayout, which is not something we would like to do. So we do the hackish way, we just prescale the font with inverted value. This hack changes only the rendering process without touching the way how the text is saved into .kra or .svg. That is nice, but it means it also affects how old files are renderred. To let the user open older files we provide a preference option to enable this scaling again. NOTE: the hack is not needed for pixel-measured fonts, they seem to render correctly. Pity we don't use them in our SVG code (partially because they don't allow fractional-sized fonts). M +50 -1 libs/flake/text/KoSvgTextChunkShape.cpp M +26 -0 libs/ui/dialogs/kis_dlg_preferences.cc M +2 -0 libs/ui/dialogs/kis_dlg_preferences.h M +51 -17 libs/ui/forms/wdggeneralsettings.ui https://invent.kde.org/graphics/krita/commit/cb06cfb2c037db6c51a0569ab59940e7e93a729a Thank you Dmitry! :D Git commit 91625c4ae311e5293dbee54eb2e6a04a5a53d6dd by Dmitry Kazakov. Committed on 03/05/2021 at 14:20. Pushed by dkazakov into branch 'master'. Fix font size in files created in Krita 4.4 Now when loading a file created in Krita 4.4 we convert its font sizes using the DPI of the dispaly and bake this new value into the file. The user can override this behavior by selecting another DPI in Settings->General->Miscelaneous->Font DPI workaround. Setting this value to 72 DPI will effectively disable any scaling. M +0 -2 libs/flake/svg/SvgGraphicContext.h M +0 -1 libs/flake/svg/SvgLoadingContext.cpp M +1 -1 libs/flake/svg/SvgLoadingContext.h M +14 -0 libs/flake/svg/SvgParser.cpp M +1 -0 libs/flake/svg/SvgParser.h M +2 -25 libs/flake/svg/SvgStyleParser.cpp M +3 -2 libs/flake/svg/SvgUtil.cpp M +29 -20 libs/flake/tests/TestSvgText.cpp M +65 -36 libs/flake/text/KoSvgTextChunkShape.cpp M +0 -2 libs/flake/text/KoSvgTextChunkShape_p.h M +63 -5 libs/flake/text/KoSvgTextProperties.cpp M +5 -1 libs/flake/text/KoSvgTextProperties.h M +15 -1 libs/ui/flake/kis_shape_layer.cc M +1 -0 libs/ui/flake/kis_shape_layer.h M +1 -0 libs/ui/flake/kis_shape_selection.cpp M +5 -1 libs/ui/forms/wdggeneralsettings.ui M +1 -0 plugins/impex/svg/kis_svg_import.cc https://invent.kde.org/graphics/krita/commit/91625c4ae311e5293dbee54eb2e6a04a5a53d6dd Created attachment 138214 [details] attachment-18245-0.html I notice that the text in the placeholder box types in at the correct size for the setting. This has become apparent when creating multi-line text for caption boxes in comics. Text has to be split into several lines to fit the width of a picture. If I want the text in the picture to be 10 points, I have to type it into the placeholder at 10 points to see where to make line breaks so that the length of text is going to fit the picture width. I then have to reduce the font size by two points (to 8 points) and change the spacing of the lines in svg mode. I can then save the text to place it in the dialog box. I don't understand why the placeholder box is correct and the artwork is the wrong size. Is this due to the dpi of the placeholder being at a different resolution? Best regards, John Ridgway On Mon, 3 May 2021 at 15:43, Dmitry Kazakov <bugzilla_noreply@kde.org> wrote: > https://bugs.kde.org/show_bug.cgi?id=404011 > > Dmitry Kazakov <dimula73@gmail.com> changed: > > What |Removed |Added > > ---------------------------------------------------------------------------- > Latest Commit|https://invent.kde.org/grap | > https://invent.kde.org/grap > |hics/krita/commit/cb06cfb2c > |hics/krita/commit/91625c4ae > |037db6c51a0569ab59940e7e93a > |311e5293dbee54eb2e6a04a5a53 > |729a |d6dd > > --- Comment #17 from Dmitry Kazakov <dimula73@gmail.com> --- > Git commit 91625c4ae311e5293dbee54eb2e6a04a5a53d6dd by Dmitry Kazakov. > Committed on 03/05/2021 at 14:20. > Pushed by dkazakov into branch 'master'. > > Fix font size in files created in Krita 4.4 > > Now when loading a file created in Krita 4.4 we convert its font > sizes using the DPI of the dispaly and bake this new value into > the file. The user can override this behavior by selecting > another DPI in Settings->General->Miscelaneous->Font DPI workaround. > Setting this value to 72 DPI will effectively disable any scaling. > > M +0 -2 libs/flake/svg/SvgGraphicContext.h > M +0 -1 libs/flake/svg/SvgLoadingContext.cpp > M +1 -1 libs/flake/svg/SvgLoadingContext.h > M +14 -0 libs/flake/svg/SvgParser.cpp > M +1 -0 libs/flake/svg/SvgParser.h > M +2 -25 libs/flake/svg/SvgStyleParser.cpp > M +3 -2 libs/flake/svg/SvgUtil.cpp > M +29 -20 libs/flake/tests/TestSvgText.cpp > M +65 -36 libs/flake/text/KoSvgTextChunkShape.cpp > M +0 -2 libs/flake/text/KoSvgTextChunkShape_p.h > M +63 -5 libs/flake/text/KoSvgTextProperties.cpp > M +5 -1 libs/flake/text/KoSvgTextProperties.h > M +15 -1 libs/ui/flake/kis_shape_layer.cc > M +1 -0 libs/ui/flake/kis_shape_layer.h > M +1 -0 libs/ui/flake/kis_shape_selection.cpp > M +5 -1 libs/ui/forms/wdggeneralsettings.ui > M +1 -0 plugins/impex/svg/kis_svg_import.cc > > > https://invent.kde.org/graphics/krita/commit/91625c4ae311e5293dbee54eb2e6a04a5a53d6dd > > -- > You are receiving this mail because: > You reported the bug. *** Bug 402094 has been marked as a duplicate of this bug. *** |
Created attachment 117882 [details] Three samples of text. Krita, Photoshop, Painter in descending order. SUMMARY Text appears at an incorrect point size. STEPS TO REPRODUCE 1. Type in a note. Save as jpg file. 2. Open this file in Photoshop and type the same note. Save again. 3. Open file in Painter and type in the same note again. Compare results. The text as produced in Photoshop and Painter are similar size (letter spacing and line spacing may be slightly different). The text as produced in Krita is substantially larger. Text used Arial regular. 9pt. Document at 300 dpi. OBSERVED RESULT EXPECTED RESULT SOFTWARE/OS VERSIONS Windows: MacOS: Linux/KDE Plasma: (available in About System) KDE Plasma Version: KDE Frameworks Version: Qt Version: ADDITIONAL INFORMATION