/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you under the Apache * License, Version 2.0 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace vcl; Qt5FontFace::Qt5FontFace(const Qt5FontFace& rSrc) : PhysicalFontFace(rSrc) , m_aFontId(rSrc.m_aFontId) { if (rSrc.m_xCharMap.is()) m_xCharMap = rSrc.m_xCharMap; } FontWeight Qt5FontFace::toFontWeight(const int nWeight) { if (nWeight <= QFont::Thin) return WEIGHT_THIN; if (nWeight <= QFont::ExtraLight) return WEIGHT_ULTRALIGHT; if (nWeight <= QFont::Light) return WEIGHT_LIGHT; if (nWeight <= QFont::Normal) return WEIGHT_NORMAL; if (nWeight <= QFont::Medium) return WEIGHT_MEDIUM; if (nWeight <= QFont::DemiBold) return WEIGHT_SEMIBOLD; if (nWeight <= QFont::Bold) return WEIGHT_BOLD; if (nWeight <= QFont::ExtraBold) return WEIGHT_ULTRABOLD; return WEIGHT_BLACK; } FontWidth Qt5FontFace::toFontWidth(const int nStretch) { if (nStretch == 0) // QFont::AnyStretch since Qt 5.8 return WIDTH_DONTKNOW; if (nStretch <= QFont::UltraCondensed) return WIDTH_ULTRA_CONDENSED; if (nStretch <= QFont::ExtraCondensed) return WIDTH_EXTRA_CONDENSED; if (nStretch <= QFont::Condensed) return WIDTH_CONDENSED; if (nStretch <= QFont::SemiCondensed) return WIDTH_SEMI_CONDENSED; if (nStretch <= QFont::Unstretched) return WIDTH_NORMAL; if (nStretch <= QFont::SemiExpanded) return WIDTH_SEMI_EXPANDED; if (nStretch <= QFont::Expanded) return WIDTH_EXPANDED; if (nStretch <= QFont::ExtraExpanded) return WIDTH_EXTRA_EXPANDED; return WIDTH_ULTRA_EXPANDED; } FontItalic Qt5FontFace::toFontItalic(const QFont::Style eStyle) { switch (eStyle) { case QFont::StyleNormal: return ITALIC_NONE; case QFont::StyleItalic: return ITALIC_NORMAL; case QFont::StyleOblique: return ITALIC_OBLIQUE; } return ITALIC_NONE; } void Qt5FontFace::fillAttributesFromQFont(const QFont& rFont, FontAttributes& rFA) { QFontInfo aFontInfo(rFont); rFA.SetFamilyName(toOUString(aFontInfo.family())); if (IsStarSymbol(toOUString(aFontInfo.family()))) rFA.SetSymbolFlag(true); rFA.SetStyleName(toOUString(aFontInfo.styleName())); rFA.SetPitch(aFontInfo.fixedPitch() ? PITCH_FIXED : PITCH_VARIABLE); rFA.SetWeight(Qt5FontFace::toFontWeight(aFontInfo.weight())); rFA.SetItalic(Qt5FontFace::toFontItalic(aFontInfo.style())); rFA.SetWidthType(Qt5FontFace::toFontWidth(rFont.stretch())); } Qt5FontFace* Qt5FontFace::fromQFont(const QFont& rFont) { FontAttributes aFA; fillAttributesFromQFont(rFont, aFA); return new Qt5FontFace(aFA, rFont.toString()); } Qt5FontFace* Qt5FontFace::fromQFontDatabase(const QString& aFamily, const QString& aStyle) { QFontDatabase aFDB; FontAttributes aFA; aFA.SetFamilyName(toOUString(aFamily)); if (IsStarSymbol(aFA.GetFamilyName())) aFA.SetSymbolFlag(true); aFA.SetStyleName(toOUString(aStyle)); aFA.SetPitch(aFDB.isFixedPitch(aFamily, aStyle) ? PITCH_FIXED : PITCH_VARIABLE); aFA.SetWeight(Qt5FontFace::toFontWeight(aFDB.weight(aFamily, aStyle))); aFA.SetItalic(aFDB.italic(aFamily, aStyle) ? ITALIC_NORMAL : ITALIC_NONE); return new Qt5FontFace(aFA, aFamily + "," + aStyle); } Qt5FontFace::Qt5FontFace(const FontAttributes& rFA, const QString& rFontID) : PhysicalFontFace(rFA) , m_aFontId(rFontID) , m_bFontCapabilitiesRead(false) { } sal_IntPtr Qt5FontFace::GetFontId() const { return reinterpret_cast(&m_aFontId); } QFont Qt5FontFace::CreateFont() const { QFont aFont; aFont.fromString(m_aFontId); return aFont; } rtl::Reference Qt5FontFace::CreateFontInstance(const FontSelectPattern& rFSD) const { return new Qt5Font(*this, rFSD); } const FontCharMapRef& Qt5FontFace::GetFontCharMap() const { if (m_xCharMap.is()) return m_xCharMap; QFont aFont; aFont.fromString(m_aFontId); QRawFont aRawFont(QRawFont::fromFont(aFont)); QByteArray aCMapTable = aRawFont.fontTable("cmap"); if (aCMapTable.isEmpty()) { m_xCharMap = new FontCharMap(); return m_xCharMap; } CmapResult aCmapResult; if (ParseCMAP(reinterpret_cast(aCMapTable.data()), aCMapTable.size(), aCmapResult)) m_xCharMap = new FontCharMap(aCmapResult); return m_xCharMap; } bool Qt5FontFace::GetFontCapabilities(vcl::FontCapabilities& rFontCapabilities) const { // read this only once per font if (m_bFontCapabilitiesRead) { rFontCapabilities = m_aFontCapabilities; return rFontCapabilities.oUnicodeRange || rFontCapabilities.oCodePageRange; } m_bFontCapabilitiesRead = true; QFont aFont; aFont.fromString(m_aFontId); QRawFont aRawFont(QRawFont::fromFont(aFont)); QByteArray aOS2Table = aRawFont.fontTable("OS/2"); if (!aOS2Table.isEmpty()) { vcl::getTTCoverage(m_aFontCapabilities.oUnicodeRange, m_aFontCapabilities.oCodePageRange, reinterpret_cast(aOS2Table.data()), aOS2Table.size()); } rFontCapabilities = m_aFontCapabilities; return rFontCapabilities.oUnicodeRange || rFontCapabilities.oCodePageRange; } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */