diff options
author | Ashod Nakashian <ashod.nakashian@collabora.co.uk> | 2018-05-20 15:17:16 -0400 |
---|---|---|
committer | Jan Holesovsky <kendy@collabora.com> | 2018-06-01 08:59:24 +0200 |
commit | ef332bcfac96ec0f492179f454be6a474c67c212 (patch) | |
tree | cec522b31f551eb0655ea88154b3ae292bd68c7a /svx | |
parent | 02234666caa4af031dde9411193f7994c9e2746c (diff) |
svx: set the font name of imported PDF text
Change-Id: I79dde3c8983a70311de2d2a46093fac2722fb372
Diffstat (limited to 'svx')
-rw-r--r-- | svx/source/svdraw/svdpdf.cxx | 24 |
1 files changed, 19 insertions, 5 deletions
diff --git a/svx/source/svdraw/svdpdf.cxx b/svx/source/svdraw/svdpdf.cxx index 24102a135ece..5a90da06b6eb 100644 --- a/svx/source/svdraw/svdpdf.cxx +++ b/svx/source/svdraw/svdpdf.cxx @@ -927,6 +927,20 @@ void ImpSdrPdfImport::ImportText(FPDF_PAGEOBJECT pPageObject, FPDF_TEXTPAGE pTex mbFntDirty = true; } + std::unique_ptr<char[]> pFontName(new char[80 + 1]); // + terminating null + char* pCharFontName = reinterpret_cast<char*>(pFontName.get()); + int nFontNameChars = FPDFTextObj_GetFontName(pPageObject, pCharFontName); + if (nFontNameChars > 0) + { + OUString sFontName = OUString::createFromAscii(pFontName.get()); + if (sFontName != aFnt.GetFamilyName()) + { + aFnt.SetFamilyName(sFontName); + mpVD->SetFont(aFnt); + mbFntDirty = true; + } + } + Color aTextColor(COL_TRANSPARENT); unsigned int nR, nG, nB, nA; if (FPDFTextObj_GetColor(pPageObject, &nR, &nG, &nB, &nA)) @@ -1209,11 +1223,11 @@ void ImpSdrPdfImport::ImportPath(FPDF_PAGEOBJECT pPageObject, int /*nPageObjectI if (!mbLastObjWasPolyWithoutLine || !CheckLastPolyLineAndFillMerge(basegfx::B2DPolyPolygon(aPolyPoly))) { - SdrPathObj* pPath = new SdrPathObj(OBJ_POLY, aPolyPoly); - pPath->SetModel(mpModel); - SetAttributes(pPath); - InsertObj(pPath, false); -} + SdrPathObj *pPath = new SdrPathObj(OBJ_POLY, aPolyPoly); + pPath->SetModel(mpModel); + SetAttributes(pPath); + InsertObj(pPath, false); + } } Point ImpSdrPdfImport::PointsToLogic(double x, double y) const |