124f6443dSAndrew Rist /************************************************************** 2cdf0e10cSrcweir * 324f6443dSAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 424f6443dSAndrew Rist * or more contributor license agreements. See the NOTICE file 524f6443dSAndrew Rist * distributed with this work for additional information 624f6443dSAndrew Rist * regarding copyright ownership. The ASF licenses this file 724f6443dSAndrew Rist * to you under the Apache License, Version 2.0 (the 824f6443dSAndrew Rist * "License"); you may not use this file except in compliance 924f6443dSAndrew Rist * with the License. You may obtain a copy of the License at 1024f6443dSAndrew Rist * 1124f6443dSAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 1224f6443dSAndrew Rist * 1324f6443dSAndrew Rist * Unless required by applicable law or agreed to in writing, 1424f6443dSAndrew Rist * software distributed under the License is distributed on an 1524f6443dSAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 1624f6443dSAndrew Rist * KIND, either express or implied. See the License for the 1724f6443dSAndrew Rist * specific language governing permissions and limitations 1824f6443dSAndrew Rist * under the License. 1924f6443dSAndrew Rist * 2024f6443dSAndrew Rist *************************************************************/ 2124f6443dSAndrew Rist 2224f6443dSAndrew Rist 23cdf0e10cSrcweir 24cdf0e10cSrcweir #ifndef _SV_SALGDI_H 25cdf0e10cSrcweir #define _SV_SALGDI_H 26cdf0e10cSrcweir 27cdf0e10cSrcweir #include "basegfx/polygon/b2dpolypolygon.hxx" 28cdf0e10cSrcweir 29cdf0e10cSrcweir #include "premac.h" 30cdf0e10cSrcweir #include <ApplicationServices/ApplicationServices.h> 31cdf0e10cSrcweir #include "postmac.h" 32cdf0e10cSrcweir 33cdf0e10cSrcweir #include "aqua/aquavcltypes.h" 34cdf0e10cSrcweir 35cdf0e10cSrcweir #include "outfont.hxx" 36cdf0e10cSrcweir #include "salgdi.hxx" 37cdf0e10cSrcweir 38cdf0e10cSrcweir #include <vector> 39cdf0e10cSrcweir 40cdf0e10cSrcweir class AquaSalFrame; 41cdf0e10cSrcweir class AquaSalBitmap; 42cdf0e10cSrcweir class ImplDevFontAttributes; 43*24a22e85SHerbert Dürr class ImplMacTextStyle; 44cdf0e10cSrcweir 45*24a22e85SHerbert Dürr struct CGRect; 46*24a22e85SHerbert Dürr 47*24a22e85SHerbert Dürr #ifndef CGFLOAT_TYPE 48*24a22e85SHerbert Dürr typedef float CGFloat; 49*24a22e85SHerbert Dürr #endif 50cdf0e10cSrcweir 51cdf0e10cSrcweir // mac specific physically available font face 52cdf0e10cSrcweir class ImplMacFontData : public ImplFontData 53cdf0e10cSrcweir { 54cdf0e10cSrcweir public: 55cdf0e10cSrcweir ImplMacFontData( const ImplDevFontAttributes&, ATSUFontID ); 56cdf0e10cSrcweir 57cdf0e10cSrcweir virtual ~ImplMacFontData(); 58cdf0e10cSrcweir 59cdf0e10cSrcweir virtual ImplFontData* Clone() const; 60cdf0e10cSrcweir virtual ImplFontEntry* CreateFontInstance( ImplFontSelectData& ) const; 61cdf0e10cSrcweir virtual sal_IntPtr GetFontId() const; 62cdf0e10cSrcweir 63cdf0e10cSrcweir const ImplFontCharMap* GetImplFontCharMap() const; 64cdf0e10cSrcweir bool HasChar( sal_uInt32 cChar ) const; 65cdf0e10cSrcweir 66cdf0e10cSrcweir void ReadOs2Table() const; 67cdf0e10cSrcweir void ReadMacCmapEncoding() const; 68cdf0e10cSrcweir bool HasCJKSupport() const; 69cdf0e10cSrcweir 70cdf0e10cSrcweir private: 71cdf0e10cSrcweir const ATSUFontID mnFontId; 72cdf0e10cSrcweir mutable const ImplFontCharMap* mpCharMap; 73cdf0e10cSrcweir mutable bool mbOs2Read; // true if OS2-table related info is valid 74cdf0e10cSrcweir mutable bool mbHasOs2Table; 75cdf0e10cSrcweir mutable bool mbCmapEncodingRead; // true if cmap encoding of Mac font is read 76cdf0e10cSrcweir mutable bool mbHasCJKSupport; // #i78970# CJK fonts need extra leading 77cdf0e10cSrcweir }; 78cdf0e10cSrcweir 79cdf0e10cSrcweir // abstracting quartz color instead of having to use an CGFloat[] array 80cdf0e10cSrcweir class RGBAColor 81cdf0e10cSrcweir { 82cdf0e10cSrcweir public: 83cdf0e10cSrcweir RGBAColor( SalColor ); 84cdf0e10cSrcweir RGBAColor( float fRed, float fGreen, float fBlue, float fAlpha ); //NOTUSEDYET 85*24a22e85SHerbert Dürr void SetAlpha( float fAlpha ) { mfRGBA[3] = fAlpha; } 86*24a22e85SHerbert Dürr 87*24a22e85SHerbert Dürr bool IsVisible() const { return (mfRGBA[3] > 0); } 88*24a22e85SHerbert Dürr const CGFloat* AsArray() const { return mfRGBA; } 89*24a22e85SHerbert Dürr CGFloat GetRed() const { return mfRGBA[0]; } 90*24a22e85SHerbert Dürr CGFloat GetGreen() const { return mfRGBA[1]; } 91*24a22e85SHerbert Dürr CGFloat GetBlue() const { return mfRGBA[2]; } 92*24a22e85SHerbert Dürr CGFloat GetAlpha() const { return mfRGBA[3]; } 93*24a22e85SHerbert Dürr private: 94*24a22e85SHerbert Dürr CGFloat mfRGBA[4]; // RGBA 95cdf0e10cSrcweir }; 96cdf0e10cSrcweir 97cdf0e10cSrcweir // ------------------- 98cdf0e10cSrcweir // - AquaSalGraphics - 99cdf0e10cSrcweir // ------------------- 100cdf0e10cSrcweir class AquaSalGraphics : public SalGraphics 101cdf0e10cSrcweir { 102cdf0e10cSrcweir friend class ATSLayout; 103cdf0e10cSrcweir protected: 104cdf0e10cSrcweir AquaSalFrame* mpFrame; 105cdf0e10cSrcweir CGLayerRef mxLayer; // Quartz graphics layer 106cdf0e10cSrcweir CGContextRef mrContext; // Quartz drawing context 107cdf0e10cSrcweir class XorEmulation* mpXorEmulation; 108cdf0e10cSrcweir int mnXorMode; // 0: off 1: on 2: invert only 109cdf0e10cSrcweir int mnWidth; 110cdf0e10cSrcweir int mnHeight; 111cdf0e10cSrcweir int mnBitmapDepth; // zero unless bitmap 112cdf0e10cSrcweir /// device resolution of this graphics 113cdf0e10cSrcweir long mnRealDPIX; 114cdf0e10cSrcweir long mnRealDPIY; 115cdf0e10cSrcweir /// some graphics implementations (e.g. AquaSalInfoPrinter) scale 116cdf0e10cSrcweir /// everything down by a factor (see SetupPrinterGraphics for details) 117cdf0e10cSrcweir /// so we have to compensate for it with the inverse factor 118cdf0e10cSrcweir double mfFakeDPIScale; 119cdf0e10cSrcweir 120cdf0e10cSrcweir /// path representing current clip region 121cdf0e10cSrcweir CGMutablePathRef mxClipPath; 122cdf0e10cSrcweir 123cdf0e10cSrcweir /// Drawing colors 124cdf0e10cSrcweir /// pen color RGBA 125cdf0e10cSrcweir RGBAColor maLineColor; 126cdf0e10cSrcweir /// brush color RGBA 127cdf0e10cSrcweir RGBAColor maFillColor; 128cdf0e10cSrcweir 129cdf0e10cSrcweir // Device Font settings 130cdf0e10cSrcweir const ImplMacFontData* mpMacFontData; 131cdf0e10cSrcweir /// ATSU style object which carries all font attributes 132cdf0e10cSrcweir ATSUStyle maATSUStyle; 133cdf0e10cSrcweir /// text rotation as ATSU angle 134cdf0e10cSrcweir Fixed mnATSUIRotation; 135cdf0e10cSrcweir /// workaround to prevent ATSU overflows for huge font sizes 136cdf0e10cSrcweir float mfFontScale; 137cdf0e10cSrcweir /// <1.0: font is squeezed, >1.0 font is stretched, else 1.0 138cdf0e10cSrcweir float mfFontStretch; 139cdf0e10cSrcweir /// allows text to be rendered without antialiasing 140cdf0e10cSrcweir bool mbNonAntialiasedText; 141cdf0e10cSrcweir 142cdf0e10cSrcweir // Graphics types 143cdf0e10cSrcweir 144cdf0e10cSrcweir /// is this a printer graphics 145cdf0e10cSrcweir bool mbPrinter; 146cdf0e10cSrcweir /// is this a virtual device graphics 147cdf0e10cSrcweir bool mbVirDev; 148cdf0e10cSrcweir /// is this a window graphics 149cdf0e10cSrcweir bool mbWindow; 150cdf0e10cSrcweir 151cdf0e10cSrcweir public: 152cdf0e10cSrcweir AquaSalGraphics(); 153cdf0e10cSrcweir virtual ~AquaSalGraphics(); 154cdf0e10cSrcweir 155cdf0e10cSrcweir bool IsPenVisible() const { return maLineColor.IsVisible(); } 156cdf0e10cSrcweir bool IsBrushVisible() const { return maFillColor.IsVisible(); } 157cdf0e10cSrcweir 158cdf0e10cSrcweir void SetWindowGraphics( AquaSalFrame* pFrame ); 159cdf0e10cSrcweir void SetPrinterGraphics( CGContextRef, long nRealDPIX, long nRealDPIY, double fFakeScale ); 160cdf0e10cSrcweir void SetVirDevGraphics( CGLayerRef, CGContextRef, int nBitDepth = 0 ); 161cdf0e10cSrcweir 162cdf0e10cSrcweir void initResolution( NSWindow* ); 163cdf0e10cSrcweir void copyResolution( AquaSalGraphics& ); 164cdf0e10cSrcweir void updateResolution(); 165cdf0e10cSrcweir 166cdf0e10cSrcweir bool IsWindowGraphics() const { return mbWindow; } 167cdf0e10cSrcweir bool IsPrinterGraphics() const { return mbPrinter; } 168cdf0e10cSrcweir bool IsVirDevGraphics() const { return mbVirDev; } 169cdf0e10cSrcweir AquaSalFrame* getGraphicsFrame() const { return mpFrame; } 170cdf0e10cSrcweir void setGraphicsFrame( AquaSalFrame* pFrame ) { mpFrame = pFrame; } 171cdf0e10cSrcweir 172cdf0e10cSrcweir void ImplDrawPixel( long nX, long nY, const RGBAColor& ); // helper to draw single pixels 173cdf0e10cSrcweir 174cdf0e10cSrcweir bool CheckContext(); 175cdf0e10cSrcweir void UpdateWindow( NSRect& ); // delivered in NSView coordinates 176cdf0e10cSrcweir void RefreshRect( const CGRect& ); 177cdf0e10cSrcweir void RefreshRect( const NSRect& ); 178cdf0e10cSrcweir void RefreshRect(float lX, float lY, float lWidth, float lHeight); 179cdf0e10cSrcweir 180cdf0e10cSrcweir void SetState(); 181cdf0e10cSrcweir void UnsetState(); 182cdf0e10cSrcweir // InvalidateContext does an UnsetState and sets mrContext to 0 183cdf0e10cSrcweir void InvalidateContext(); 184cdf0e10cSrcweir 185cdf0e10cSrcweir virtual bool setClipRegion( const Region& ); 186cdf0e10cSrcweir 187cdf0e10cSrcweir // draw --> LineColor and FillColor and RasterOp and ClipRegion 188cdf0e10cSrcweir virtual void drawPixel( long nX, long nY ); 189cdf0e10cSrcweir virtual void drawPixel( long nX, long nY, SalColor nSalColor ); 190cdf0e10cSrcweir virtual void drawLine( long nX1, long nY1, long nX2, long nY2 ); 191cdf0e10cSrcweir virtual void drawRect( long nX, long nY, long nWidth, long nHeight ); 19254ae6a37SHerbert Dürr virtual void drawPolyLine( sal_uInt32 nPoints, const SalPoint* pPtAry ); 19354ae6a37SHerbert Dürr virtual void drawPolygon( sal_uInt32 nPoints, const SalPoint* pPtAry ); 19454ae6a37SHerbert Dürr virtual void drawPolyPolygon( sal_uInt32 nPoly, const sal_uInt32* pPoints, PCONSTSALPOINT* pPtAry ); 195cdf0e10cSrcweir virtual bool drawPolyPolygon( const ::basegfx::B2DPolyPolygon&, double fTransparency ); 19654ae6a37SHerbert Dürr virtual sal_Bool drawPolyLineBezier( sal_uInt32 nPoints, const SalPoint* pPtAry, const sal_uInt8* pFlgAry ); 19754ae6a37SHerbert Dürr virtual sal_Bool drawPolygonBezier( sal_uInt32 nPoints, const SalPoint* pPtAry, const sal_uInt8* pFlgAry ); 19854ae6a37SHerbert Dürr virtual sal_Bool drawPolyPolygonBezier( sal_uInt32 nPoly, const sal_uInt32* pPoints, const SalPoint* const* pPtAry, const sal_uInt8* const* pFlgAry ); 1995aaf853bSArmin Le Grand virtual bool drawPolyLine( 2005aaf853bSArmin Le Grand const ::basegfx::B2DPolygon&, 2015aaf853bSArmin Le Grand double fTransparency, 2025aaf853bSArmin Le Grand const ::basegfx::B2DVector& rLineWidths, 2035aaf853bSArmin Le Grand basegfx::B2DLineJoin, 2045aaf853bSArmin Le Grand com::sun::star::drawing::LineCap eLineCap); 205cdf0e10cSrcweir 206cdf0e10cSrcweir // CopyArea --> No RasterOp, but ClipRegion 207cdf0e10cSrcweir virtual void copyArea( long nDestX, long nDestY, long nSrcX, long nSrcY, long nSrcWidth, 208cdf0e10cSrcweir long nSrcHeight, sal_uInt16 nFlags ); 209cdf0e10cSrcweir 210cdf0e10cSrcweir // CopyBits and DrawBitmap --> RasterOp and ClipRegion 211cdf0e10cSrcweir // CopyBits() --> pSrcGraphics == NULL, then CopyBits on same Graphics 2125f27b83cSArmin Le Grand virtual void copyBits( const SalTwoRect& rPosAry, SalGraphics* pSrcGraphics ); 2135f27b83cSArmin Le Grand virtual void drawBitmap( const SalTwoRect& rPosAry, const SalBitmap& rSalBitmap ); 2145f27b83cSArmin Le Grand virtual void drawBitmap( const SalTwoRect& rPosAry, 215cdf0e10cSrcweir const SalBitmap& rSalBitmap, 216cdf0e10cSrcweir SalColor nTransparentColor ); 2175f27b83cSArmin Le Grand virtual void drawBitmap( const SalTwoRect& rPosAry, 218cdf0e10cSrcweir const SalBitmap& rSalBitmap, 219cdf0e10cSrcweir const SalBitmap& rTransparentBitmap ); 2205f27b83cSArmin Le Grand virtual void drawMask( const SalTwoRect& rPosAry, 221cdf0e10cSrcweir const SalBitmap& rSalBitmap, 222cdf0e10cSrcweir SalColor nMaskColor ); 223cdf0e10cSrcweir 224cdf0e10cSrcweir virtual SalBitmap* getBitmap( long nX, long nY, long nWidth, long nHeight ); 225cdf0e10cSrcweir virtual SalColor getPixel( long nX, long nY ); 226cdf0e10cSrcweir 227cdf0e10cSrcweir // invert --> ClipRegion (only Windows or VirDevs) 228cdf0e10cSrcweir virtual void invert( long nX, long nY, long nWidth, long nHeight, SalInvert nFlags); 22954ae6a37SHerbert Dürr virtual void invert( sal_uInt32 nPoints, const SalPoint* pPtAry, SalInvert nFlags ); 230cdf0e10cSrcweir 231cdf0e10cSrcweir virtual sal_Bool drawEPS( long nX, long nY, long nWidth, long nHeight, void* pPtr, sal_uLong nSize ); 232cdf0e10cSrcweir 233cdf0e10cSrcweir virtual bool drawAlphaBitmap( const SalTwoRect&, 234cdf0e10cSrcweir const SalBitmap& rSourceBitmap, 235cdf0e10cSrcweir const SalBitmap& rAlphaBitmap ); 2365f27b83cSArmin Le Grand virtual bool drawTransformedBitmap( 2375f27b83cSArmin Le Grand const basegfx::B2DPoint& rNull, 2385f27b83cSArmin Le Grand const basegfx::B2DPoint& rX, 2395f27b83cSArmin Le Grand const basegfx::B2DPoint& rY, 2405f27b83cSArmin Le Grand const SalBitmap& rSourceBitmap, 2415f27b83cSArmin Le Grand const SalBitmap* pAlphaBitmap); 242cdf0e10cSrcweir 243cdf0e10cSrcweir virtual bool drawAlphaRect( long nX, long nY, long nWidth, 244cdf0e10cSrcweir long nHeight, sal_uInt8 nTransparency ); 245cdf0e10cSrcweir 246cdf0e10cSrcweir CGPoint* makeCGptArray(sal_uLong nPoints, const SalPoint* pPtAry); 247cdf0e10cSrcweir // native widget rendering methods that require mirroring 248cdf0e10cSrcweir virtual sal_Bool hitTestNativeControl( ControlType nType, ControlPart nPart, const Rectangle& rControlRegion, 249cdf0e10cSrcweir const Point& aPos, sal_Bool& rIsInside ); 250cdf0e10cSrcweir virtual sal_Bool drawNativeControl( ControlType nType, ControlPart nPart, const Rectangle& rControlRegion, 251cdf0e10cSrcweir ControlState nState, const ImplControlValue& aValue, 252cdf0e10cSrcweir const rtl::OUString& aCaption ); 253cdf0e10cSrcweir virtual sal_Bool drawNativeControlText( ControlType nType, ControlPart nPart, const Rectangle& rControlRegion, 254cdf0e10cSrcweir ControlState nState, const ImplControlValue& aValue, 255cdf0e10cSrcweir const rtl::OUString& aCaption ); 256cdf0e10cSrcweir virtual sal_Bool getNativeControlRegion( ControlType nType, ControlPart nPart, const Rectangle& rControlRegion, ControlState nState, 257cdf0e10cSrcweir const ImplControlValue& aValue, const rtl::OUString& aCaption, 258cdf0e10cSrcweir Rectangle &rNativeBoundingRegion, Rectangle &rNativeContentRegion ); 259cdf0e10cSrcweir 260cdf0e10cSrcweir // get device resolution 2618a718ffcSHerbert Dürr virtual void GetResolution( sal_Int32& rDPIX, sal_Int32& rDPIY ); 262cdf0e10cSrcweir // get the depth of the device 263cdf0e10cSrcweir virtual sal_uInt16 GetBitCount(); 264cdf0e10cSrcweir // get the width of the device 265cdf0e10cSrcweir virtual long GetGraphicsWidth() const; 266cdf0e10cSrcweir 267cdf0e10cSrcweir // set the clip region to empty 268cdf0e10cSrcweir virtual void ResetClipRegion(); 269cdf0e10cSrcweir 270cdf0e10cSrcweir // set the line color to transparent (= don't draw lines) 271cdf0e10cSrcweir virtual void SetLineColor(); 272cdf0e10cSrcweir // set the line color to a specific color 273cdf0e10cSrcweir virtual void SetLineColor( SalColor nSalColor ); 274cdf0e10cSrcweir // set the fill color to transparent (= don't fill) 275cdf0e10cSrcweir virtual void SetFillColor(); 276cdf0e10cSrcweir // set the fill color to a specific color, shapes will be 277cdf0e10cSrcweir // filled accordingly 278cdf0e10cSrcweir virtual void SetFillColor( SalColor nSalColor ); 279cdf0e10cSrcweir // enable/disable XOR drawing 280cdf0e10cSrcweir virtual void SetXORMode( bool bSet, bool bInvertOnly ); 281cdf0e10cSrcweir // set line color for raster operations 282cdf0e10cSrcweir virtual void SetROPLineColor( SalROPColor nROPColor ); 283cdf0e10cSrcweir // set fill color for raster operations 284cdf0e10cSrcweir virtual void SetROPFillColor( SalROPColor nROPColor ); 285cdf0e10cSrcweir // set the text color to a specific color 286cdf0e10cSrcweir virtual void SetTextColor( SalColor nSalColor ); 287cdf0e10cSrcweir // set the font 288cdf0e10cSrcweir virtual sal_uInt16 SetFont( ImplFontSelectData*, int nFallbackLevel ); 289cdf0e10cSrcweir // get the current font's etrics 290cdf0e10cSrcweir virtual void GetFontMetric( ImplFontMetricData*, int nFallbackLevel ); 291cdf0e10cSrcweir // get kernign pairs of the current font 292cdf0e10cSrcweir // return only PairCount if (pKernPairs == NULL) 293cdf0e10cSrcweir virtual sal_uLong GetKernPairs( sal_uLong nPairs, ImplKernPairData* pKernPairs ); 294cdf0e10cSrcweir // get the repertoire of the current font 295cdf0e10cSrcweir virtual const ImplFontCharMap* GetImplFontCharMap() const; 296cdf0e10cSrcweir // graphics must fill supplied font list 297cdf0e10cSrcweir virtual void GetDevFontList( ImplDevFontList* ); 298cdf0e10cSrcweir // graphics should call ImplAddDevFontSubstitute on supplied 299cdf0e10cSrcweir // OutputDevice for all its device specific preferred font substitutions 300cdf0e10cSrcweir virtual void GetDevFontSubstList( OutputDevice* ); 301cdf0e10cSrcweir virtual bool AddTempDevFont( ImplDevFontList*, const String& rFileURL, const String& rFontName ); 302cdf0e10cSrcweir // CreateFontSubset: a method to get a subset of glyhps of a font 303cdf0e10cSrcweir // inside a new valid font file 304cdf0e10cSrcweir // returns TRUE if creation of subset was successfull 305cdf0e10cSrcweir // parameters: rToFile: contains a osl file URL to write the subset to 306cdf0e10cSrcweir // pFont: describes from which font to create a subset 307cdf0e10cSrcweir // pGlyphIDs: the glyph ids to be extracted 308cdf0e10cSrcweir // pEncoding: the character code corresponding to each glyph 309cdf0e10cSrcweir // pWidths: the advance widths of the correspoding glyphs (in PS font units) 310cdf0e10cSrcweir // nGlyphs: the number of glyphs 311cdf0e10cSrcweir // rInfo: additional outgoing information 312cdf0e10cSrcweir // implementation note: encoding 0 with glyph id 0 should be added implicitly 313cdf0e10cSrcweir // as "undefined character" 314cdf0e10cSrcweir virtual sal_Bool CreateFontSubset( const rtl::OUString& rToFile, 315cdf0e10cSrcweir const ImplFontData* pFont, 316248a599fSHerbert Dürr sal_GlyphId* pGlyphIds, 317cdf0e10cSrcweir sal_uInt8* pEncoding, 318cdf0e10cSrcweir sal_Int32* pWidths, 319cdf0e10cSrcweir int nGlyphs, 320cdf0e10cSrcweir FontSubsetInfo& rInfo // out parameter 321cdf0e10cSrcweir ); 322cdf0e10cSrcweir 323cdf0e10cSrcweir // GetFontEncodingVector: a method to get the encoding map Unicode 324cdf0e10cSrcweir // to font encoded character; this is only used for type1 fonts and 325cdf0e10cSrcweir // may return NULL in case of unknown encoding vector 326cdf0e10cSrcweir // if ppNonEncoded is set and non encoded characters (that is type1 327cdf0e10cSrcweir // glyphs with only a name) exist it is set to the corresponding 328cdf0e10cSrcweir // map for non encoded glyphs; the encoding vector contains -1 329cdf0e10cSrcweir // as encoding for these cases 330cdf0e10cSrcweir virtual const Ucs2SIntMap* GetFontEncodingVector( const ImplFontData*, const Ucs2OStrMap** ppNonEncoded ); 331cdf0e10cSrcweir 332cdf0e10cSrcweir // GetEmbedFontData: gets the font data for a font marked 333cdf0e10cSrcweir // embeddable by GetDevFontList or NULL in case of error 334cdf0e10cSrcweir // parameters: pFont: describes the font in question 335cdf0e10cSrcweir // pWidths: the widths of all glyphs from char code 0 to 255 336cdf0e10cSrcweir // pWidths MUST support at least 256 members; 337cdf0e10cSrcweir // rInfo: additional outgoing information 338cdf0e10cSrcweir // pDataLen: out parameter, contains the byte length of the returned buffer 339cdf0e10cSrcweir virtual const void* GetEmbedFontData( const ImplFontData*, 340cdf0e10cSrcweir const sal_Ucs* pUnicodes, 341cdf0e10cSrcweir sal_Int32* pWidths, 342cdf0e10cSrcweir FontSubsetInfo& rInfo, 343cdf0e10cSrcweir long* pDataLen ); 344cdf0e10cSrcweir // frees the font data again 345cdf0e10cSrcweir virtual void FreeEmbedFontData( const void* pData, long nDataLen ); 346cdf0e10cSrcweir 347cdf0e10cSrcweir virtual void GetGlyphWidths( const ImplFontData*, 348cdf0e10cSrcweir bool bVertical, 349cdf0e10cSrcweir Int32Vector& rWidths, 350cdf0e10cSrcweir Ucs2UIntMap& rUnicodeEnc ); 351cdf0e10cSrcweir 352248a599fSHerbert Dürr virtual bool GetGlyphBoundRect( sal_GlyphId, Rectangle& ); 353248a599fSHerbert Dürr virtual bool GetGlyphOutline( sal_GlyphId, basegfx::B2DPolyPolygon& ); 354cdf0e10cSrcweir 355cdf0e10cSrcweir virtual SalLayout* GetTextLayout( ImplLayoutArgs&, int nFallbackLevel ); 356cdf0e10cSrcweir virtual void DrawServerFontLayout( const ServerFontLayout& ); 357cdf0e10cSrcweir virtual bool supportsOperation( OutDevSupportType ) const; 358cdf0e10cSrcweir 359cdf0e10cSrcweir // Query the platform layer for control support 360cdf0e10cSrcweir virtual sal_Bool IsNativeControlSupported( ControlType nType, ControlPart nPart ); 361cdf0e10cSrcweir 362cdf0e10cSrcweir virtual SystemGraphicsData GetGraphicsData() const; 363cdf0e10cSrcweir virtual SystemFontData GetSysFontData( int /* nFallbacklevel */ ) const; 364cdf0e10cSrcweir 365cdf0e10cSrcweir private: 366cdf0e10cSrcweir // differences between VCL, Quartz and kHiThemeOrientation coordinate systems 367cdf0e10cSrcweir // make some graphics seem to be vertically-mirrored from a VCL perspective 368cdf0e10cSrcweir bool IsFlipped() const { return mbWindow; } 369cdf0e10cSrcweir 370cdf0e10cSrcweir void ApplyXorContext(); 371cdf0e10cSrcweir void Pattern50Fill(); 372cdf0e10cSrcweir UInt32 getState( ControlState nState ); 373cdf0e10cSrcweir UInt32 getTrackState( ControlState nState ); 374cdf0e10cSrcweir }; 375cdf0e10cSrcweir 376cdf0e10cSrcweir class XorEmulation 377cdf0e10cSrcweir { 378cdf0e10cSrcweir public: 379cdf0e10cSrcweir XorEmulation(); 380cdf0e10cSrcweir /*final*/ ~XorEmulation(); 381cdf0e10cSrcweir 382cdf0e10cSrcweir void SetTarget( int nWidth, int nHeight, int nBitmapDepth, CGContextRef, CGLayerRef ); 383cdf0e10cSrcweir bool UpdateTarget(); 384cdf0e10cSrcweir void Enable() { mbIsEnabled = true; } 385cdf0e10cSrcweir void Disable() { mbIsEnabled = false; } 386cdf0e10cSrcweir bool IsEnabled() const { return mbIsEnabled; } 387cdf0e10cSrcweir CGContextRef GetTargetContext() const { return mxTargetContext; } 388cdf0e10cSrcweir CGContextRef GetMaskContext() const { return (mbIsEnabled ? mxMaskContext : NULL); } 389cdf0e10cSrcweir 390cdf0e10cSrcweir private: 391cdf0e10cSrcweir CGLayerRef mxTargetLayer; 392cdf0e10cSrcweir CGContextRef mxTargetContext; 393cdf0e10cSrcweir CGContextRef mxMaskContext; 394cdf0e10cSrcweir CGContextRef mxTempContext; 395cdf0e10cSrcweir sal_uLong* mpMaskBuffer; 396cdf0e10cSrcweir sal_uLong* mpTempBuffer; 397cdf0e10cSrcweir int mnBufferLongs; 398cdf0e10cSrcweir bool mbIsEnabled; 399cdf0e10cSrcweir }; 400cdf0e10cSrcweir 401cdf0e10cSrcweir 402cdf0e10cSrcweir // --- some trivial inlines 403cdf0e10cSrcweir 404cdf0e10cSrcweir inline void AquaSalGraphics::RefreshRect( const CGRect& rRect ) 405cdf0e10cSrcweir { 406cdf0e10cSrcweir RefreshRect( rRect.origin.x, rRect.origin.y, rRect.size.width, rRect.size.height ); 407cdf0e10cSrcweir } 408cdf0e10cSrcweir 409cdf0e10cSrcweir inline void AquaSalGraphics::RefreshRect( const NSRect& rRect ) 410cdf0e10cSrcweir { 411cdf0e10cSrcweir RefreshRect( rRect.origin.x, rRect.origin.y, rRect.size.width, rRect.size.height ); 412cdf0e10cSrcweir } 413cdf0e10cSrcweir 414cdf0e10cSrcweir inline RGBAColor::RGBAColor( SalColor nSalColor ) 415*24a22e85SHerbert Dürr { 416*24a22e85SHerbert Dürr mfRGBA[0] = SALCOLOR_RED( nSalColor) * (1.0/255); 417*24a22e85SHerbert Dürr mfRGBA[1] = SALCOLOR_GREEN(nSalColor) * (1.0/255); 418*24a22e85SHerbert Dürr mfRGBA[2] = SALCOLOR_BLUE( nSalColor) * (1.0/255); 419*24a22e85SHerbert Dürr mfRGBA[3] = 1.0; // default to opaque 420*24a22e85SHerbert Dürr } 421cdf0e10cSrcweir 422cdf0e10cSrcweir inline RGBAColor::RGBAColor( float fRed, float fGreen, float fBlue, float fAlpha ) 423*24a22e85SHerbert Dürr { 424*24a22e85SHerbert Dürr mfRGBA[0] = fRed; 425*24a22e85SHerbert Dürr mfRGBA[1] = fGreen; 426*24a22e85SHerbert Dürr mfRGBA[2] = fBlue; 427*24a22e85SHerbert Dürr mfRGBA[3] = fAlpha; 428*24a22e85SHerbert Dürr } 429cdf0e10cSrcweir 430cdf0e10cSrcweir #endif // _SV_SALGDI_H 431*24a22e85SHerbert Dürr 432