Issue #14: Incorrect text drawing for vertical writing systems

This commit is contained in:
Jakub Melka 2022-06-01 19:57:41 +02:00
parent ad12fc89df
commit e7c102ef48
4 changed files with 15 additions and 6 deletions

View File

@ -995,6 +995,7 @@ PDFRealizedFontPointer PDFRealizedFont::createRealizedFont(PDFFontPointer font,
impl->m_parentFont = font;
impl->m_pixelSize = pixelSize;
const PDFFontCMap* cmap = font->getCMap();
const FontDescriptor* descriptor = font->getFontDescriptor();
if (descriptor->isEmbedded())
{
@ -1009,7 +1010,7 @@ PDFRealizedFontPointer PDFRealizedFont::createRealizedFont(PDFFontPointer font,
PDFRealizedFontImpl::checkFreeTypeError(FT_New_Memory_Face(impl->m_library, reinterpret_cast<const FT_Byte*>(impl->m_embeddedFontData.constData()), impl->m_embeddedFontData.size(), 0, &impl->m_face));
FT_Select_Charmap(impl->m_face, FT_ENCODING_UNICODE); // We try to select unicode encoding, but if it fails, we don't do anything (use glyph indices instead)
PDFRealizedFontImpl::checkFreeTypeError(FT_Set_Pixel_Sizes(impl->m_face, 0, qRound(pixelSize * PDFRealizedFontImpl::PIXEL_SIZE_MULTIPLIER)));
impl->m_isVertical = impl->m_face->face_flags & FT_FACE_FLAG_VERTICAL;
impl->m_isVertical = cmap ? cmap->isVertical() : false;
impl->m_isEmbedded = true;
result.reset(new PDFRealizedFont(implPtr.release()));
}
@ -1035,7 +1036,7 @@ PDFRealizedFontPointer PDFRealizedFont::createRealizedFont(PDFFontPointer font,
PDFRealizedFontImpl::checkFreeTypeError(FT_New_Memory_Face(impl->m_library, reinterpret_cast<const FT_Byte*>(impl->m_systemFontData.constData()), impl->m_systemFontData.size(), 0, &impl->m_face));
FT_Select_Charmap(impl->m_face, FT_ENCODING_UNICODE); // We try to select unicode encoding, but if it fails, we don't do anything (use glyph indices instead)
PDFRealizedFontImpl::checkFreeTypeError(FT_Set_Pixel_Sizes(impl->m_face, 0, qRound(pixelSize * PDFRealizedFontImpl::PIXEL_SIZE_MULTIPLIER)));
impl->m_isVertical = impl->m_face->face_flags & FT_FACE_FLAG_VERTICAL;
impl->m_isVertical = cmap ? cmap->isVertical() : false;
impl->m_isEmbedded = false;
if (const char* postScriptName = FT_Get_Postscript_Name(impl->m_face))
{

View File

@ -276,6 +276,9 @@ public:
/// Returns ToUnicode mapping (or nullptr, if font has no mapping to unicode)
virtual const PDFFontCMap* getToUnicode() const { return nullptr; }
/// Returns cmap for font character encoding
virtual const PDFFontCMap* getCMap() const { return nullptr; }
/// Returns font descriptor
const FontDescriptor* getFontDescriptor() const { return &m_fontDescriptor; }
@ -488,6 +491,9 @@ public:
/// Returns true, if mapping is valid
bool isValid() const { return !m_entries.empty(); }
/// Returns true, if vertical writing mode is on
bool isVertical() const { return m_vertical; }
/// Creates mapping from name (name must be one of predefined names)
static PDFFontCMap createFromName(const QByteArray& name);
@ -612,7 +618,7 @@ public:
virtual FontType getFontType() const override { return FontType::Type0; }
virtual const PDFFontCMap* getToUnicode() const override { return &m_toUnicode; }
const PDFFontCMap* getCMap() const { return &m_cmap; }
virtual const PDFFontCMap* getCMap() const override { return &m_cmap; }
const PDFCIDtoGIDMapper* getCIDtoGIDMapper() const { return &m_mapper; }
/// Returns the glyph advance, if it can be obtained, or zero, if it cannot

View File

@ -51,9 +51,9 @@ Software have following features (the list is not complete):
- [x] internal structure inspector
- [x] compare documents
- [x] static XFA support (readonly, simple XFA only)
- [ ] create fillable forms *(planned in year 2022)*
- [ ] electronically/digitally sign documents *(planned in year 2022)*
- [ ] 3D PDF support *(planned in year 2023)*
- [x] electronically/digitally sign documents
- [ ] 3D PDF support *(planned in year 2022)*
- [ ] create fillable forms *(planned in year 2023)*
- [ ] watermarks / headers / footers *(planned in year 2023)*
- [ ] presentation application *(planned in year 2023)*
- [ ] public key security encryption *(planned in year 2023)*

View File

@ -1,7 +1,9 @@
CURRENT:
- Issue #10: Performance optimization
- Issue #14: Incorrect text drawing for vertical writing systems
- static XFA support (readonly, simple XFA only)
- electronically/digitally sign documents
V: 1.1.0, 19.12.2021
- DocDiff application (compare similar PDF documents)