xref: /AOO41X/main/vcl/unx/headless/svppspgraphics.cxx (revision 9f62ea84a806e17e6f2bbff75724a7257a0eb5d9)
1*9f62ea84SAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3*9f62ea84SAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4*9f62ea84SAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5*9f62ea84SAndrew Rist  * distributed with this work for additional information
6*9f62ea84SAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7*9f62ea84SAndrew Rist  * to you under the Apache License, Version 2.0 (the
8*9f62ea84SAndrew Rist  * "License"); you may not use this file except in compliance
9*9f62ea84SAndrew Rist  * with the License.  You may obtain a copy of the License at
10cdf0e10cSrcweir  *
11*9f62ea84SAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12cdf0e10cSrcweir  *
13*9f62ea84SAndrew Rist  * Unless required by applicable law or agreed to in writing,
14*9f62ea84SAndrew Rist  * software distributed under the License is distributed on an
15*9f62ea84SAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*9f62ea84SAndrew Rist  * KIND, either express or implied.  See the License for the
17*9f62ea84SAndrew Rist  * specific language governing permissions and limitations
18*9f62ea84SAndrew Rist  * under the License.
19cdf0e10cSrcweir  *
20*9f62ea84SAndrew Rist  *************************************************************/
21*9f62ea84SAndrew Rist 
22*9f62ea84SAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
25cdf0e10cSrcweir #include "precompiled_vcl.hxx"
26cdf0e10cSrcweir 
27cdf0e10cSrcweir #include <stdlib.h>
28cdf0e10cSrcweir #include <unistd.h>
29cdf0e10cSrcweir #include <fcntl.h>
30cdf0e10cSrcweir #include <sys/mman.h>
31cdf0e10cSrcweir #include <sys/stat.h>
32cdf0e10cSrcweir #include <sys/types.h>
33cdf0e10cSrcweir 
34cdf0e10cSrcweir #include "basegfx/vector/b2ivector.hxx"
35cdf0e10cSrcweir #include "basegfx/point/b2ipoint.hxx"
36cdf0e10cSrcweir 
37cdf0e10cSrcweir #include "basebmp/color.hxx"
38cdf0e10cSrcweir 
39cdf0e10cSrcweir #include "vcl/jobdata.hxx"
40cdf0e10cSrcweir #include "vcl/printerinfomanager.hxx"
41cdf0e10cSrcweir #include "vcl/bmpacc.hxx"
42cdf0e10cSrcweir #include "vcl/svapp.hxx"
43cdf0e10cSrcweir #include "vcl/sysdata.hxx"
44cdf0e10cSrcweir 
45cdf0e10cSrcweir #include "salprn.hxx"
46cdf0e10cSrcweir #include "salbmp.hxx"
47cdf0e10cSrcweir #include "glyphcache.hxx"
48cdf0e10cSrcweir #include "impfont.hxx"
49cdf0e10cSrcweir #include "outfont.hxx"
50cdf0e10cSrcweir #include "fontsubset.hxx"
51cdf0e10cSrcweir #include "printergfx.hxx"
52cdf0e10cSrcweir #include "svppspgraphics.hxx"
53cdf0e10cSrcweir #include "svpbmp.hxx"
54cdf0e10cSrcweir #include "region.h"
55cdf0e10cSrcweir 
56cdf0e10cSrcweir using namespace psp;
57cdf0e10cSrcweir using namespace rtl;
58cdf0e10cSrcweir using namespace basebmp;
59cdf0e10cSrcweir using namespace basegfx;
60cdf0e10cSrcweir 
61cdf0e10cSrcweir // ----- Implementation of PrinterBmp by means of SalBitmap/BitmapBuffer ---------------
62cdf0e10cSrcweir 
63cdf0e10cSrcweir class SalPrinterBmp : public psp::PrinterBmp
64cdf0e10cSrcweir {
65cdf0e10cSrcweir 	private:
66cdf0e10cSrcweir     SalPrinterBmp ();
67cdf0e10cSrcweir 
68cdf0e10cSrcweir     BitmapDeviceSharedPtr       m_aBitmap;
69cdf0e10cSrcweir 	public:
70cdf0e10cSrcweir 
71cdf0e10cSrcweir 							SalPrinterBmp (const BitmapDeviceSharedPtr& rDevice);
72cdf0e10cSrcweir 		virtual				~SalPrinterBmp ();
73cdf0e10cSrcweir 		virtual sal_uInt32	GetPaletteColor (sal_uInt32 nIdx) const;
74cdf0e10cSrcweir 		virtual sal_uInt32	GetPaletteEntryCount () const;
75cdf0e10cSrcweir 		virtual sal_uInt32	GetPixelRGB  (sal_uInt32 nRow, sal_uInt32 nColumn) const;
76cdf0e10cSrcweir 		virtual sal_uInt8	GetPixelGray (sal_uInt32 nRow, sal_uInt32 nColumn) const;
77cdf0e10cSrcweir 		virtual sal_uInt8	GetPixelIdx  (sal_uInt32 nRow, sal_uInt32 nColumn) const;
78cdf0e10cSrcweir 		virtual sal_uInt32	GetWidth () const;
79cdf0e10cSrcweir 		virtual sal_uInt32	GetHeight() const;
80cdf0e10cSrcweir 		virtual sal_uInt32	GetDepth ()	const;
81cdf0e10cSrcweir 
82cdf0e10cSrcweir         static sal_uInt32 getRGBFromColor( const basebmp::Color& rCol )
83cdf0e10cSrcweir         {
84cdf0e10cSrcweir             return 	  ((rCol.getBlue()) 		 & 0x000000ff)
85cdf0e10cSrcweir                     | ((rCol.getGreen() <<  8) & 0x0000ff00)
86cdf0e10cSrcweir                     | ((rCol.getRed()   << 16) & 0x00ff0000);
87cdf0e10cSrcweir         }
88cdf0e10cSrcweir };
89cdf0e10cSrcweir 
90cdf0e10cSrcweir SalPrinterBmp::SalPrinterBmp(const BitmapDeviceSharedPtr& rDevice) :
91cdf0e10cSrcweir     m_aBitmap( rDevice )
92cdf0e10cSrcweir {
93cdf0e10cSrcweir }
94cdf0e10cSrcweir 
95cdf0e10cSrcweir SalPrinterBmp::~SalPrinterBmp ()
96cdf0e10cSrcweir {
97cdf0e10cSrcweir }
98cdf0e10cSrcweir 
99cdf0e10cSrcweir sal_uInt32
100cdf0e10cSrcweir SalPrinterBmp::GetWidth () const
101cdf0e10cSrcweir {
102cdf0e10cSrcweir     return m_aBitmap.get() ? m_aBitmap->getSize().getX() : 0;
103cdf0e10cSrcweir }
104cdf0e10cSrcweir 
105cdf0e10cSrcweir sal_uInt32
106cdf0e10cSrcweir SalPrinterBmp::GetHeight () const
107cdf0e10cSrcweir {
108cdf0e10cSrcweir     return m_aBitmap.get() ? m_aBitmap->getSize().getY() : 0;
109cdf0e10cSrcweir }
110cdf0e10cSrcweir 
111cdf0e10cSrcweir sal_uInt32
112cdf0e10cSrcweir SalPrinterBmp::GetDepth () const
113cdf0e10cSrcweir {
114cdf0e10cSrcweir     return m_aBitmap.get() ?
115cdf0e10cSrcweir            SvpElement::getBitCountFromScanlineFormat( m_aBitmap->getScanlineFormat() )
116cdf0e10cSrcweir            : 0;
117cdf0e10cSrcweir }
118cdf0e10cSrcweir 
119cdf0e10cSrcweir 
120cdf0e10cSrcweir sal_uInt32
121cdf0e10cSrcweir SalPrinterBmp::GetPaletteEntryCount () const
122cdf0e10cSrcweir {
123cdf0e10cSrcweir     return m_aBitmap.get() ? m_aBitmap->getPaletteEntryCount() : 0;
124cdf0e10cSrcweir }
125cdf0e10cSrcweir 
126cdf0e10cSrcweir sal_uInt32
127cdf0e10cSrcweir SalPrinterBmp::GetPaletteColor (sal_uInt32 nIdx) const
128cdf0e10cSrcweir {
129cdf0e10cSrcweir     sal_uInt32 nCol = 0;
130cdf0e10cSrcweir     if( m_aBitmap.get() && nIdx < static_cast<sal_uInt32>(m_aBitmap->getPaletteEntryCount()) )
131cdf0e10cSrcweir     {
132cdf0e10cSrcweir         const basebmp::Color& rColor = (*m_aBitmap->getPalette().get())[ nIdx ];
133cdf0e10cSrcweir         nCol = getRGBFromColor( rColor );
134cdf0e10cSrcweir     }
135cdf0e10cSrcweir     return nCol;
136cdf0e10cSrcweir }
137cdf0e10cSrcweir 
138cdf0e10cSrcweir sal_uInt32
139cdf0e10cSrcweir SalPrinterBmp::GetPixelRGB (sal_uInt32 nRow, sal_uInt32 nColumn) const
140cdf0e10cSrcweir {
141cdf0e10cSrcweir     sal_uInt32 nCol = 0;
142cdf0e10cSrcweir     if( m_aBitmap.get() )
143cdf0e10cSrcweir         nCol = getRGBFromColor( m_aBitmap->getPixel( B2IPoint( nColumn, nRow ) ) );
144cdf0e10cSrcweir     return nCol;
145cdf0e10cSrcweir }
146cdf0e10cSrcweir 
147cdf0e10cSrcweir sal_uInt8
148cdf0e10cSrcweir SalPrinterBmp::GetPixelGray (sal_uInt32 nRow, sal_uInt32 nColumn) const
149cdf0e10cSrcweir {
150cdf0e10cSrcweir     sal_uInt8 nGray = 0;
151cdf0e10cSrcweir     if( m_aBitmap.get() )
152cdf0e10cSrcweir     {
153cdf0e10cSrcweir         // TODO: don't use tools color
154cdf0e10cSrcweir         basebmp::Color aCol = m_aBitmap->getPixel( B2IPoint( nColumn, nRow ) );
155cdf0e10cSrcweir         ::Color aColor( aCol.getRed(), aCol.getGreen(), aCol.getBlue() );
156cdf0e10cSrcweir         nGray = aColor.GetLuminance();
157cdf0e10cSrcweir     }
158cdf0e10cSrcweir     return nGray;
159cdf0e10cSrcweir }
160cdf0e10cSrcweir 
161cdf0e10cSrcweir sal_uInt8
162cdf0e10cSrcweir SalPrinterBmp::GetPixelIdx (sal_uInt32 nRow, sal_uInt32 nColumn) const
163cdf0e10cSrcweir {
164cdf0e10cSrcweir     sal_uInt8 nIdx = 0;
165cdf0e10cSrcweir     if( m_aBitmap.get() )
166cdf0e10cSrcweir         nIdx = static_cast<sal_uInt8>(m_aBitmap->getPixelData( B2IPoint( nColumn, nRow ) ));
167cdf0e10cSrcweir     return nIdx;
168cdf0e10cSrcweir }
169cdf0e10cSrcweir 
170cdf0e10cSrcweir /*******************************************************
171cdf0e10cSrcweir  * PspGraphics                                         *
172cdf0e10cSrcweir  *******************************************************/
173cdf0e10cSrcweir 
174cdf0e10cSrcweir bool PspGraphics::drawAlphaBitmap( const SalTwoRect&, const SalBitmap& /*rSourceBitmap*/, const SalBitmap& /*rAlphaBitmap*/ )
175cdf0e10cSrcweir {
176cdf0e10cSrcweir 	return false;
177cdf0e10cSrcweir }
178cdf0e10cSrcweir 
179cdf0e10cSrcweir bool PspGraphics::drawAlphaRect( long /*nX*/, long /*nY*/, long /*nWidth*/, long /*nHeight*/, sal_uInt8 /*nTransparency*/ )
180cdf0e10cSrcweir {
181cdf0e10cSrcweir 	return false;
182cdf0e10cSrcweir }
183cdf0e10cSrcweir 
184cdf0e10cSrcweir bool PspGraphics::supportsOperation( OutDevSupportType ) const
185cdf0e10cSrcweir {
186cdf0e10cSrcweir     return false;
187cdf0e10cSrcweir }
188cdf0e10cSrcweir 
189cdf0e10cSrcweir PspGraphics::~PspGraphics()
190cdf0e10cSrcweir {
191cdf0e10cSrcweir     ReleaseFonts();
192cdf0e10cSrcweir }
193cdf0e10cSrcweir 
194cdf0e10cSrcweir void PspGraphics::GetResolution( sal_Int32 &rDPIX, sal_Int32 &rDPIY )
195cdf0e10cSrcweir {
196cdf0e10cSrcweir 	if (m_pJobData != NULL)
197cdf0e10cSrcweir 	{
198cdf0e10cSrcweir 		int x = m_pJobData->m_aContext.getRenderResolution();
199cdf0e10cSrcweir 
200cdf0e10cSrcweir 		rDPIX = x;
201cdf0e10cSrcweir 		rDPIY = x;
202cdf0e10cSrcweir 	}
203cdf0e10cSrcweir }
204cdf0e10cSrcweir 
205cdf0e10cSrcweir sal_uInt16 PspGraphics::GetBitCount()
206cdf0e10cSrcweir {
207cdf0e10cSrcweir     return m_pPrinterGfx->GetBitCount();
208cdf0e10cSrcweir }
209cdf0e10cSrcweir 
210cdf0e10cSrcweir long PspGraphics::GetGraphicsWidth() const
211cdf0e10cSrcweir {
212cdf0e10cSrcweir     return 0;
213cdf0e10cSrcweir }
214cdf0e10cSrcweir 
215cdf0e10cSrcweir void PspGraphics::ResetClipRegion()
216cdf0e10cSrcweir {
217cdf0e10cSrcweir     m_pPrinterGfx->ResetClipRegion();
218cdf0e10cSrcweir }
219cdf0e10cSrcweir 
220cdf0e10cSrcweir bool PspGraphics::setClipRegion( const Region& i_rClip )
221cdf0e10cSrcweir {
222cdf0e10cSrcweir     // TODO: support polygonal clipregions here
223cdf0e10cSrcweir     m_pPrinterGfx->BeginSetClipRegion( i_rClip.GetRectCount() );
224cdf0e10cSrcweir 
225cdf0e10cSrcweir     ImplRegionInfo aInfo;
226cdf0e10cSrcweir     long nX, nY, nW, nH;
227cdf0e10cSrcweir     bool bRegionRect = i_rClip.ImplGetFirstRect(aInfo, nX, nY, nW, nH );
228cdf0e10cSrcweir     while( bRegionRect )
229cdf0e10cSrcweir     {
230cdf0e10cSrcweir         if ( nW && nH )
231cdf0e10cSrcweir         {
232cdf0e10cSrcweir             m_pPrinterGfx->UnionClipRegion( nX, nY, nW, nH );
233cdf0e10cSrcweir         }
234cdf0e10cSrcweir         bRegionRect = i_rClip.ImplGetNextRect( aInfo, nX, nY, nW, nH );
235cdf0e10cSrcweir     }
236cdf0e10cSrcweir     m_pPrinterGfx->EndSetClipRegion();
237cdf0e10cSrcweir     return true;
238cdf0e10cSrcweir }
239cdf0e10cSrcweir 
240cdf0e10cSrcweir void PspGraphics::SetLineColor()
241cdf0e10cSrcweir {
242cdf0e10cSrcweir     m_pPrinterGfx->SetLineColor ();
243cdf0e10cSrcweir }
244cdf0e10cSrcweir 
245cdf0e10cSrcweir void PspGraphics::SetLineColor( SalColor nSalColor )
246cdf0e10cSrcweir {
247cdf0e10cSrcweir     psp::PrinterColor aColor (SALCOLOR_RED   (nSalColor),
248cdf0e10cSrcweir                               SALCOLOR_GREEN (nSalColor),
249cdf0e10cSrcweir                               SALCOLOR_BLUE  (nSalColor));
250cdf0e10cSrcweir     m_pPrinterGfx->SetLineColor (aColor);
251cdf0e10cSrcweir }
252cdf0e10cSrcweir 
253cdf0e10cSrcweir void PspGraphics::SetFillColor()
254cdf0e10cSrcweir {
255cdf0e10cSrcweir     m_pPrinterGfx->SetFillColor ();
256cdf0e10cSrcweir }
257cdf0e10cSrcweir 
258cdf0e10cSrcweir void PspGraphics::SetFillColor( SalColor nSalColor )
259cdf0e10cSrcweir {
260cdf0e10cSrcweir     psp::PrinterColor aColor (SALCOLOR_RED   (nSalColor),
261cdf0e10cSrcweir                               SALCOLOR_GREEN (nSalColor),
262cdf0e10cSrcweir                               SALCOLOR_BLUE  (nSalColor));
263cdf0e10cSrcweir     m_pPrinterGfx->SetFillColor (aColor);
264cdf0e10cSrcweir }
265cdf0e10cSrcweir 
266cdf0e10cSrcweir void PspGraphics::SetROPLineColor( SalROPColor )
267cdf0e10cSrcweir {
268cdf0e10cSrcweir     DBG_ASSERT( 0, "Error: PrinterGfx::SetROPLineColor() not implemented" );
269cdf0e10cSrcweir }
270cdf0e10cSrcweir 
271cdf0e10cSrcweir void PspGraphics::SetROPFillColor( SalROPColor )
272cdf0e10cSrcweir {
273cdf0e10cSrcweir     DBG_ASSERT( 0, "Error: PrinterGfx::SetROPFillColor() not implemented" );
274cdf0e10cSrcweir }
275cdf0e10cSrcweir 
276cdf0e10cSrcweir void PspGraphics::SetXORMode( bool bSet, bool )
277cdf0e10cSrcweir {
278cdf0e10cSrcweir     (void)bSet;
279cdf0e10cSrcweir     DBG_ASSERT( !bSet, "Error: PrinterGfx::SetXORMode() not implemented" );
280cdf0e10cSrcweir }
281cdf0e10cSrcweir 
282cdf0e10cSrcweir void PspGraphics::drawPixel( long nX, long nY )
283cdf0e10cSrcweir {
284cdf0e10cSrcweir     m_pPrinterGfx->DrawPixel (Point(nX, nY));
285cdf0e10cSrcweir }
286cdf0e10cSrcweir 
287cdf0e10cSrcweir void PspGraphics::drawPixel( long nX, long nY, SalColor nSalColor )
288cdf0e10cSrcweir {
289cdf0e10cSrcweir     psp::PrinterColor aColor (SALCOLOR_RED   (nSalColor),
290cdf0e10cSrcweir                               SALCOLOR_GREEN (nSalColor),
291cdf0e10cSrcweir                               SALCOLOR_BLUE  (nSalColor));
292cdf0e10cSrcweir     m_pPrinterGfx->DrawPixel (Point(nX, nY), aColor);
293cdf0e10cSrcweir }
294cdf0e10cSrcweir 
295cdf0e10cSrcweir void PspGraphics::drawLine( long nX1, long nY1, long nX2, long nY2 )
296cdf0e10cSrcweir {
297cdf0e10cSrcweir     m_pPrinterGfx->DrawLine (Point(nX1, nY1), Point(nX2, nY2));
298cdf0e10cSrcweir }
299cdf0e10cSrcweir 
300cdf0e10cSrcweir void PspGraphics::drawRect( long nX, long nY, long nDX, long nDY )
301cdf0e10cSrcweir {
302cdf0e10cSrcweir     m_pPrinterGfx->DrawRect (Rectangle(Point(nX, nY), Size(nDX, nDY)));
303cdf0e10cSrcweir }
304cdf0e10cSrcweir 
305cdf0e10cSrcweir void PspGraphics::drawPolyLine( sal_uLong nPoints, const SalPoint *pPtAry )
306cdf0e10cSrcweir {
307cdf0e10cSrcweir     m_pPrinterGfx->DrawPolyLine (nPoints, (Point*)pPtAry);
308cdf0e10cSrcweir }
309cdf0e10cSrcweir 
310cdf0e10cSrcweir void PspGraphics::drawPolygon( sal_uLong nPoints, const SalPoint* pPtAry )
311cdf0e10cSrcweir {
312cdf0e10cSrcweir 	// Point must be equal to SalPoint! see vcl/inc/salgtype.hxx
313cdf0e10cSrcweir     m_pPrinterGfx->DrawPolygon (nPoints, (Point*)pPtAry);
314cdf0e10cSrcweir }
315cdf0e10cSrcweir 
316cdf0e10cSrcweir void PspGraphics::drawPolyPolygon( sal_uInt32			nPoly,
317cdf0e10cSrcweir 								   const sal_uInt32   *pPoints,
318cdf0e10cSrcweir 								   PCONSTSALPOINT  *pPtAry )
319cdf0e10cSrcweir {
320cdf0e10cSrcweir     m_pPrinterGfx->DrawPolyPolygon (nPoly, pPoints, (const Point**)pPtAry);
321cdf0e10cSrcweir }
322cdf0e10cSrcweir 
323cdf0e10cSrcweir bool PspGraphics::drawPolyLine( const ::basegfx::B2DPolygon&, double /*fTransparency*/, const ::basegfx::B2DVector& /*rLineWidths*/, basegfx::B2DLineJoin /*eJoin*/ )
324cdf0e10cSrcweir {
325cdf0e10cSrcweir         // TODO: implement and advertise OutDevSupport_B2DDraw support
326cdf0e10cSrcweir         return false;
327cdf0e10cSrcweir }
328cdf0e10cSrcweir 
329cdf0e10cSrcweir sal_Bool PspGraphics::drawPolyLineBezier( sal_uLong nPoints, const SalPoint* pPtAry, const sal_uInt8* pFlgAry )
330cdf0e10cSrcweir {
331cdf0e10cSrcweir     m_pPrinterGfx->DrawPolyLineBezier (nPoints, (Point*)pPtAry, pFlgAry);
332cdf0e10cSrcweir     return sal_True;
333cdf0e10cSrcweir }
334cdf0e10cSrcweir 
335cdf0e10cSrcweir sal_Bool PspGraphics::drawPolygonBezier( sal_uLong nPoints, const SalPoint* pPtAry, const sal_uInt8* pFlgAry )
336cdf0e10cSrcweir {
337cdf0e10cSrcweir     m_pPrinterGfx->DrawPolygonBezier (nPoints, (Point*)pPtAry, pFlgAry);
338cdf0e10cSrcweir     return sal_True;
339cdf0e10cSrcweir }
340cdf0e10cSrcweir 
341cdf0e10cSrcweir sal_Bool PspGraphics::drawPolyPolygonBezier( sal_uInt32 nPoly,
342cdf0e10cSrcweir                                              const sal_uInt32* pPoints,
343cdf0e10cSrcweir                                              const SalPoint* const* pPtAry,
344cdf0e10cSrcweir                                              const sal_uInt8* const* pFlgAry )
345cdf0e10cSrcweir {
346cdf0e10cSrcweir 	// Point must be equal to SalPoint! see vcl/inc/salgtype.hxx
347cdf0e10cSrcweir     m_pPrinterGfx->DrawPolyPolygonBezier (nPoly, pPoints, (Point**)pPtAry, (sal_uInt8**)pFlgAry);
348cdf0e10cSrcweir     return sal_True;
349cdf0e10cSrcweir }
350cdf0e10cSrcweir 
351cdf0e10cSrcweir bool PspGraphics::drawPolyPolygon( const basegfx::B2DPolyPolygon&, double /*fTransparency*/ )
352cdf0e10cSrcweir {
353cdf0e10cSrcweir     // TODO: implement and advertise OutDevSupport_B2DDraw support
354cdf0e10cSrcweir     return false;
355cdf0e10cSrcweir }
356cdf0e10cSrcweir 
357cdf0e10cSrcweir void PspGraphics::invert( sal_uLong /*nPoints*/,
358cdf0e10cSrcweir                           const SalPoint* /*pPtAry*/,
359cdf0e10cSrcweir                           SalInvert /*nFlags*/ )
360cdf0e10cSrcweir {
361cdf0e10cSrcweir     DBG_ASSERT( 0, "Error: PrinterGfx::Invert() not implemented" );
362cdf0e10cSrcweir }
363cdf0e10cSrcweir sal_Bool PspGraphics::drawEPS( long nX, long nY, long nWidth, long nHeight, void* pPtr, sal_uLong nSize )
364cdf0e10cSrcweir {
365cdf0e10cSrcweir     return m_pPrinterGfx->DrawEPS( Rectangle( Point( nX, nY ), Size( nWidth, nHeight ) ), pPtr, nSize );
366cdf0e10cSrcweir }
367cdf0e10cSrcweir 
368cdf0e10cSrcweir void PspGraphics::copyBits( const SalTwoRect* /*pPosAry*/,
369cdf0e10cSrcweir                             SalGraphics* /*pSSrcGraphics*/ )
370cdf0e10cSrcweir {
371cdf0e10cSrcweir     DBG_ERROR( "Error: PrinterGfx::CopyBits() not implemented" );
372cdf0e10cSrcweir }
373cdf0e10cSrcweir 
374cdf0e10cSrcweir void PspGraphics::copyArea ( long /*nDestX*/,    long /*nDestY*/,
375cdf0e10cSrcweir                              long /*nSrcX*/,     long /*nSrcY*/,
376cdf0e10cSrcweir                              long /*nSrcWidth*/, long /*nSrcHeight*/,
377cdf0e10cSrcweir                              sal_uInt16 /*nFlags*/ )
378cdf0e10cSrcweir {
379cdf0e10cSrcweir     DBG_ERROR( "Error: PrinterGfx::CopyArea() not implemented" );
380cdf0e10cSrcweir }
381cdf0e10cSrcweir 
382cdf0e10cSrcweir void PspGraphics::drawBitmap( const SalTwoRect* pPosAry, const SalBitmap& rSalBitmap )
383cdf0e10cSrcweir {
384cdf0e10cSrcweir     Rectangle aSrc (Point(pPosAry->mnSrcX, pPosAry->mnSrcY),
385cdf0e10cSrcweir                     Size(pPosAry->mnSrcWidth, pPosAry->mnSrcHeight));
386cdf0e10cSrcweir     Rectangle aDst (Point(pPosAry->mnDestX, pPosAry->mnDestY),
387cdf0e10cSrcweir                     Size(pPosAry->mnDestWidth, pPosAry->mnDestHeight));
388cdf0e10cSrcweir 
389cdf0e10cSrcweir     const SvpSalBitmap* pBmp = dynamic_cast<const SvpSalBitmap*>(&rSalBitmap);
390cdf0e10cSrcweir     if( pBmp )
391cdf0e10cSrcweir     {
392cdf0e10cSrcweir         SalPrinterBmp aBmp(pBmp->getBitmap());
393cdf0e10cSrcweir         m_pPrinterGfx->DrawBitmap(aDst, aSrc, aBmp);
394cdf0e10cSrcweir     }
395cdf0e10cSrcweir }
396cdf0e10cSrcweir 
397cdf0e10cSrcweir void PspGraphics::drawBitmap( const SalTwoRect* /*pPosAry*/,
398cdf0e10cSrcweir                               const SalBitmap& /*rSalBitmap*/,
399cdf0e10cSrcweir                               const SalBitmap& /*rTransBitmap*/ )
400cdf0e10cSrcweir {
401cdf0e10cSrcweir     DBG_ERROR("Error: no PrinterGfx::DrawBitmap() for transparent bitmap");
402cdf0e10cSrcweir }
403cdf0e10cSrcweir 
404cdf0e10cSrcweir void PspGraphics::drawBitmap( const SalTwoRect* /*pPosAry*/,
405cdf0e10cSrcweir                               const SalBitmap& /*rSalBitmap*/,
406cdf0e10cSrcweir                               SalColor /*nTransparentColor*/ )
407cdf0e10cSrcweir {
408cdf0e10cSrcweir     DBG_ERROR("Error: no PrinterGfx::DrawBitmap() for transparent color");
409cdf0e10cSrcweir }
410cdf0e10cSrcweir 
411cdf0e10cSrcweir void PspGraphics::drawMask( const SalTwoRect* /*pPosAry*/,
412cdf0e10cSrcweir                             const SalBitmap& /*rSalBitmap*/,
413cdf0e10cSrcweir                             SalColor /*nMaskColor*/ )
414cdf0e10cSrcweir {
415cdf0e10cSrcweir     DBG_ERROR("Error: PrinterGfx::DrawMask() not implemented");
416cdf0e10cSrcweir }
417cdf0e10cSrcweir 
418cdf0e10cSrcweir SalBitmap* PspGraphics::getBitmap( long /*nX*/, long /*nY*/, long /*nDX*/, long /*nDY*/ )
419cdf0e10cSrcweir {
420cdf0e10cSrcweir     DBG_WARNING ("Warning: PrinterGfx::GetBitmap() not implemented");
421cdf0e10cSrcweir     return NULL;
422cdf0e10cSrcweir }
423cdf0e10cSrcweir 
424cdf0e10cSrcweir SalColor PspGraphics::getPixel( long /*nX*/, long /*nY*/ )
425cdf0e10cSrcweir {
426cdf0e10cSrcweir     DBG_ERROR ("Warning: PrinterGfx::GetPixel() not implemented");
427cdf0e10cSrcweir     return 0;
428cdf0e10cSrcweir }
429cdf0e10cSrcweir 
430cdf0e10cSrcweir void PspGraphics::invert(
431cdf0e10cSrcweir                          long		/*nX*/,
432cdf0e10cSrcweir                          long		/*nY*/,
433cdf0e10cSrcweir                          long		/*nDX*/,
434cdf0e10cSrcweir                          long		/*nDY*/,
435cdf0e10cSrcweir                          SalInvert	/*nFlags*/ )
436cdf0e10cSrcweir {
437cdf0e10cSrcweir     DBG_ERROR ("Warning: PrinterGfx::Invert() not implemented");
438cdf0e10cSrcweir }
439cdf0e10cSrcweir 
440cdf0e10cSrcweir //==========================================================================
441cdf0e10cSrcweir 
442cdf0e10cSrcweir class ImplPspFontData : public ImplFontData
443cdf0e10cSrcweir {
444cdf0e10cSrcweir private:
445cdf0e10cSrcweir     enum { PSPFD_MAGIC = 0xb5bf01f0 };
446cdf0e10cSrcweir     sal_IntPtr              mnFontId;
447cdf0e10cSrcweir 
448cdf0e10cSrcweir public:
449cdf0e10cSrcweir                             ImplPspFontData( const psp::FastPrintFontInfo& );
450cdf0e10cSrcweir     virtual sal_IntPtr      GetFontId() const { return mnFontId; }
451cdf0e10cSrcweir     virtual ImplFontData*   Clone() const { return new ImplPspFontData( *this ); }
452cdf0e10cSrcweir     virtual ImplFontEntry*  CreateFontInstance( ImplFontSelectData& ) const;
453cdf0e10cSrcweir     static bool             CheckFontData( const ImplFontData& r ) { return r.CheckMagic( PSPFD_MAGIC ); }
454cdf0e10cSrcweir };
455cdf0e10cSrcweir 
456cdf0e10cSrcweir //--------------------------------------------------------------------------
457cdf0e10cSrcweir 
458cdf0e10cSrcweir ImplPspFontData::ImplPspFontData( const psp::FastPrintFontInfo& rInfo )
459cdf0e10cSrcweir :   ImplFontData( PspGraphics::Info2DevFontAttributes(rInfo), PSPFD_MAGIC ),
460cdf0e10cSrcweir     mnFontId( rInfo.m_nID )
461cdf0e10cSrcweir {}
462cdf0e10cSrcweir 
463cdf0e10cSrcweir //--------------------------------------------------------------------------
464cdf0e10cSrcweir 
465cdf0e10cSrcweir ImplFontEntry* ImplPspFontData::CreateFontInstance( ImplFontSelectData& rFSD ) const
466cdf0e10cSrcweir {
467cdf0e10cSrcweir     ImplServerFontEntry* pEntry = new ImplServerFontEntry( rFSD );
468cdf0e10cSrcweir     return pEntry;
469cdf0e10cSrcweir }
470cdf0e10cSrcweir 
471cdf0e10cSrcweir //==========================================================================
472cdf0e10cSrcweir 
473cdf0e10cSrcweir class PspFontLayout : public GenericSalLayout
474cdf0e10cSrcweir {
475cdf0e10cSrcweir public:
476cdf0e10cSrcweir                         PspFontLayout( ::psp::PrinterGfx& );
477cdf0e10cSrcweir     virtual bool        LayoutText( ImplLayoutArgs& );
478cdf0e10cSrcweir     virtual void        InitFont() const;
479cdf0e10cSrcweir     virtual void        DrawText( SalGraphics& ) const;
480cdf0e10cSrcweir private:
481cdf0e10cSrcweir     ::psp::PrinterGfx&  mrPrinterGfx;
482cdf0e10cSrcweir     sal_IntPtr          mnFontID;
483cdf0e10cSrcweir     int                 mnFontHeight;
484cdf0e10cSrcweir     int                 mnFontWidth;
485cdf0e10cSrcweir     bool                mbVertical;
486cdf0e10cSrcweir     bool                mbArtItalic;
487cdf0e10cSrcweir     bool                mbArtBold;
488cdf0e10cSrcweir };
489cdf0e10cSrcweir 
490cdf0e10cSrcweir //--------------------------------------------------------------------------
491cdf0e10cSrcweir 
492cdf0e10cSrcweir PspFontLayout::PspFontLayout( ::psp::PrinterGfx& rGfx )
493cdf0e10cSrcweir :   mrPrinterGfx( rGfx )
494cdf0e10cSrcweir {
495cdf0e10cSrcweir     mnFontID     = mrPrinterGfx.GetFontID();
496cdf0e10cSrcweir     mnFontHeight = mrPrinterGfx.GetFontHeight();
497cdf0e10cSrcweir     mnFontWidth  = mrPrinterGfx.GetFontWidth();
498cdf0e10cSrcweir     mbVertical   = mrPrinterGfx.GetFontVertical();
499cdf0e10cSrcweir     mbArtItalic	 = mrPrinterGfx.GetArtificialItalic();
500cdf0e10cSrcweir     mbArtBold	 = mrPrinterGfx.GetArtificialBold();
501cdf0e10cSrcweir }
502cdf0e10cSrcweir 
503cdf0e10cSrcweir //--------------------------------------------------------------------------
504cdf0e10cSrcweir 
505cdf0e10cSrcweir bool PspFontLayout::LayoutText( ImplLayoutArgs& rArgs )
506cdf0e10cSrcweir {
507cdf0e10cSrcweir     mbVertical = ((rArgs.mnFlags & SAL_LAYOUT_VERTICAL) != 0);
508cdf0e10cSrcweir 
509cdf0e10cSrcweir     long nUnitsPerPixel = 1;
510cdf0e10cSrcweir     int nOldGlyphId = -1;
511cdf0e10cSrcweir     long nGlyphWidth = 0;
512cdf0e10cSrcweir     int nCharPos = -1;
513cdf0e10cSrcweir     Point aNewPos( 0, 0 );
514cdf0e10cSrcweir     GlyphItem aPrevItem;
515cdf0e10cSrcweir     rtl_TextEncoding aFontEnc = mrPrinterGfx.GetFontMgr().getFontEncoding( mnFontID );
516cdf0e10cSrcweir     for(;;)
517cdf0e10cSrcweir     {
518cdf0e10cSrcweir         bool bRightToLeft;
519cdf0e10cSrcweir         if( !rArgs.GetNextPos( &nCharPos, &bRightToLeft ) )
520cdf0e10cSrcweir             break;
521cdf0e10cSrcweir 
522cdf0e10cSrcweir         sal_UCS4 cChar = rArgs.mpStr[ nCharPos ];
523cdf0e10cSrcweir         if( bRightToLeft )
524cdf0e10cSrcweir             cChar = GetMirroredChar( cChar );
525cdf0e10cSrcweir         // symbol font aliasing: 0x0020-0x00ff -> 0xf020 -> 0xf0ff
526cdf0e10cSrcweir         if( aFontEnc == RTL_TEXTENCODING_SYMBOL )
527cdf0e10cSrcweir             if( cChar < 256 )
528cdf0e10cSrcweir                 cChar += 0xf000;
529cdf0e10cSrcweir         int nGlyphIndex = cChar;  // printer glyphs = unicode
530cdf0e10cSrcweir 
531cdf0e10cSrcweir         // update fallback_runs if needed
532cdf0e10cSrcweir         psp::CharacterMetric aMetric;
533cdf0e10cSrcweir         mrPrinterGfx.GetFontMgr().getMetrics( mnFontID, cChar, cChar, &aMetric, mbVertical );
534cdf0e10cSrcweir         if( aMetric.width == -1 && aMetric.height == -1 )
535cdf0e10cSrcweir             rArgs.NeedFallback( nCharPos, bRightToLeft );
536cdf0e10cSrcweir 
537cdf0e10cSrcweir         // apply pair kerning to prev glyph if requested
538cdf0e10cSrcweir         if( SAL_LAYOUT_KERNING_PAIRS & rArgs.mnFlags )
539cdf0e10cSrcweir         {
540cdf0e10cSrcweir             if( nOldGlyphId > 0 )
541cdf0e10cSrcweir             {
542cdf0e10cSrcweir                 const std::list< KernPair >& rKernPairs = mrPrinterGfx.getKernPairs(mbVertical);
543cdf0e10cSrcweir                 for( std::list< KernPair >::const_iterator it = rKernPairs.begin();
544cdf0e10cSrcweir                      it != rKernPairs.end(); ++it )
545cdf0e10cSrcweir                 {
546cdf0e10cSrcweir                     if( it->first == nOldGlyphId && it->second == nGlyphIndex )
547cdf0e10cSrcweir                     {
548cdf0e10cSrcweir                         int nTextScale = mrPrinterGfx.GetFontWidth();
549cdf0e10cSrcweir                         if( ! nTextScale )
550cdf0e10cSrcweir                             nTextScale = mrPrinterGfx.GetFontHeight();
551cdf0e10cSrcweir                         int nKern = (mbVertical ? it->kern_y : it->kern_x) * nTextScale;
552cdf0e10cSrcweir                         nGlyphWidth += nKern;
553cdf0e10cSrcweir                         aPrevItem.mnNewWidth = nGlyphWidth;
554cdf0e10cSrcweir                         break;
555cdf0e10cSrcweir                     }
556cdf0e10cSrcweir                 }
557cdf0e10cSrcweir             }
558cdf0e10cSrcweir         }
559cdf0e10cSrcweir 
560cdf0e10cSrcweir         // finish previous glyph
561cdf0e10cSrcweir         if( nOldGlyphId >= 0 )
562cdf0e10cSrcweir             AppendGlyph( aPrevItem );
563cdf0e10cSrcweir         nOldGlyphId = nGlyphIndex;
564cdf0e10cSrcweir         aNewPos.X() += nGlyphWidth;
565cdf0e10cSrcweir 
566cdf0e10cSrcweir         // prepare GlyphItem for appending it in next round
567cdf0e10cSrcweir         nUnitsPerPixel = mrPrinterGfx.GetCharWidth( cChar, cChar, &nGlyphWidth );
568cdf0e10cSrcweir         int nGlyphFlags = bRightToLeft ? GlyphItem::IS_RTL_GLYPH : 0;
569cdf0e10cSrcweir         nGlyphIndex |= GF_ISCHAR;
570cdf0e10cSrcweir         aPrevItem = GlyphItem( nCharPos, nGlyphIndex, aNewPos, nGlyphFlags, nGlyphWidth );
571cdf0e10cSrcweir     }
572cdf0e10cSrcweir 
573cdf0e10cSrcweir     // append last glyph item if any
574cdf0e10cSrcweir     if( nOldGlyphId >= 0 )
575cdf0e10cSrcweir         AppendGlyph( aPrevItem );
576cdf0e10cSrcweir 
577cdf0e10cSrcweir     SetOrientation( mrPrinterGfx.GetFontAngle() );
578cdf0e10cSrcweir     SetUnitsPerPixel( nUnitsPerPixel );
579cdf0e10cSrcweir     return (nOldGlyphId >= 0);
580cdf0e10cSrcweir }
581cdf0e10cSrcweir 
582cdf0e10cSrcweir class PspServerFontLayout : public ServerFontLayout
583cdf0e10cSrcweir {
584cdf0e10cSrcweir public:
585cdf0e10cSrcweir     PspServerFontLayout( psp::PrinterGfx&, ServerFont& rFont, const ImplLayoutArgs& rArgs );
586cdf0e10cSrcweir 
587cdf0e10cSrcweir     virtual void        InitFont() const;
588cdf0e10cSrcweir     const sal_Unicode*	getTextPtr() const { return maText.getStr() - mnMinCharPos; }
589cdf0e10cSrcweir     int					getMinCharPos() const { return mnMinCharPos; }
590cdf0e10cSrcweir     int					getMaxCharPos() const { return mnMinCharPos+maText.getLength()-1; }
591cdf0e10cSrcweir private:
592cdf0e10cSrcweir     ::psp::PrinterGfx&  mrPrinterGfx;
593cdf0e10cSrcweir     sal_IntPtr          mnFontID;
594cdf0e10cSrcweir     int                 mnFontHeight;
595cdf0e10cSrcweir     int                 mnFontWidth;
596cdf0e10cSrcweir     bool                mbVertical;
597cdf0e10cSrcweir     bool				mbArtItalic;
598cdf0e10cSrcweir     bool				mbArtBold;
599cdf0e10cSrcweir     rtl::OUString		maText;
600cdf0e10cSrcweir     int					mnMinCharPos;
601cdf0e10cSrcweir };
602cdf0e10cSrcweir 
603cdf0e10cSrcweir PspServerFontLayout::PspServerFontLayout( ::psp::PrinterGfx& rGfx, ServerFont& rFont, const ImplLayoutArgs& rArgs )
604cdf0e10cSrcweir         :   ServerFontLayout( rFont ),
605cdf0e10cSrcweir             mrPrinterGfx( rGfx )
606cdf0e10cSrcweir {
607cdf0e10cSrcweir     mnFontID     = mrPrinterGfx.GetFontID();
608cdf0e10cSrcweir     mnFontHeight = mrPrinterGfx.GetFontHeight();
609cdf0e10cSrcweir     mnFontWidth  = mrPrinterGfx.GetFontWidth();
610cdf0e10cSrcweir     mbVertical   = mrPrinterGfx.GetFontVertical();
611cdf0e10cSrcweir     mbArtItalic	 = mrPrinterGfx.GetArtificialItalic();
612cdf0e10cSrcweir     mbArtBold	 = mrPrinterGfx.GetArtificialBold();
613cdf0e10cSrcweir     maText		 = OUString( rArgs.mpStr + rArgs.mnMinCharPos, rArgs.mnEndCharPos - rArgs.mnMinCharPos+1 );
614cdf0e10cSrcweir     mnMinCharPos = rArgs.mnMinCharPos;
615cdf0e10cSrcweir }
616cdf0e10cSrcweir 
617cdf0e10cSrcweir void PspServerFontLayout::InitFont() const
618cdf0e10cSrcweir {
619cdf0e10cSrcweir     mrPrinterGfx.SetFont( mnFontID, mnFontHeight, mnFontWidth,
620cdf0e10cSrcweir                           mnOrientation, mbVertical, mbArtItalic, mbArtBold );
621cdf0e10cSrcweir }
622cdf0e10cSrcweir 
623cdf0e10cSrcweir //--------------------------------------------------------------------------
624cdf0e10cSrcweir 
625cdf0e10cSrcweir static void DrawPrinterLayout( const SalLayout& rLayout, ::psp::PrinterGfx& rGfx, bool bIsPspServerFontLayout )
626cdf0e10cSrcweir {
627cdf0e10cSrcweir     const int nMaxGlyphs = 200;
628cdf0e10cSrcweir     sal_GlyphId aGlyphAry[ nMaxGlyphs ];
629cdf0e10cSrcweir     sal_Int32   aWidthAry[ nMaxGlyphs ];
630cdf0e10cSrcweir     sal_Int32   aIdxAry  [ nMaxGlyphs ];
631cdf0e10cSrcweir     sal_Ucs     aUnicodes[ nMaxGlyphs ];
632cdf0e10cSrcweir     int			aCharPosAry	[ nMaxGlyphs ];
633cdf0e10cSrcweir 
634cdf0e10cSrcweir     Point aPos;
635cdf0e10cSrcweir     long nUnitsPerPixel = rLayout.GetUnitsPerPixel();
636cdf0e10cSrcweir     const sal_Unicode* pText = bIsPspServerFontLayout ? static_cast<const PspServerFontLayout&>(rLayout).getTextPtr() : NULL;
637cdf0e10cSrcweir     int nMinCharPos = bIsPspServerFontLayout ? static_cast<const PspServerFontLayout&>(rLayout).getMinCharPos() : 0;
638cdf0e10cSrcweir     int nMaxCharPos = bIsPspServerFontLayout ? static_cast<const PspServerFontLayout&>(rLayout).getMaxCharPos() : 0;
639cdf0e10cSrcweir     for( int nStart = 0;; )
640cdf0e10cSrcweir     {
641cdf0e10cSrcweir         int nGlyphCount = rLayout.GetNextGlyphs( nMaxGlyphs, aGlyphAry, aPos, nStart, aWidthAry, bIsPspServerFontLayout ? aCharPosAry : NULL );
642cdf0e10cSrcweir         if( !nGlyphCount )
643cdf0e10cSrcweir             break;
644cdf0e10cSrcweir 
645cdf0e10cSrcweir         sal_Int32 nXOffset = 0;
646cdf0e10cSrcweir         for( int i = 0; i < nGlyphCount; ++i )
647cdf0e10cSrcweir         {
648cdf0e10cSrcweir             nXOffset += aWidthAry[ i ];
649cdf0e10cSrcweir             aIdxAry[ i ] = nXOffset / nUnitsPerPixel;
650cdf0e10cSrcweir             sal_Int32 nGlyphIdx = aGlyphAry[i] & (GF_IDXMASK | GF_ROTMASK);
651cdf0e10cSrcweir             if( bIsPspServerFontLayout )
652cdf0e10cSrcweir                 aUnicodes[i] = (aCharPosAry[i] >= nMinCharPos && aCharPosAry[i] <= nMaxCharPos) ? pText[ aCharPosAry[i] ] : 0;
653cdf0e10cSrcweir             else
654cdf0e10cSrcweir                 aUnicodes[i] = (aGlyphAry[i] & GF_ISCHAR) ? nGlyphIdx : 0;
655cdf0e10cSrcweir             aGlyphAry[i] = nGlyphIdx;
656cdf0e10cSrcweir         }
657cdf0e10cSrcweir 
658cdf0e10cSrcweir         rGfx.DrawGlyphs( aPos, (sal_uInt32 *)aGlyphAry, aUnicodes, nGlyphCount, aIdxAry );
659cdf0e10cSrcweir     }
660cdf0e10cSrcweir }
661cdf0e10cSrcweir 
662cdf0e10cSrcweir //--------------------------------------------------------------------------
663cdf0e10cSrcweir 
664cdf0e10cSrcweir void PspFontLayout::InitFont() const
665cdf0e10cSrcweir {
666cdf0e10cSrcweir     mrPrinterGfx.SetFont( mnFontID, mnFontHeight, mnFontWidth,
667cdf0e10cSrcweir         mnOrientation, mbVertical, mbArtItalic, mbArtBold );
668cdf0e10cSrcweir }
669cdf0e10cSrcweir 
670cdf0e10cSrcweir //--------------------------------------------------------------------------
671cdf0e10cSrcweir 
672cdf0e10cSrcweir void PspFontLayout::DrawText( SalGraphics& ) const
673cdf0e10cSrcweir {
674cdf0e10cSrcweir     DrawPrinterLayout( *this, mrPrinterGfx, false );
675cdf0e10cSrcweir }
676cdf0e10cSrcweir 
677cdf0e10cSrcweir void PspGraphics::DrawServerFontLayout( const ServerFontLayout& rLayout )
678cdf0e10cSrcweir {
679cdf0e10cSrcweir     // print complex text
680cdf0e10cSrcweir     DrawPrinterLayout( rLayout, *m_pPrinterGfx, true );
681cdf0e10cSrcweir }
682cdf0e10cSrcweir 
683cdf0e10cSrcweir const ImplFontCharMap* PspGraphics::GetImplFontCharMap() const
684cdf0e10cSrcweir {
685cdf0e10cSrcweir     if( !m_pServerFont[0] )
686cdf0e10cSrcweir         return NULL;
687cdf0e10cSrcweir 
688cdf0e10cSrcweir     const ImplFontCharMap* pIFCMap = m_pServerFont[0]->GetImplFontCharMap();
689cdf0e10cSrcweir     return pIFCMap;
690cdf0e10cSrcweir }
691cdf0e10cSrcweir 
692cdf0e10cSrcweir sal_uInt16 PspGraphics::SetFont( ImplFontSelectData *pEntry, int nFallbackLevel )
693cdf0e10cSrcweir {
694cdf0e10cSrcweir     // release all fonts that are to be overridden
695cdf0e10cSrcweir     for( int i = nFallbackLevel; i < MAX_FALLBACK; ++i )
696cdf0e10cSrcweir     {
697cdf0e10cSrcweir         if( m_pServerFont[i] != NULL )
698cdf0e10cSrcweir         {
699cdf0e10cSrcweir             // old server side font is no longer referenced
700cdf0e10cSrcweir             GlyphCache::GetInstance().UncacheFont( *m_pServerFont[i] );
701cdf0e10cSrcweir             m_pServerFont[i] = NULL;
702cdf0e10cSrcweir         }
703cdf0e10cSrcweir     }
704cdf0e10cSrcweir 
705cdf0e10cSrcweir     // return early if there is no new font
706cdf0e10cSrcweir     if( !pEntry )
707cdf0e10cSrcweir         return 0;
708cdf0e10cSrcweir 
709cdf0e10cSrcweir     sal_IntPtr nID = pEntry->mpFontData ? pEntry->mpFontData->GetFontId() : 0;
710cdf0e10cSrcweir 
711cdf0e10cSrcweir     // determine which font attributes need to be emulated
712cdf0e10cSrcweir     bool bArtItalic = false;
713cdf0e10cSrcweir     bool bArtBold = false;
714cdf0e10cSrcweir     if( pEntry->meItalic == ITALIC_OBLIQUE || pEntry->meItalic == ITALIC_NORMAL )
715cdf0e10cSrcweir     {
716cdf0e10cSrcweir         psp::italic::type eItalic = m_pPrinterGfx->GetFontMgr().getFontItalic( nID );
717cdf0e10cSrcweir         if( eItalic != psp::italic::Italic && eItalic != psp::italic::Oblique )
718cdf0e10cSrcweir             bArtItalic = true;
719cdf0e10cSrcweir     }
720cdf0e10cSrcweir     int nWeight = (int)pEntry->meWeight;
721cdf0e10cSrcweir     int nRealWeight = (int)m_pPrinterGfx->GetFontMgr().getFontWeight( nID );
722cdf0e10cSrcweir     if( nRealWeight <= (int)psp::weight::Medium && nWeight > (int)WEIGHT_MEDIUM )
723cdf0e10cSrcweir     {
724cdf0e10cSrcweir         bArtBold = true;
725cdf0e10cSrcweir     }
726cdf0e10cSrcweir 
727cdf0e10cSrcweir     // also set the serverside font for layouting
728cdf0e10cSrcweir     m_bFontVertical = pEntry->mbVertical;
729cdf0e10cSrcweir     if( pEntry->mpFontData )
730cdf0e10cSrcweir     {
731cdf0e10cSrcweir         // requesting a font provided by builtin rasterizer
732cdf0e10cSrcweir         ServerFont* pServerFont = GlyphCache::GetInstance().CacheFont( *pEntry );
733cdf0e10cSrcweir         if( pServerFont != NULL )
734cdf0e10cSrcweir         {
735cdf0e10cSrcweir             if( pServerFont->TestFont() )
736cdf0e10cSrcweir                 m_pServerFont[ nFallbackLevel ] = pServerFont;
737cdf0e10cSrcweir             else
738cdf0e10cSrcweir                 GlyphCache::GetInstance().UncacheFont( *pServerFont );
739cdf0e10cSrcweir         }
740cdf0e10cSrcweir     }
741cdf0e10cSrcweir 
742cdf0e10cSrcweir     // set the printer font
743cdf0e10cSrcweir     return m_pPrinterGfx->SetFont( nID,
744cdf0e10cSrcweir                                    pEntry->mnHeight,
745cdf0e10cSrcweir                                    pEntry->mnWidth,
746cdf0e10cSrcweir                                    pEntry->mnOrientation,
747cdf0e10cSrcweir                                    pEntry->mbVertical,
748cdf0e10cSrcweir                                    bArtItalic,
749cdf0e10cSrcweir                                    bArtBold
750cdf0e10cSrcweir                                    );
751cdf0e10cSrcweir }
752cdf0e10cSrcweir 
753cdf0e10cSrcweir void PspGraphics::SetTextColor( SalColor nSalColor )
754cdf0e10cSrcweir {
755cdf0e10cSrcweir     psp::PrinterColor aColor (SALCOLOR_RED   (nSalColor),
756cdf0e10cSrcweir                               SALCOLOR_GREEN (nSalColor),
757cdf0e10cSrcweir                               SALCOLOR_BLUE  (nSalColor));
758cdf0e10cSrcweir     m_pPrinterGfx->SetTextColor (aColor);
759cdf0e10cSrcweir }
760cdf0e10cSrcweir 
761cdf0e10cSrcweir bool PspGraphics::AddTempDevFont( ImplDevFontList*, const String&, const String& )
762cdf0e10cSrcweir {
763cdf0e10cSrcweir     return false;
764cdf0e10cSrcweir }
765cdf0e10cSrcweir 
766cdf0e10cSrcweir void PspGraphics::GetDevFontList( ImplDevFontList *pList )
767cdf0e10cSrcweir {
768cdf0e10cSrcweir     ::std::list< psp::fontID > aList;
769cdf0e10cSrcweir     psp::PrintFontManager& rMgr = psp::PrintFontManager::get();
770cdf0e10cSrcweir     rMgr.getFontList( aList, m_pJobData->m_pParser, m_pInfoPrinter->m_bCompatMetrics );
771cdf0e10cSrcweir 
772cdf0e10cSrcweir     ::std::list< psp::fontID >::iterator it;
773cdf0e10cSrcweir     psp::FastPrintFontInfo aInfo;
774cdf0e10cSrcweir     for (it = aList.begin(); it != aList.end(); ++it)
775cdf0e10cSrcweir         if (rMgr.getFontFastInfo (*it, aInfo))
776cdf0e10cSrcweir             AnnounceFonts( pList, aInfo );
777cdf0e10cSrcweir }
778cdf0e10cSrcweir 
779cdf0e10cSrcweir void PspGraphics::GetDevFontSubstList( OutputDevice* pOutDev )
780cdf0e10cSrcweir {
781cdf0e10cSrcweir     const psp::PrinterInfo& rInfo = psp::PrinterInfoManager::get().getPrinterInfo( m_pJobData->m_aPrinterName );
782cdf0e10cSrcweir     if( rInfo.m_bPerformFontSubstitution )
783cdf0e10cSrcweir     {
784cdf0e10cSrcweir         for( std::hash_map< rtl::OUString, rtl::OUString, rtl::OUStringHash >::const_iterator it = rInfo.m_aFontSubstitutes.begin(); it != rInfo.m_aFontSubstitutes.end(); ++it )
785cdf0e10cSrcweir             AddDevFontSubstitute( pOutDev, it->first, it->second, FONT_SUBSTITUTE_ALWAYS );
786cdf0e10cSrcweir     }
787cdf0e10cSrcweir }
788cdf0e10cSrcweir 
789cdf0e10cSrcweir void PspGraphics::GetFontMetric( ImplFontMetricData *pMetric, int )
790cdf0e10cSrcweir {
791cdf0e10cSrcweir     const psp::PrintFontManager& rMgr = psp::PrintFontManager::get();
792cdf0e10cSrcweir     psp::PrintFontInfo aInfo;
793cdf0e10cSrcweir 
794cdf0e10cSrcweir     if (rMgr.getFontInfo (m_pPrinterGfx->GetFontID(), aInfo))
795cdf0e10cSrcweir     {
796cdf0e10cSrcweir         ImplDevFontAttributes aDFA = Info2DevFontAttributes( aInfo );
797cdf0e10cSrcweir         static_cast<ImplFontAttributes&>(*pMetric) = aDFA;
798cdf0e10cSrcweir         pMetric->mbDevice       = aDFA.mbDevice;
799cdf0e10cSrcweir         pMetric->mbScalableFont = true;
800cdf0e10cSrcweir 
801cdf0e10cSrcweir         pMetric->mnOrientation 	= m_pPrinterGfx->GetFontAngle();
802cdf0e10cSrcweir         pMetric->mnSlant		= 0;
803cdf0e10cSrcweir 
804cdf0e10cSrcweir         sal_Int32 nTextHeight	= m_pPrinterGfx->GetFontHeight();
805cdf0e10cSrcweir         sal_Int32 nTextWidth	= m_pPrinterGfx->GetFontWidth();
806cdf0e10cSrcweir         if( ! nTextWidth )
807cdf0e10cSrcweir             nTextWidth = nTextHeight;
808cdf0e10cSrcweir 
809cdf0e10cSrcweir         pMetric->mnWidth		= nTextWidth;
810cdf0e10cSrcweir         pMetric->mnAscent		= ( aInfo.m_nAscend * nTextHeight + 500 ) / 1000;
811cdf0e10cSrcweir         pMetric->mnDescent		= ( aInfo.m_nDescend * nTextHeight + 500 ) / 1000;
812cdf0e10cSrcweir         pMetric->mnIntLeading	= ( aInfo.m_nLeading * nTextHeight + 500 ) / 1000;
813cdf0e10cSrcweir         pMetric->mnExtLeading	= 0;
814cdf0e10cSrcweir     }
815cdf0e10cSrcweir }
816cdf0e10cSrcweir 
817cdf0e10cSrcweir sal_uLong PspGraphics::GetKernPairs( sal_uLong nPairs, ImplKernPairData *pKernPairs )
818cdf0e10cSrcweir {
819cdf0e10cSrcweir     const ::std::list< ::psp::KernPair >& rPairs( m_pPrinterGfx->getKernPairs() );
820cdf0e10cSrcweir     sal_uLong nHavePairs = rPairs.size();
821cdf0e10cSrcweir     if( pKernPairs && nPairs )
822cdf0e10cSrcweir     {
823cdf0e10cSrcweir         ::std::list< ::psp::KernPair >::const_iterator it;
824cdf0e10cSrcweir         unsigned int i;
825cdf0e10cSrcweir         int nTextScale = m_pPrinterGfx->GetFontWidth();
826cdf0e10cSrcweir         if( ! nTextScale )
827cdf0e10cSrcweir             nTextScale = m_pPrinterGfx->GetFontHeight();
828cdf0e10cSrcweir         for( i = 0, it = rPairs.begin(); i < nPairs && i < nHavePairs; i++, ++it )
829cdf0e10cSrcweir         {
830cdf0e10cSrcweir             pKernPairs[i].mnChar1	= it->first;
831cdf0e10cSrcweir             pKernPairs[i].mnChar2	= it->second;
832cdf0e10cSrcweir             pKernPairs[i].mnKern	= it->kern_x * nTextScale / 1000;
833cdf0e10cSrcweir         }
834cdf0e10cSrcweir 
835cdf0e10cSrcweir     }
836cdf0e10cSrcweir     return nHavePairs;
837cdf0e10cSrcweir }
838cdf0e10cSrcweir 
839cdf0e10cSrcweir sal_Bool PspGraphics::GetGlyphBoundRect( long nGlyphIndex, Rectangle& rRect )
840cdf0e10cSrcweir {
841cdf0e10cSrcweir     int nLevel = nGlyphIndex >> GF_FONTSHIFT;
842cdf0e10cSrcweir     if( nLevel >= MAX_FALLBACK )
843cdf0e10cSrcweir         return sal_False;
844cdf0e10cSrcweir 
845cdf0e10cSrcweir     ServerFont* pSF = m_pServerFont[ nLevel ];
846cdf0e10cSrcweir     if( !pSF )
847cdf0e10cSrcweir         return sal_False;
848cdf0e10cSrcweir 
849cdf0e10cSrcweir     nGlyphIndex &= ~GF_FONTMASK;
850cdf0e10cSrcweir     const GlyphMetric& rGM = pSF->GetGlyphMetric( nGlyphIndex );
851cdf0e10cSrcweir     rRect = Rectangle( rGM.GetOffset(), rGM.GetSize() );
852cdf0e10cSrcweir     return sal_True;
853cdf0e10cSrcweir }
854cdf0e10cSrcweir 
855cdf0e10cSrcweir sal_Bool PspGraphics::GetGlyphOutline( long nGlyphIndex,
856cdf0e10cSrcweir     ::basegfx::B2DPolyPolygon& rB2DPolyPoly )
857cdf0e10cSrcweir {
858cdf0e10cSrcweir     int nLevel = nGlyphIndex >> GF_FONTSHIFT;
859cdf0e10cSrcweir     if( nLevel >= MAX_FALLBACK )
860cdf0e10cSrcweir         return sal_False;
861cdf0e10cSrcweir 
862cdf0e10cSrcweir     ServerFont* pSF = m_pServerFont[ nLevel ];
863cdf0e10cSrcweir     if( !pSF )
864cdf0e10cSrcweir         return sal_False;
865cdf0e10cSrcweir 
866cdf0e10cSrcweir     nGlyphIndex &= ~GF_FONTMASK;
867cdf0e10cSrcweir     if( pSF->GetGlyphOutline( nGlyphIndex, rB2DPolyPoly ) )
868cdf0e10cSrcweir         return sal_True;
869cdf0e10cSrcweir 
870cdf0e10cSrcweir     return sal_False;
871cdf0e10cSrcweir }
872cdf0e10cSrcweir 
873cdf0e10cSrcweir SalLayout* PspGraphics::GetTextLayout( ImplLayoutArgs& rArgs, int nFallbackLevel )
874cdf0e10cSrcweir {
875cdf0e10cSrcweir     // workaround for printers not handling glyph indexing for non-TT fonts
876cdf0e10cSrcweir     int nFontId = m_pPrinterGfx->GetFontID();
877cdf0e10cSrcweir     if( psp::fonttype::TrueType != psp::PrintFontManager::get().getFontType( nFontId ) )
878cdf0e10cSrcweir         rArgs.mnFlags |= SAL_LAYOUT_DISABLE_GLYPH_PROCESSING;
879cdf0e10cSrcweir     else if( nFallbackLevel > 0 )
880cdf0e10cSrcweir         rArgs.mnFlags &= ~SAL_LAYOUT_DISABLE_GLYPH_PROCESSING;
881cdf0e10cSrcweir 
882cdf0e10cSrcweir     GenericSalLayout* pLayout = NULL;
883cdf0e10cSrcweir 
884cdf0e10cSrcweir     if( m_pServerFont[ nFallbackLevel ]
885cdf0e10cSrcweir         && !(rArgs.mnFlags & SAL_LAYOUT_DISABLE_GLYPH_PROCESSING) )
886cdf0e10cSrcweir         pLayout = new PspServerFontLayout( *m_pPrinterGfx, *m_pServerFont[nFallbackLevel], rArgs );
887cdf0e10cSrcweir     else
888cdf0e10cSrcweir         pLayout = new PspFontLayout( *m_pPrinterGfx );
889cdf0e10cSrcweir 
890cdf0e10cSrcweir     return pLayout;
891cdf0e10cSrcweir }
892cdf0e10cSrcweir 
893cdf0e10cSrcweir //--------------------------------------------------------------------------
894cdf0e10cSrcweir 
895cdf0e10cSrcweir sal_Bool PspGraphics::CreateFontSubset(
896cdf0e10cSrcweir                                    const rtl::OUString& rToFile,
897cdf0e10cSrcweir                                    const ImplFontData* pFont,
898cdf0e10cSrcweir                                    sal_Int32* pGlyphIDs,
899cdf0e10cSrcweir                                    sal_uInt8* pEncoding,
900cdf0e10cSrcweir                                    sal_Int32* pWidths,
901cdf0e10cSrcweir                                    int nGlyphCount,
902cdf0e10cSrcweir                                    FontSubsetInfo& rInfo
903cdf0e10cSrcweir                                    )
904cdf0e10cSrcweir {
905cdf0e10cSrcweir     // in this context the pFont->GetFontId() is a valid PSP
906cdf0e10cSrcweir     // font since they are the only ones left after the PDF
907cdf0e10cSrcweir     // export has filtered its list of subsettable fonts (for
908cdf0e10cSrcweir     // which this method was created). The correct way would
909cdf0e10cSrcweir     // be to have the GlyphCache search for the ImplFontData pFont
910cdf0e10cSrcweir     psp::fontID aFont = pFont->GetFontId();
911cdf0e10cSrcweir 
912cdf0e10cSrcweir     psp::PrintFontManager& rMgr = psp::PrintFontManager::get();
913cdf0e10cSrcweir     bool bSuccess = rMgr.createFontSubset( rInfo,
914cdf0e10cSrcweir                                  aFont,
915cdf0e10cSrcweir                                  rToFile,
916cdf0e10cSrcweir                                  pGlyphIDs,
917cdf0e10cSrcweir                                  pEncoding,
918cdf0e10cSrcweir                                  pWidths,
919cdf0e10cSrcweir                                  nGlyphCount );
920cdf0e10cSrcweir     return bSuccess;
921cdf0e10cSrcweir }
922cdf0e10cSrcweir 
923cdf0e10cSrcweir //--------------------------------------------------------------------------
924cdf0e10cSrcweir 
925cdf0e10cSrcweir const void* PspGraphics::GetEmbedFontData( const ImplFontData* pFont, const sal_Ucs* pUnicodes, sal_Int32* pWidths, FontSubsetInfo& rInfo, long* pDataLen )
926cdf0e10cSrcweir {
927cdf0e10cSrcweir     // in this context the pFont->GetFontId() is a valid PSP
928cdf0e10cSrcweir     // font since they are the only ones left after the PDF
929cdf0e10cSrcweir     // export has filtered its list of subsettable fonts (for
930cdf0e10cSrcweir     // which this method was created). The correct way would
931cdf0e10cSrcweir     // be to have the GlyphCache search for the ImplFontData pFont
932cdf0e10cSrcweir     psp::fontID aFont = pFont->GetFontId();
933cdf0e10cSrcweir     return PspGraphics::DoGetEmbedFontData( aFont, pUnicodes, pWidths, rInfo, pDataLen );
934cdf0e10cSrcweir }
935cdf0e10cSrcweir 
936cdf0e10cSrcweir //--------------------------------------------------------------------------
937cdf0e10cSrcweir 
938cdf0e10cSrcweir void PspGraphics::FreeEmbedFontData( const void* pData, long nLen )
939cdf0e10cSrcweir {
940cdf0e10cSrcweir     PspGraphics::DoFreeEmbedFontData( pData, nLen );
941cdf0e10cSrcweir }
942cdf0e10cSrcweir 
943cdf0e10cSrcweir //--------------------------------------------------------------------------
944cdf0e10cSrcweir 
945cdf0e10cSrcweir const Ucs2SIntMap* PspGraphics::GetFontEncodingVector( const ImplFontData* pFont, const Ucs2OStrMap** pNonEncoded )
946cdf0e10cSrcweir {
947cdf0e10cSrcweir     // in this context the pFont->GetFontId() is a valid PSP
948cdf0e10cSrcweir     // font since they are the only ones left after the PDF
949cdf0e10cSrcweir     // export has filtered its list of subsettable fonts (for
950cdf0e10cSrcweir     // which this method was created). The correct way would
951cdf0e10cSrcweir     // be to have the GlyphCache search for the ImplFontData pFont
952cdf0e10cSrcweir     psp::fontID aFont = pFont->GetFontId();
953cdf0e10cSrcweir     return PspGraphics::DoGetFontEncodingVector( aFont, pNonEncoded );
954cdf0e10cSrcweir }
955cdf0e10cSrcweir 
956cdf0e10cSrcweir //--------------------------------------------------------------------------
957cdf0e10cSrcweir 
958cdf0e10cSrcweir void PspGraphics::GetGlyphWidths( const ImplFontData* pFont,
959cdf0e10cSrcweir                                   bool bVertical,
960cdf0e10cSrcweir                                   Int32Vector& rWidths,
961cdf0e10cSrcweir                                   Ucs2UIntMap& rUnicodeEnc )
962cdf0e10cSrcweir {
963cdf0e10cSrcweir     // in this context the pFont->GetFontId() is a valid PSP
964cdf0e10cSrcweir     // font since they are the only ones left after the PDF
965cdf0e10cSrcweir     // export has filtered its list of subsettable fonts (for
966cdf0e10cSrcweir     // which this method was created). The correct way would
967cdf0e10cSrcweir     // be to have the GlyphCache search for the ImplFontData pFont
968cdf0e10cSrcweir     psp::fontID aFont = pFont->GetFontId();
969cdf0e10cSrcweir     PspGraphics::DoGetGlyphWidths( aFont, bVertical, rWidths, rUnicodeEnc );
970cdf0e10cSrcweir }
971cdf0e10cSrcweir 
972cdf0e10cSrcweir // static helpers of PspGraphics
973cdf0e10cSrcweir 
974cdf0e10cSrcweir const void* PspGraphics::DoGetEmbedFontData( fontID aFont, const sal_Ucs* pUnicodes, sal_Int32* pWidths, FontSubsetInfo& rInfo, long* pDataLen )
975cdf0e10cSrcweir {
976cdf0e10cSrcweir     psp::PrintFontManager& rMgr = psp::PrintFontManager::get();
977cdf0e10cSrcweir 
978cdf0e10cSrcweir     psp::PrintFontInfo aFontInfo;
979cdf0e10cSrcweir     if( ! rMgr.getFontInfo( aFont, aFontInfo ) )
980cdf0e10cSrcweir         return NULL;
981cdf0e10cSrcweir 
982cdf0e10cSrcweir     // fill in font info
983cdf0e10cSrcweir     rInfo.m_nAscent		= aFontInfo.m_nAscend;
984cdf0e10cSrcweir     rInfo.m_nDescent	= aFontInfo.m_nDescend;
985cdf0e10cSrcweir     rInfo.m_aPSName		= rMgr.getPSName( aFont );
986cdf0e10cSrcweir 
987cdf0e10cSrcweir     int xMin, yMin, xMax, yMax;
988cdf0e10cSrcweir     rMgr.getFontBoundingBox( aFont, xMin, yMin, xMax, yMax );
989cdf0e10cSrcweir 
990cdf0e10cSrcweir     psp::CharacterMetric aMetrics[256];
991cdf0e10cSrcweir     sal_Ucs aUnicodes[256];
992cdf0e10cSrcweir     if( aFontInfo.m_aEncoding == RTL_TEXTENCODING_SYMBOL && aFontInfo.m_eType == psp::fonttype::Type1 )
993cdf0e10cSrcweir     {
994cdf0e10cSrcweir         for( int i = 0; i < 256; i++ )
995cdf0e10cSrcweir             aUnicodes[i] = pUnicodes[i] < 0x0100 ? pUnicodes[i] + 0xf000 : pUnicodes[i];
996cdf0e10cSrcweir         pUnicodes = aUnicodes;
997cdf0e10cSrcweir     }
998cdf0e10cSrcweir     if( ! rMgr.getMetrics( aFont, pUnicodes, 256, aMetrics ) )
999cdf0e10cSrcweir         return NULL;
1000cdf0e10cSrcweir 
1001cdf0e10cSrcweir     OString aSysPath = rMgr.getFontFileSysPath( aFont );
1002cdf0e10cSrcweir     struct stat aStat;
1003cdf0e10cSrcweir     if( stat( aSysPath.getStr(), &aStat ) )
1004cdf0e10cSrcweir         return NULL;
1005cdf0e10cSrcweir     int fd = open( aSysPath.getStr(), O_RDONLY );
1006cdf0e10cSrcweir     if( fd < 0 )
1007cdf0e10cSrcweir         return NULL;
1008cdf0e10cSrcweir     void* pFile = mmap( NULL, aStat.st_size, PROT_READ, MAP_SHARED, fd, 0 );
1009cdf0e10cSrcweir     close( fd );
1010cdf0e10cSrcweir     if( pFile == MAP_FAILED )
1011cdf0e10cSrcweir         return NULL;
1012cdf0e10cSrcweir 
1013cdf0e10cSrcweir     *pDataLen = aStat.st_size;
1014cdf0e10cSrcweir 
1015cdf0e10cSrcweir     rInfo.m_aFontBBox	= Rectangle( Point( xMin, yMin ), Size( xMax-xMin, yMax-yMin ) );
1016cdf0e10cSrcweir     rInfo.m_nCapHeight	= yMax; // Well ...
1017cdf0e10cSrcweir 
1018cdf0e10cSrcweir     for( int i = 0; i < 256; i++ )
1019cdf0e10cSrcweir         pWidths[i] = (aMetrics[i].width > 0 ? aMetrics[i].width : 0);
1020cdf0e10cSrcweir 
1021cdf0e10cSrcweir     switch( aFontInfo.m_eType )
1022cdf0e10cSrcweir     {
1023cdf0e10cSrcweir         case psp::fonttype::TrueType:
1024cdf0e10cSrcweir             rInfo.m_nFontType = FontSubsetInfo::SFNT_TTF;
1025cdf0e10cSrcweir             break;
1026cdf0e10cSrcweir         case psp::fonttype::Type1: {
1027cdf0e10cSrcweir             const bool bPFA = ((*(unsigned char*)pFile) < 0x80);
1028cdf0e10cSrcweir             rInfo.m_nFontType = bPFA ? FontSubsetInfo::TYPE1_PFA : FontSubsetInfo::TYPE1_PFB;
1029cdf0e10cSrcweir             }
1030cdf0e10cSrcweir             break;
1031cdf0e10cSrcweir         default:
1032cdf0e10cSrcweir             return NULL;
1033cdf0e10cSrcweir     }
1034cdf0e10cSrcweir 
1035cdf0e10cSrcweir     return pFile;
1036cdf0e10cSrcweir }
1037cdf0e10cSrcweir 
1038cdf0e10cSrcweir void PspGraphics::DoFreeEmbedFontData( const void* pData, long nLen )
1039cdf0e10cSrcweir {
1040cdf0e10cSrcweir     if( pData )
1041cdf0e10cSrcweir         munmap( (char*)pData, nLen );
1042cdf0e10cSrcweir }
1043cdf0e10cSrcweir 
1044cdf0e10cSrcweir const Ucs2SIntMap* PspGraphics::DoGetFontEncodingVector( fontID aFont, const Ucs2OStrMap** pNonEncoded )
1045cdf0e10cSrcweir {
1046cdf0e10cSrcweir     psp::PrintFontManager& rMgr = psp::PrintFontManager::get();
1047cdf0e10cSrcweir 
1048cdf0e10cSrcweir     psp::PrintFontInfo aFontInfo;
1049cdf0e10cSrcweir     if( ! rMgr.getFontInfo( aFont, aFontInfo ) )
1050cdf0e10cSrcweir     {
1051cdf0e10cSrcweir         if( pNonEncoded )
1052cdf0e10cSrcweir             *pNonEncoded = NULL;
1053cdf0e10cSrcweir         return NULL;
1054cdf0e10cSrcweir     }
1055cdf0e10cSrcweir 
1056cdf0e10cSrcweir     return rMgr.getEncodingMap( aFont, pNonEncoded );
1057cdf0e10cSrcweir }
1058cdf0e10cSrcweir 
1059cdf0e10cSrcweir void PspGraphics::DoGetGlyphWidths( psp::fontID aFont,
1060cdf0e10cSrcweir                                     bool bVertical,
1061cdf0e10cSrcweir                                     Int32Vector& rWidths,
1062cdf0e10cSrcweir                                     Ucs2UIntMap& rUnicodeEnc )
1063cdf0e10cSrcweir {
1064cdf0e10cSrcweir     psp::PrintFontManager& rMgr = psp::PrintFontManager::get();
1065cdf0e10cSrcweir     rMgr.getGlyphWidths( aFont, bVertical, rWidths, rUnicodeEnc );
1066cdf0e10cSrcweir }
1067cdf0e10cSrcweir 
1068cdf0e10cSrcweir // ----------------------------------------------------------------------------
1069cdf0e10cSrcweir 
1070cdf0e10cSrcweir FontWidth PspGraphics::ToFontWidth (psp::width::type eWidth)
1071cdf0e10cSrcweir {
1072cdf0e10cSrcweir 	switch (eWidth)
1073cdf0e10cSrcweir 	{
1074cdf0e10cSrcweir 		case psp::width::UltraCondensed: return WIDTH_ULTRA_CONDENSED;
1075cdf0e10cSrcweir 		case psp::width::ExtraCondensed: return WIDTH_EXTRA_CONDENSED;
1076cdf0e10cSrcweir 		case psp::width::Condensed:		 return WIDTH_CONDENSED;
1077cdf0e10cSrcweir 		case psp::width::SemiCondensed:	 return WIDTH_SEMI_CONDENSED;
1078cdf0e10cSrcweir 		case psp::width::Normal:		 return WIDTH_NORMAL;
1079cdf0e10cSrcweir 		case psp::width::SemiExpanded:	 return WIDTH_SEMI_EXPANDED;
1080cdf0e10cSrcweir 		case psp::width::Expanded:		 return WIDTH_EXPANDED;
1081cdf0e10cSrcweir 		case psp::width::ExtraExpanded:	 return WIDTH_EXTRA_EXPANDED;
1082cdf0e10cSrcweir 		case psp::width::UltraExpanded:	 return WIDTH_ULTRA_EXPANDED;
1083cdf0e10cSrcweir         default: break;
1084cdf0e10cSrcweir 	}
1085cdf0e10cSrcweir 	return WIDTH_DONTKNOW;
1086cdf0e10cSrcweir }
1087cdf0e10cSrcweir 
1088cdf0e10cSrcweir FontWeight PspGraphics::ToFontWeight (psp::weight::type eWeight)
1089cdf0e10cSrcweir {
1090cdf0e10cSrcweir 	switch (eWeight)
1091cdf0e10cSrcweir 	{
1092cdf0e10cSrcweir 		case psp::weight::Thin:		  return WEIGHT_THIN;
1093cdf0e10cSrcweir 		case psp::weight::UltraLight: return WEIGHT_ULTRALIGHT;
1094cdf0e10cSrcweir 		case psp::weight::Light:	  return WEIGHT_LIGHT;
1095cdf0e10cSrcweir 		case psp::weight::SemiLight:  return WEIGHT_SEMILIGHT;
1096cdf0e10cSrcweir 		case psp::weight::Normal:	  return WEIGHT_NORMAL;
1097cdf0e10cSrcweir 		case psp::weight::Medium:	  return WEIGHT_MEDIUM;
1098cdf0e10cSrcweir 		case psp::weight::SemiBold:	  return WEIGHT_SEMIBOLD;
1099cdf0e10cSrcweir 		case psp::weight::Bold:		  return WEIGHT_BOLD;
1100cdf0e10cSrcweir 		case psp::weight::UltraBold:  return WEIGHT_ULTRABOLD;
1101cdf0e10cSrcweir 		case psp::weight::Black:	  return WEIGHT_BLACK;
1102cdf0e10cSrcweir         default: break;
1103cdf0e10cSrcweir 	}
1104cdf0e10cSrcweir 	return WEIGHT_DONTKNOW;
1105cdf0e10cSrcweir }
1106cdf0e10cSrcweir 
1107cdf0e10cSrcweir FontPitch PspGraphics::ToFontPitch (psp::pitch::type ePitch)
1108cdf0e10cSrcweir {
1109cdf0e10cSrcweir 	switch (ePitch)
1110cdf0e10cSrcweir 	{
1111cdf0e10cSrcweir 		case psp::pitch::Fixed:		return PITCH_FIXED;
1112cdf0e10cSrcweir 		case psp::pitch::Variable:	return PITCH_VARIABLE;
1113cdf0e10cSrcweir         default: break;
1114cdf0e10cSrcweir 	}
1115cdf0e10cSrcweir 	return PITCH_DONTKNOW;
1116cdf0e10cSrcweir }
1117cdf0e10cSrcweir 
1118cdf0e10cSrcweir FontItalic PspGraphics::ToFontItalic (psp::italic::type eItalic)
1119cdf0e10cSrcweir {
1120cdf0e10cSrcweir 	switch (eItalic)
1121cdf0e10cSrcweir 	{
1122cdf0e10cSrcweir 		case psp::italic::Upright:	return ITALIC_NONE;
1123cdf0e10cSrcweir 		case psp::italic::Oblique:	return ITALIC_OBLIQUE;
1124cdf0e10cSrcweir 		case psp::italic::Italic:	return ITALIC_NORMAL;
1125cdf0e10cSrcweir         default: break;
1126cdf0e10cSrcweir 	}
1127cdf0e10cSrcweir 	return ITALIC_DONTKNOW;
1128cdf0e10cSrcweir }
1129cdf0e10cSrcweir 
1130cdf0e10cSrcweir FontFamily PspGraphics::ToFontFamily (psp::family::type eFamily)
1131cdf0e10cSrcweir {
1132cdf0e10cSrcweir 	switch (eFamily)
1133cdf0e10cSrcweir 	{
1134cdf0e10cSrcweir 		case psp::family::Decorative: return FAMILY_DECORATIVE;
1135cdf0e10cSrcweir 		case psp::family::Modern:	  return FAMILY_MODERN;
1136cdf0e10cSrcweir 		case psp::family::Roman:	  return FAMILY_ROMAN;
1137cdf0e10cSrcweir 		case psp::family::Script:	  return FAMILY_SCRIPT;
1138cdf0e10cSrcweir 		case psp::family::Swiss:	  return FAMILY_SWISS;
1139cdf0e10cSrcweir 		case psp::family::System:	  return FAMILY_SYSTEM;
1140cdf0e10cSrcweir         default: break;
1141cdf0e10cSrcweir 	}
1142cdf0e10cSrcweir 	return FAMILY_DONTKNOW;
1143cdf0e10cSrcweir }
1144cdf0e10cSrcweir 
1145cdf0e10cSrcweir ImplDevFontAttributes PspGraphics::Info2DevFontAttributes( const psp::FastPrintFontInfo& rInfo )
1146cdf0e10cSrcweir {
1147cdf0e10cSrcweir     ImplDevFontAttributes aDFA;
1148cdf0e10cSrcweir     aDFA.maName         = rInfo.m_aFamilyName;
1149cdf0e10cSrcweir     aDFA.maStyleName    = rInfo.m_aStyleName;
1150cdf0e10cSrcweir     aDFA.meFamily       = ToFontFamily (rInfo.m_eFamilyStyle);
1151cdf0e10cSrcweir     aDFA.meWeight       = ToFontWeight (rInfo.m_eWeight);
1152cdf0e10cSrcweir     aDFA.meItalic       = ToFontItalic (rInfo.m_eItalic);
1153cdf0e10cSrcweir     aDFA.meWidthType    = ToFontWidth (rInfo.m_eWidth);
1154cdf0e10cSrcweir     aDFA.mePitch        = ToFontPitch (rInfo.m_ePitch);
1155cdf0e10cSrcweir     aDFA.mbSymbolFlag   = (rInfo.m_aEncoding == RTL_TEXTENCODING_SYMBOL);
1156cdf0e10cSrcweir 
1157cdf0e10cSrcweir     switch( rInfo.m_eType )
1158cdf0e10cSrcweir     {
1159cdf0e10cSrcweir         case psp::fonttype::Builtin:
1160cdf0e10cSrcweir             aDFA.mnQuality       = 1024;
1161cdf0e10cSrcweir             aDFA.mbDevice        = true;
1162cdf0e10cSrcweir             aDFA.mbSubsettable   = false;
1163cdf0e10cSrcweir             aDFA.mbEmbeddable    = false;
1164cdf0e10cSrcweir             break;
1165cdf0e10cSrcweir         case psp::fonttype::TrueType:
1166cdf0e10cSrcweir             aDFA.mnQuality       = 512;
1167cdf0e10cSrcweir             aDFA.mbDevice        = false;
1168cdf0e10cSrcweir             aDFA.mbSubsettable   = true;
1169cdf0e10cSrcweir             aDFA.mbEmbeddable    = false;
1170cdf0e10cSrcweir             break;
1171cdf0e10cSrcweir         case psp::fonttype::Type1:
1172cdf0e10cSrcweir             aDFA.mnQuality       = 0;
1173cdf0e10cSrcweir             aDFA.mbDevice        = false;
1174cdf0e10cSrcweir             aDFA.mbSubsettable   = false;
1175cdf0e10cSrcweir             aDFA.mbEmbeddable    = true;
1176cdf0e10cSrcweir             break;
1177cdf0e10cSrcweir         default:
1178cdf0e10cSrcweir             aDFA.mnQuality       = 0;
1179cdf0e10cSrcweir             aDFA.mbDevice        = false;
1180cdf0e10cSrcweir             aDFA.mbSubsettable   = false;
1181cdf0e10cSrcweir             aDFA.mbEmbeddable    = false;
1182cdf0e10cSrcweir             break;
1183cdf0e10cSrcweir     }
1184cdf0e10cSrcweir 
1185cdf0e10cSrcweir     aDFA.mbOrientation   = true;
1186cdf0e10cSrcweir 
1187cdf0e10cSrcweir     // add font family name aliases
1188cdf0e10cSrcweir     ::std::list< OUString >::const_iterator it = rInfo.m_aAliases.begin();
1189cdf0e10cSrcweir     bool bHasMapNames = false;
1190cdf0e10cSrcweir     for(; it != rInfo.m_aAliases.end(); ++it )
1191cdf0e10cSrcweir     {
1192cdf0e10cSrcweir         if( bHasMapNames )
1193cdf0e10cSrcweir             aDFA.maMapNames.Append( ';' );
1194cdf0e10cSrcweir         aDFA.maMapNames.Append( (*it).getStr() );
1195cdf0e10cSrcweir         bHasMapNames = true;
1196cdf0e10cSrcweir     }
1197cdf0e10cSrcweir 
1198cdf0e10cSrcweir #if OSL_DEBUG_LEVEL > 2
1199cdf0e10cSrcweir     if( bHasMapNames )
1200cdf0e10cSrcweir     {
1201cdf0e10cSrcweir         ByteString aOrigName( aDFA.maName, osl_getThreadTextEncoding() );
1202cdf0e10cSrcweir         ByteString aAliasNames( aDFA.maMapNames, osl_getThreadTextEncoding() );
1203cdf0e10cSrcweir         fprintf( stderr, "using alias names \"%s\" for font family \"%s\"\n",
1204cdf0e10cSrcweir             aAliasNames.GetBuffer(), aOrigName.GetBuffer() );
1205cdf0e10cSrcweir     }
1206cdf0e10cSrcweir #endif
1207cdf0e10cSrcweir 
1208cdf0e10cSrcweir     return aDFA;
1209cdf0e10cSrcweir }
1210cdf0e10cSrcweir 
1211cdf0e10cSrcweir // -----------------------------------------------------------------------
1212cdf0e10cSrcweir 
1213cdf0e10cSrcweir void PspGraphics::AnnounceFonts( ImplDevFontList* pFontList, const psp::FastPrintFontInfo& aInfo )
1214cdf0e10cSrcweir {
1215cdf0e10cSrcweir     int nQuality = 0;
1216cdf0e10cSrcweir 
1217cdf0e10cSrcweir     if( aInfo.m_eType == psp::fonttype::TrueType )
1218cdf0e10cSrcweir     {
1219cdf0e10cSrcweir         // asian type 1 fonts are not known
1220cdf0e10cSrcweir         psp::PrintFontManager& rMgr = psp::PrintFontManager::get();
1221cdf0e10cSrcweir         ByteString aFileName( rMgr.getFontFileSysPath( aInfo.m_nID ) );
1222cdf0e10cSrcweir         int nPos = aFileName.SearchBackward( '_' );
1223cdf0e10cSrcweir         if( nPos == STRING_NOTFOUND || aFileName.GetChar( nPos+1 ) == '.' )
1224cdf0e10cSrcweir             nQuality += 5;
1225cdf0e10cSrcweir         else
1226cdf0e10cSrcweir         {
1227cdf0e10cSrcweir             static const char* pLangBoost = NULL;
1228cdf0e10cSrcweir             static bool bOnce = true;
1229cdf0e10cSrcweir             if( bOnce )
1230cdf0e10cSrcweir             {
1231cdf0e10cSrcweir                 bOnce = false;
1232cdf0e10cSrcweir                 const LanguageType aLang = Application::GetSettings().GetUILanguage();
1233cdf0e10cSrcweir                 switch( aLang )
1234cdf0e10cSrcweir                 {
1235cdf0e10cSrcweir                     case LANGUAGE_JAPANESE:
1236cdf0e10cSrcweir                         pLangBoost = "jan";
1237cdf0e10cSrcweir                         break;
1238cdf0e10cSrcweir                     case LANGUAGE_CHINESE:
1239cdf0e10cSrcweir                     case LANGUAGE_CHINESE_SIMPLIFIED:
1240cdf0e10cSrcweir                     case LANGUAGE_CHINESE_SINGAPORE:
1241cdf0e10cSrcweir                         pLangBoost = "zhs";
1242cdf0e10cSrcweir                         break;
1243cdf0e10cSrcweir                     case LANGUAGE_CHINESE_TRADITIONAL:
1244cdf0e10cSrcweir                     case LANGUAGE_CHINESE_HONGKONG:
1245cdf0e10cSrcweir                     case LANGUAGE_CHINESE_MACAU:
1246cdf0e10cSrcweir                         pLangBoost = "zht";
1247cdf0e10cSrcweir                         break;
1248cdf0e10cSrcweir                     case LANGUAGE_KOREAN:
1249cdf0e10cSrcweir                     case LANGUAGE_KOREAN_JOHAB:
1250cdf0e10cSrcweir                         pLangBoost = "kor";
1251cdf0e10cSrcweir                         break;
1252cdf0e10cSrcweir                 }
1253cdf0e10cSrcweir             }
1254cdf0e10cSrcweir 
1255cdf0e10cSrcweir             if( pLangBoost )
1256cdf0e10cSrcweir                 if( aFileName.Copy( nPos+1, 3 ).EqualsIgnoreCaseAscii( pLangBoost ) )
1257cdf0e10cSrcweir                     nQuality += 10;
1258cdf0e10cSrcweir         }
1259cdf0e10cSrcweir     }
1260cdf0e10cSrcweir 
1261cdf0e10cSrcweir     ImplPspFontData* pFD = new ImplPspFontData( aInfo );
1262cdf0e10cSrcweir     pFD->mnQuality += nQuality;
1263cdf0e10cSrcweir     pFontList->Add( pFD );
1264cdf0e10cSrcweir }
1265cdf0e10cSrcweir 
1266cdf0e10cSrcweir bool PspGraphics::filterText( const String& rOrig, String& rNewText, xub_StrLen nIndex, xub_StrLen& rLen, xub_StrLen& rCutStart, xub_StrLen& rCutStop )
1267cdf0e10cSrcweir {
1268cdf0e10cSrcweir 	if( ! m_pPhoneNr )
1269cdf0e10cSrcweir 		return false;
1270cdf0e10cSrcweir 
1271cdf0e10cSrcweir     rCutStop = rCutStart = STRING_NOTFOUND;
1272cdf0e10cSrcweir 
1273cdf0e10cSrcweir #define FAX_PHONE_TOKEN          "@@#"
1274cdf0e10cSrcweir #define FAX_PHONE_TOKEN_LENGTH   3
1275cdf0e10cSrcweir #define FAX_END_TOKEN            "@@"
1276cdf0e10cSrcweir #define FAX_END_TOKEN_LENGTH     2
1277cdf0e10cSrcweir 
1278cdf0e10cSrcweir 	bool bRet = false;
1279cdf0e10cSrcweir 	bool bStarted = false;
1280cdf0e10cSrcweir 	bool bStopped = false;
1281cdf0e10cSrcweir 	sal_uInt16 nPos;
1282cdf0e10cSrcweir 	sal_uInt16 nStart = 0;
1283cdf0e10cSrcweir 	sal_uInt16 nStop = rLen;
1284cdf0e10cSrcweir 	String aPhone = rOrig.Copy( nIndex, rLen );
1285cdf0e10cSrcweir 
1286cdf0e10cSrcweir 	if( ! m_bPhoneCollectionActive )
1287cdf0e10cSrcweir 	{
1288cdf0e10cSrcweir 		if( ( nPos = aPhone.SearchAscii( FAX_PHONE_TOKEN ) ) != STRING_NOTFOUND )
1289cdf0e10cSrcweir 		{
1290cdf0e10cSrcweir 			nStart = nPos;
1291cdf0e10cSrcweir 			m_bPhoneCollectionActive = true;
1292cdf0e10cSrcweir 			m_aPhoneCollection.Erase();
1293cdf0e10cSrcweir 			bRet = true;
1294cdf0e10cSrcweir 			bStarted = true;
1295cdf0e10cSrcweir 		}
1296cdf0e10cSrcweir 	}
1297cdf0e10cSrcweir 	if( m_bPhoneCollectionActive )
1298cdf0e10cSrcweir 	{
1299cdf0e10cSrcweir 		bRet = true;
1300cdf0e10cSrcweir 		nPos = bStarted ? nStart + FAX_PHONE_TOKEN_LENGTH : 0;
1301cdf0e10cSrcweir 		if( ( nPos = aPhone.SearchAscii( FAX_END_TOKEN, nPos ) ) != STRING_NOTFOUND )
1302cdf0e10cSrcweir 		{
1303cdf0e10cSrcweir 			m_bPhoneCollectionActive = false;
1304cdf0e10cSrcweir 			nStop = nPos + FAX_END_TOKEN_LENGTH;
1305cdf0e10cSrcweir 			bStopped = true;
1306cdf0e10cSrcweir 		}
1307cdf0e10cSrcweir 		int nTokenStart = nStart + (bStarted ? FAX_PHONE_TOKEN_LENGTH : 0);
1308cdf0e10cSrcweir 		int nTokenStop = nStop - (bStopped ? FAX_END_TOKEN_LENGTH : 0);
1309cdf0e10cSrcweir 		m_aPhoneCollection += aPhone.Copy( nTokenStart, nTokenStop - nTokenStart );
1310cdf0e10cSrcweir 		if( ! m_bPhoneCollectionActive )
1311cdf0e10cSrcweir 		{
1312cdf0e10cSrcweir             m_pPhoneNr->AppendAscii( "<Fax#>" );
1313cdf0e10cSrcweir 			m_pPhoneNr->Append( m_aPhoneCollection );
1314cdf0e10cSrcweir             m_pPhoneNr->AppendAscii( "</Fax#>" );
1315cdf0e10cSrcweir 			m_aPhoneCollection.Erase();
1316cdf0e10cSrcweir 		}
1317cdf0e10cSrcweir 	}
1318cdf0e10cSrcweir 	if( m_aPhoneCollection.Len() > 1024 )
1319cdf0e10cSrcweir 	{
1320cdf0e10cSrcweir 		m_bPhoneCollectionActive = false;
1321cdf0e10cSrcweir 		m_aPhoneCollection.Erase();
1322cdf0e10cSrcweir 		bRet = false;
1323cdf0e10cSrcweir 	}
1324cdf0e10cSrcweir 
1325cdf0e10cSrcweir     if( bRet && m_bSwallowFaxNo )
1326cdf0e10cSrcweir     {
1327cdf0e10cSrcweir         rLen -= nStop - nStart;
1328cdf0e10cSrcweir         rCutStart = nStart+nIndex;
1329cdf0e10cSrcweir         rCutStop = nStop+nIndex;
1330cdf0e10cSrcweir         if( rCutStart )
1331cdf0e10cSrcweir             rNewText = rOrig.Copy( 0, rCutStart );
1332cdf0e10cSrcweir         rNewText += rOrig.Copy( rCutStop );
1333cdf0e10cSrcweir     }
1334cdf0e10cSrcweir 
1335cdf0e10cSrcweir     return bRet && m_bSwallowFaxNo;
1336cdf0e10cSrcweir }
1337cdf0e10cSrcweir 
1338cdf0e10cSrcweir SystemFontData PspGraphics::GetSysFontData( int nFallbacklevel ) const
1339cdf0e10cSrcweir {
1340cdf0e10cSrcweir     SystemFontData aSysFontData;
1341cdf0e10cSrcweir 
1342cdf0e10cSrcweir     if (nFallbacklevel >= MAX_FALLBACK) nFallbacklevel = MAX_FALLBACK - 1;
1343cdf0e10cSrcweir     if (nFallbacklevel < 0 ) nFallbacklevel = 0;
1344cdf0e10cSrcweir 
1345cdf0e10cSrcweir     aSysFontData.nSize = sizeof( SystemFontData );
1346cdf0e10cSrcweir     aSysFontData.nFontId = 0;
1347cdf0e10cSrcweir     aSysFontData.nFontFlags = 0;
1348cdf0e10cSrcweir     aSysFontData.bFakeBold = false;
1349cdf0e10cSrcweir     aSysFontData.bFakeItalic = false;
1350cdf0e10cSrcweir     aSysFontData.bAntialias = true;
1351cdf0e10cSrcweir     return aSysFontData;
1352cdf0e10cSrcweir }
1353cdf0e10cSrcweir 
1354cdf0e10cSrcweir SystemGraphicsData PspGraphics::GetGraphicsData() const
1355cdf0e10cSrcweir {
1356cdf0e10cSrcweir     SystemGraphicsData aRes;
1357cdf0e10cSrcweir     aRes.nSize = sizeof(aRes);
1358cdf0e10cSrcweir         aRes.hDrawable = 0;
1359cdf0e10cSrcweir         aRes.pRenderFormat = 0;
1360cdf0e10cSrcweir     return aRes;
1361cdf0e10cSrcweir }
1362cdf0e10cSrcweir 
1363