Kaydet (Commit) 0c75202a authored tarafından Caolán's avatar Caolán

only one headless text renderer now

Change-Id: I045d7a58f3eae20c733fe93faa3a64687e7c85e3
üst 07217654
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* file, You can obtain one at http://mozilla.org/MPL/2.0/. * file, You can obtain one at http://mozilla.org/MPL/2.0/.
*/ */
#include "svpcairotextrender.hxx" #include "headless/svpcairotextrender.hxx"
#include "headless/svpgdi.hxx" #include "headless/svpgdi.hxx"
SvpCairoTextRender::SvpCairoTextRender(SvpSalGraphics& rParent) SvpCairoTextRender::SvpCairoTextRender(SvpSalGraphics& rParent)
......
/* -*- 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/.
*/
#ifndef INCLUDED_VCL_UNX_GTK3_GDI_GTK3CAIROTEXTRENDER_HXX
#define INCLUDED_VCL_UNX_GTK3_GDI_GTK3CAIROTEXTRENDER_HXX
#include "cairotextrender.hxx"
class SvpSalGraphics;
class SvpCairoTextRender : public CairoTextRender
{
protected:
SvpSalGraphics& mrParent;
public:
explicit SvpCairoTextRender(SvpSalGraphics& rParent);
virtual GlyphCache& getPlatformGlyphCache() override;
virtual cairo_t* getCairoContext() override;
virtual void getSurfaceOffset(double& nDX, double& nDY) override;
virtual void clipRegion(cairo_t* cr) override;
virtual void drawSurface(cairo_t* cr) override;
};
#endif
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
...@@ -20,7 +20,7 @@ ...@@ -20,7 +20,7 @@
#include "headless/svpgdi.hxx" #include "headless/svpgdi.hxx"
#include "headless/svpbmp.hxx" #include "headless/svpbmp.hxx"
#ifndef IOS #ifndef IOS
#include "svpcairotextrender.hxx" #include "headless/svpcairotextrender.hxx"
#endif #endif
#include "saldatabasic.hxx" #include "saldatabasic.hxx"
...@@ -221,9 +221,9 @@ SvpSalGraphics::SvpSalGraphics() : ...@@ -221,9 +221,9 @@ SvpSalGraphics::SvpSalGraphics() :
m_bUseFillColor( false ), m_bUseFillColor( false ),
m_aFillColor( COL_WHITE ), m_aFillColor( COL_WHITE ),
m_aDrawMode( basebmp::DrawMode::Paint ), m_aDrawMode( basebmp::DrawMode::Paint ),
m_bClipSetup( false ) m_bClipSetup( false ),
m_aTextRenderImpl(*this)
{ {
m_xTextRenderImpl.reset(new SvpCairoTextRender(*this));
} }
SvpSalGraphics::~SvpSalGraphics() SvpSalGraphics::~SvpSalGraphics()
...@@ -234,7 +234,7 @@ void SvpSalGraphics::setDevice( basebmp::BitmapDeviceSharedPtr& rDevice ) ...@@ -234,7 +234,7 @@ void SvpSalGraphics::setDevice( basebmp::BitmapDeviceSharedPtr& rDevice )
{ {
m_aOrigDevice = rDevice; m_aOrigDevice = rDevice;
ResetClipRegion(); ResetClipRegion();
m_xTextRenderImpl->setDevice(rDevice); m_aTextRenderImpl.setDevice(rDevice);
} }
void SvpSalGraphics::GetResolution( sal_Int32& rDPIX, sal_Int32& rDPIY ) void SvpSalGraphics::GetResolution( sal_Int32& rDPIX, sal_Int32& rDPIY )
......
...@@ -24,38 +24,38 @@ ...@@ -24,38 +24,38 @@
sal_uInt16 SvpSalGraphics::SetFont( FontSelectPattern* pIFSD, int nFallbackLevel ) sal_uInt16 SvpSalGraphics::SetFont( FontSelectPattern* pIFSD, int nFallbackLevel )
{ {
return m_xTextRenderImpl->SetFont(pIFSD, nFallbackLevel); return m_aTextRenderImpl.SetFont(pIFSD, nFallbackLevel);
} }
void SvpSalGraphics::GetFontMetric( ImplFontMetricData* pMetric, int nFallbackLevel ) void SvpSalGraphics::GetFontMetric( ImplFontMetricData* pMetric, int nFallbackLevel )
{ {
m_xTextRenderImpl->GetFontMetric(pMetric, nFallbackLevel); m_aTextRenderImpl.GetFontMetric(pMetric, nFallbackLevel);
} }
const FontCharMapPtr SvpSalGraphics::GetFontCharMap() const const FontCharMapPtr SvpSalGraphics::GetFontCharMap() const
{ {
return m_xTextRenderImpl->GetFontCharMap(); return m_aTextRenderImpl.GetFontCharMap();
} }
bool SvpSalGraphics::GetFontCapabilities(vcl::FontCapabilities &rFontCapabilities) const bool SvpSalGraphics::GetFontCapabilities(vcl::FontCapabilities &rFontCapabilities) const
{ {
return m_xTextRenderImpl->GetFontCapabilities(rFontCapabilities); return m_aTextRenderImpl.GetFontCapabilities(rFontCapabilities);
} }
void SvpSalGraphics::GetDevFontList( PhysicalFontCollection* pFontCollection ) void SvpSalGraphics::GetDevFontList( PhysicalFontCollection* pFontCollection )
{ {
m_xTextRenderImpl->GetDevFontList(pFontCollection); m_aTextRenderImpl.GetDevFontList(pFontCollection);
} }
void SvpSalGraphics::ClearDevFontCache() void SvpSalGraphics::ClearDevFontCache()
{ {
m_xTextRenderImpl->ClearDevFontCache(); m_aTextRenderImpl.ClearDevFontCache();
} }
bool SvpSalGraphics::AddTempDevFont( PhysicalFontCollection* pFontCollection, bool SvpSalGraphics::AddTempDevFont( PhysicalFontCollection* pFontCollection,
const OUString& rFileURL, const OUString& rFontName) const OUString& rFileURL, const OUString& rFontName)
{ {
return m_xTextRenderImpl->AddTempDevFont(pFontCollection, rFileURL, rFontName); return m_aTextRenderImpl.AddTempDevFont(pFontCollection, rFileURL, rFontName);
} }
bool SvpSalGraphics::CreateFontSubset( bool SvpSalGraphics::CreateFontSubset(
...@@ -67,12 +67,12 @@ bool SvpSalGraphics::CreateFontSubset( ...@@ -67,12 +67,12 @@ bool SvpSalGraphics::CreateFontSubset(
int nGlyphCount, int nGlyphCount,
FontSubsetInfo& rInfo) FontSubsetInfo& rInfo)
{ {
return m_xTextRenderImpl->CreateFontSubset(rToFile, pFont, pGlyphIds, pEncoding, pWidths, nGlyphCount, rInfo); return m_aTextRenderImpl.CreateFontSubset(rToFile, pFont, pGlyphIds, pEncoding, pWidths, nGlyphCount, rInfo);
} }
const Ucs2SIntMap* SvpSalGraphics::GetFontEncodingVector( const PhysicalFontFace* pFont, const Ucs2OStrMap** pNonEncoded, std::set<sal_Unicode> const** ppPriority) const Ucs2SIntMap* SvpSalGraphics::GetFontEncodingVector( const PhysicalFontFace* pFont, const Ucs2OStrMap** pNonEncoded, std::set<sal_Unicode> const** ppPriority)
{ {
return m_xTextRenderImpl->GetFontEncodingVector(pFont, pNonEncoded, ppPriority); return m_aTextRenderImpl.GetFontEncodingVector(pFont, pNonEncoded, ppPriority);
} }
const void* SvpSalGraphics::GetEmbedFontData( const void* SvpSalGraphics::GetEmbedFontData(
...@@ -83,12 +83,12 @@ const void* SvpSalGraphics::GetEmbedFontData( ...@@ -83,12 +83,12 @@ const void* SvpSalGraphics::GetEmbedFontData(
FontSubsetInfo& rInfo, FontSubsetInfo& rInfo,
long* pDataLen) long* pDataLen)
{ {
return m_xTextRenderImpl->GetEmbedFontData(pFont, pUnicodes, pWidths, nLen, rInfo, pDataLen); return m_aTextRenderImpl.GetEmbedFontData(pFont, pUnicodes, pWidths, nLen, rInfo, pDataLen);
} }
void SvpSalGraphics::FreeEmbedFontData( const void* pData, long nLen ) void SvpSalGraphics::FreeEmbedFontData( const void* pData, long nLen )
{ {
m_xTextRenderImpl->FreeEmbedFontData(pData, nLen); m_aTextRenderImpl.FreeEmbedFontData(pData, nLen);
} }
void SvpSalGraphics::GetGlyphWidths( const PhysicalFontFace* pFont, void SvpSalGraphics::GetGlyphWidths( const PhysicalFontFace* pFont,
...@@ -96,39 +96,39 @@ void SvpSalGraphics::GetGlyphWidths( const PhysicalFontFace* pFont, ...@@ -96,39 +96,39 @@ void SvpSalGraphics::GetGlyphWidths( const PhysicalFontFace* pFont,
Int32Vector& rWidths, Int32Vector& rWidths,
Ucs2UIntMap& rUnicodeEnc ) Ucs2UIntMap& rUnicodeEnc )
{ {
m_xTextRenderImpl->GetGlyphWidths(pFont, bVertical, rWidths, rUnicodeEnc); m_aTextRenderImpl.GetGlyphWidths(pFont, bVertical, rWidths, rUnicodeEnc);
} }
bool SvpSalGraphics::GetGlyphBoundRect( sal_GlyphId aGlyphId, Rectangle& rRect ) bool SvpSalGraphics::GetGlyphBoundRect( sal_GlyphId aGlyphId, Rectangle& rRect )
{ {
return m_xTextRenderImpl->GetGlyphBoundRect(aGlyphId, rRect); return m_aTextRenderImpl.GetGlyphBoundRect(aGlyphId, rRect);
} }
bool SvpSalGraphics::GetGlyphOutline( sal_GlyphId aGlyphId, basegfx::B2DPolyPolygon& rPolyPoly ) bool SvpSalGraphics::GetGlyphOutline( sal_GlyphId aGlyphId, basegfx::B2DPolyPolygon& rPolyPoly )
{ {
return m_xTextRenderImpl->GetGlyphOutline(aGlyphId, rPolyPoly); return m_aTextRenderImpl.GetGlyphOutline(aGlyphId, rPolyPoly);
} }
SalLayout* SvpSalGraphics::GetTextLayout( ImplLayoutArgs& rArgs, int nFallbackLevel ) SalLayout* SvpSalGraphics::GetTextLayout( ImplLayoutArgs& rArgs, int nFallbackLevel )
{ {
return m_xTextRenderImpl->GetTextLayout(rArgs, nFallbackLevel); return m_aTextRenderImpl.GetTextLayout(rArgs, nFallbackLevel);
} }
void SvpSalGraphics::DrawServerFontLayout( const ServerFontLayout& rSalLayout ) void SvpSalGraphics::DrawServerFontLayout( const ServerFontLayout& rSalLayout )
{ {
m_xTextRenderImpl->DrawServerFontLayout(rSalLayout ); m_aTextRenderImpl.DrawServerFontLayout(rSalLayout );
} }
void SvpSalGraphics::SetTextColor( SalColor nSalColor ) void SvpSalGraphics::SetTextColor( SalColor nSalColor )
{ {
m_xTextRenderImpl->SetTextColor(nSalColor); m_aTextRenderImpl.SetTextColor(nSalColor);
} }
#if ENABLE_CAIRO_CANVAS #if ENABLE_CAIRO_CANVAS
SystemFontData SvpSalGraphics::GetSysFontData( int nFallbacklevel ) const SystemFontData SvpSalGraphics::GetSysFontData( int nFallbacklevel ) const
{ {
return m_xTextRenderImpl->GetSysFontData(nFallbacklevel); return m_aTextRenderImpl.GetSysFontData(nFallbacklevel);
} }
#endif // ENABLE_CAIRO_CANVAS #endif // ENABLE_CAIRO_CANVAS
......
...@@ -28,7 +28,7 @@ ...@@ -28,7 +28,7 @@
#include "salgdi.hxx" #include "salgdi.hxx"
#include "sallayout.hxx" #include "sallayout.hxx"
#include "textrender.hxx" #include "svpcairotextrender.hxx"
#ifdef IOS #ifdef IOS
#define SvpSalGraphics AquaSalGraphics #define SvpSalGraphics AquaSalGraphics
...@@ -79,7 +79,7 @@ private: ...@@ -79,7 +79,7 @@ private:
protected: protected:
vcl::Region m_aClipRegion; vcl::Region m_aClipRegion;
std::unique_ptr<TextRenderImpl> m_xTextRenderImpl; SvpCairoTextRender m_aTextRenderImpl;
protected: protected:
virtual bool blendBitmap( const SalTwoRect&, const SalBitmap& rBitmap ) override; virtual bool blendBitmap( const SalTwoRect&, const SalBitmap& rBitmap ) override;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment