summaryrefslogtreecommitdiff
path: root/vcl
diff options
context:
space:
mode:
Diffstat (limited to 'vcl')
-rw-r--r--vcl/win/source/gdi/salgdi3.cxx184
1 files changed, 92 insertions, 92 deletions
diff --git a/vcl/win/source/gdi/salgdi3.cxx b/vcl/win/source/gdi/salgdi3.cxx
index da4f4e071564..69a05ee23741 100644
--- a/vcl/win/source/gdi/salgdi3.cxx
+++ b/vcl/win/source/gdi/salgdi3.cxx
@@ -155,17 +155,17 @@ ImplFontAttrCache::ImplFontAttrCache( const String& rFileNameURL, const String&
aFontFileURL = read_lenPrefixed_uInt8s_ToOUString<sal_uInt16>(aCacheFile, RTL_TEXTENCODING_UTF8);
if( !aFontFileURL.Len() )
break;
- aDFA.maName = read_lenPrefixed_uInt8s_ToOUString<sal_uInt16>(aCacheFile, RTL_TEXTENCODING_UTF8);
+ aDFA.SetFamilyName(read_lenPrefixed_uInt8s_ToOUString<sal_uInt16>(aCacheFile, RTL_TEXTENCODING_UTF8));
short n;
- aCacheFile >> n; aDFA.meWeight = static_cast<FontWeight>(n);
- aCacheFile >> n; aDFA.meItalic = static_cast<FontItalic>(n);
- aCacheFile >> n; aDFA.mePitch = static_cast<FontPitch>(n);
- aCacheFile >> n; aDFA.meWidthType = static_cast<FontWidth>(n);
- aCacheFile >> n; aDFA.meFamily = static_cast<FontFamily>(n);
- aCacheFile >> n; aDFA.mbSymbolFlag = (n != 0);
+ aCacheFile >> n; aDFA.SetWeight(static_cast<FontWeight>(n));
+ aCacheFile >> n; aDFA.SetItalic(static_cast<FontItalic>(n));
+ aCacheFile >> n; aDFA.SetPitch(static_cast<FontPitch>(n));
+ aCacheFile >> n; aDFA.SetWidthType(static_cast<FontWidth>(n));
+ aCacheFile >> n; aDFA.SetFamilyType(static_cast<FontFamily>(n));
+ aCacheFile >> n; aDFA.SetSymbolFlag(n != 0);
- aCacheFile.ReadByteStringLine( aDFA.maStyleName, RTL_TEXTENCODING_UTF8 );
+ aCacheFile.ReadByteStringLine( aDFA.GetStyleName(), RTL_TEXTENCODING_UTF8 );
aFontAttributes[ aFontFileURL ] = aDFA;
}
@@ -188,16 +188,16 @@ ImplFontAttrCache::~ImplFontAttrCache()
const String rFontFileURL( (*aIter).first );
const ImplDevFontAttributes& rDFA( (*aIter).second );
write_lenPrefixed_uInt8s_FromOUString<sal_uInt16>(aCacheFile, rFontFileURL, RTL_TEXTENCODING_UTF8);
- write_lenPrefixed_uInt8s_FromOUString<sal_uInt16>(aCacheFile, rDFA.maName, RTL_TEXTENCODING_UTF8);
+ write_lenPrefixed_uInt8s_FromOUString<sal_uInt16>(aCacheFile, rDFA.GetFamilyName(), RTL_TEXTENCODING_UTF8);
- aCacheFile << static_cast<short>(rDFA.meWeight);
- aCacheFile << static_cast<short>(rDFA.meItalic);
- aCacheFile << static_cast<short>(rDFA.mePitch);
- aCacheFile << static_cast<short>(rDFA.meWidthType);
- aCacheFile << static_cast<short>(rDFA.meFamily);
- aCacheFile << static_cast<short>(rDFA.mbSymbolFlag != false);
+ aCacheFile << static_cast<short>(rDFA.GetWeight());
+ aCacheFile << static_cast<short>(rDFA.GetSlant());
+ aCacheFile << static_cast<short>(rDFA.GetPitch());
+ aCacheFile << static_cast<short>(rDFA.GetWidthType());
+ aCacheFile << static_cast<short>(rDFA.GetFamilyType());
+ aCacheFile << static_cast<short>(rDFA.IsSymbolFont() != false);
- write_lenPrefixed_uInt8s_FromOUString<sal_uInt16>(aCacheFile, rDFA.maStyleName, RTL_TEXTENCODING_UTF8);
+ write_lenPrefixed_uInt8s_FromOUString<sal_uInt16>(aCacheFile, rDFA.GetStyleName(), RTL_TEXTENCODING_UTF8);
++aIter;
}
@@ -230,7 +230,7 @@ ImplDevFontAttributes ImplFontAttrCache::GetFontAttr( const String& rFontFileNam
void ImplFontAttrCache::AddFontAttr( const String& rFontFileName, const ImplDevFontAttributes& rDFA )
{
DBG_ASSERT( rFontFileName.Len() && rDFA.maName.Len(), "ImplFontNameCache::AddFontName - invalid data!" );
- if ( rFontFileName.Len() && rDFA.maName.Len() )
+ if ( rFontFileName.Len() && rDFA.GetFamilyName().Len() )
{
aFontAttributes.insert( FontAttrMap::value_type( OptimizeURL( rFontFileName ), rDFA ) );
bModified = TRUE;
@@ -574,8 +574,8 @@ bool WinGlyphFallbackSubstititution::FindFontSubstitute( FontSelectPattern& rFon
// are the missing characters symbols?
pDevFont = pDevFontList->ImplFindByAttributes( IMPL_FONT_ATTR_SYMBOL,
- rFontSelData.meWeight, rFontSelData.meWidthType,
- rFontSelData.meItalic, rFontSelData.maSearchName );
+ rFontSelData.GetWeight(), rFontSelData.GetWidthType(),
+ rFontSelData.GetSlant(), rFontSelData.maSearchName );
if( pDevFont )
{
const PhysicalFontFace* pFace = pDevFont->FindBestFontFace( rFontSelData );
@@ -599,7 +599,7 @@ bool WinGlyphFallbackSubstititution::FindFontSubstitute( FontSelectPattern& rFon
const PhysicalFontFace* pFace = pTestFontList->Get( i );
if( !HasMissingChars( pFace, rMissingChars ) )
continue;
- rFontSelData.maSearchName = pFace->maName;
+ rFontSelData.maSearchName = pFace->GetFamilyName();
return true;
}
@@ -821,15 +821,15 @@ static ImplDevFontAttributes WinFont2DevFontAttributes( const ENUMLOGFONTEXA& rE
const LOGFONTA rLogFont = rEnumFont.elfLogFont;
// get font face attributes
- aDFA.meFamily = ImplFamilyToSal( rLogFont.lfPitchAndFamily );
- aDFA.meWidthType = WIDTH_DONTKNOW;
- aDFA.meWeight = ImplWeightToSal( rLogFont.lfWeight );
- aDFA.meItalic = (rLogFont.lfItalic) ? ITALIC_NORMAL : ITALIC_NONE;
- aDFA.mePitch = ImplLogPitchToSal( rLogFont.lfPitchAndFamily );
- aDFA.mbSymbolFlag = (rLogFont.lfCharSet == SYMBOL_CHARSET);
+ aDFA.SetFamilyType(ImplFamilyToSal( rLogFont.lfPitchAndFamily ));
+ aDFA.SetWidthType(WIDTH_DONTKNOW);
+ aDFA.SetWeight(ImplWeightToSal( rLogFont.lfWeight ));
+ aDFA.SetItalic((rLogFont.lfItalic) ? ITALIC_NORMAL : ITALIC_NONE);
+ aDFA.SetPitch(ImplLogPitchToSal( rLogFont.lfPitchAndFamily ));
+ aDFA.SetSymbolFlag(rLogFont.lfCharSet == SYMBOL_CHARSET);
// get the font face name
- aDFA.maName = ImplSalGetUniString( rLogFont.lfFaceName );
+ aDFA.SetFamilyName(ImplSalGetUniString( rLogFont.lfFaceName ));
// use the face's style name only if it looks reasonable
const char* pStyleName = (const char*)rEnumFont.elfStyle;
@@ -839,7 +839,7 @@ static ImplDevFontAttributes WinFont2DevFontAttributes( const ENUMLOGFONTEXA& rE
if( (0x00 < *p) && (*p < 0x20) )
break;
if( p < pEnd )
- aDFA.maStyleName = ImplSalGetUniString( pStyleName );
+ aDFA.SetStyleName(ImplSalGetUniString( pStyleName ));
// get device specific font attributes
aDFA.mbOrientation = (nFontType & RASTER_FONTTYPE) == 0;
@@ -869,16 +869,16 @@ static ImplDevFontAttributes WinFont2DevFontAttributes( const ENUMLOGFONTEXA& rE
// #i38665# prefer Type1 versions of the standard postscript fonts
if( aDFA.mbEmbeddable )
{
- if( aDFA.maName.EqualsAscii( "AvantGarde" )
- || aDFA.maName.EqualsAscii( "Bookman" )
- || aDFA.maName.EqualsAscii( "Courier" )
- || aDFA.maName.EqualsAscii( "Helvetica" )
- || aDFA.maName.EqualsAscii( "NewCenturySchlbk" )
- || aDFA.maName.EqualsAscii( "Palatino" )
- || aDFA.maName.EqualsAscii( "Symbol" )
- || aDFA.maName.EqualsAscii( "Times" )
- || aDFA.maName.EqualsAscii( "ZapfChancery" )
- || aDFA.maName.EqualsAscii( "ZapfDingbats" ) )
+ if( aDFA.GetFamilyName().EqualsAscii( "AvantGarde" )
+ || aDFA.GetFamilyName().EqualsAscii( "Bookman" )
+ || aDFA.GetFamilyName().EqualsAscii( "Courier" )
+ || aDFA.GetFamilyName().EqualsAscii( "Helvetica" )
+ || aDFA.GetFamilyName().EqualsAscii( "NewCenturySchlbk" )
+ || aDFA.GetFamilyName().EqualsAscii( "Palatino" )
+ || aDFA.GetFamilyName().EqualsAscii( "Symbol" )
+ || aDFA.GetFamilyName().EqualsAscii( "Times" )
+ || aDFA.GetFamilyName().EqualsAscii( "ZapfChancery" )
+ || aDFA.GetFamilyName().EqualsAscii( "ZapfDingbats" ) )
aDFA.mnQuality += 500;
}
@@ -896,15 +896,15 @@ static ImplDevFontAttributes WinFont2DevFontAttributes( const ENUMLOGFONTEXW& rE
const LOGFONTW rLogFont = rEnumFont.elfLogFont;
// get font face attributes
- aDFA.meFamily = ImplFamilyToSal( rLogFont.lfPitchAndFamily );
- aDFA.meWidthType = WIDTH_DONTKNOW;
- aDFA.meWeight = ImplWeightToSal( rLogFont.lfWeight );
- aDFA.meItalic = (rLogFont.lfItalic) ? ITALIC_NORMAL : ITALIC_NONE;
- aDFA.mePitch = ImplLogPitchToSal( rLogFont.lfPitchAndFamily );
- aDFA.mbSymbolFlag = (rLogFont.lfCharSet == SYMBOL_CHARSET);
+ aDFA.SetFamilyType(ImplFamilyToSal( rLogFont.lfPitchAndFamily ));
+ aDFA.SetWidthType(WIDTH_DONTKNOW);
+ aDFA.SetWeight(ImplWeightToSal( rLogFont.lfWeight ));
+ aDFA.SetItalic((rLogFont.lfItalic) ? ITALIC_NORMAL : ITALIC_NONE);
+ aDFA.SetPitch(ImplLogPitchToSal( rLogFont.lfPitchAndFamily ));
+ aDFA.SetSymbolFlag(rLogFont.lfCharSet == SYMBOL_CHARSET);
// get the font face name
- aDFA.maName = reinterpret_cast<const sal_Unicode*>(rLogFont.lfFaceName);
+ aDFA.SetFamilyName(reinterpret_cast<const sal_Unicode*>(rLogFont.lfFaceName));
// use the face's style name only if it looks reasonable
const wchar_t* pStyleName = rEnumFont.elfStyle;
@@ -914,7 +914,7 @@ static ImplDevFontAttributes WinFont2DevFontAttributes( const ENUMLOGFONTEXW& rE
if( *p < 0x0020 )
break;
if( p < pEnd )
- aDFA.maStyleName = reinterpret_cast<const sal_Unicode*>(pStyleName);
+ aDFA.SetStyleName(reinterpret_cast<const sal_Unicode*>(pStyleName));
// get device specific font attributes
aDFA.mbOrientation = (nFontType & RASTER_FONTTYPE) == 0;
@@ -944,16 +944,16 @@ static ImplDevFontAttributes WinFont2DevFontAttributes( const ENUMLOGFONTEXW& rE
// #i38665# prefer Type1 versions of the standard postscript fonts
if( aDFA.mbEmbeddable )
{
- if( aDFA.maName.EqualsAscii( "AvantGarde" )
- || aDFA.maName.EqualsAscii( "Bookman" )
- || aDFA.maName.EqualsAscii( "Courier" )
- || aDFA.maName.EqualsAscii( "Helvetica" )
- || aDFA.maName.EqualsAscii( "NewCenturySchlbk" )
- || aDFA.maName.EqualsAscii( "Palatino" )
- || aDFA.maName.EqualsAscii( "Symbol" )
- || aDFA.maName.EqualsAscii( "Times" )
- || aDFA.maName.EqualsAscii( "ZapfChancery" )
- || aDFA.maName.EqualsAscii( "ZapfDingbats" ) )
+ if( aDFA.GetFamilyName().EqualsAscii( "AvantGarde" )
+ || aDFA.GetFamilyName().EqualsAscii( "Bookman" )
+ || aDFA.GetFamilyName().EqualsAscii( "Courier" )
+ || aDFA.GetFamilyName().EqualsAscii( "Helvetica" )
+ || aDFA.GetFamilyName().EqualsAscii( "NewCenturySchlbk" )
+ || aDFA.GetFamilyName().EqualsAscii( "Palatino" )
+ || aDFA.GetFamilyName().EqualsAscii( "Symbol" )
+ || aDFA.GetFamilyName().EqualsAscii( "Times" )
+ || aDFA.GetFamilyName().EqualsAscii( "ZapfChancery" )
+ || aDFA.GetFamilyName().EqualsAscii( "ZapfDingbats" ) )
aDFA.mnQuality += 500;
}
@@ -1457,9 +1457,9 @@ void ImplGetLogFontFromFontSelect( HDC hDC,
{
UniString aName;
if ( pFont->mpFontData )
- aName = pFont->mpFontData->maName;
+ aName = pFont->mpFontData->GetFamilyName();
else
- aName = pFont->maName.GetToken( 0 );
+ aName = pFont->GetFamilyName().GetToken( 0 );
UINT nNameLen = aName.Len();
if ( nNameLen > (sizeof( rLogFont.lfFaceName )/sizeof( wchar_t ))-1 )
@@ -1470,8 +1470,8 @@ void ImplGetLogFontFromFontSelect( HDC hDC,
if( !pFont->mpFontData )
{
rLogFont.lfCharSet = pFont->IsSymbolFont() ? SYMBOL_CHARSET : DEFAULT_CHARSET;
- rLogFont.lfPitchAndFamily = ImplPitchToWin( pFont->mePitch )
- | ImplFamilyToWin( pFont->meFamily );
+ rLogFont.lfPitchAndFamily = ImplPitchToWin( pFont->GetPitch() )
+ | ImplFamilyToWin( pFont->GetFamilyType() );
}
else
{
@@ -1480,12 +1480,12 @@ void ImplGetLogFontFromFontSelect( HDC hDC,
rLogFont.lfPitchAndFamily = pWinFontData->GetPitchAndFamily();
}
- rLogFont.lfWeight = ImplWeightToWin( pFont->meWeight );
+ rLogFont.lfWeight = ImplWeightToWin( pFont->GetWeight() );
rLogFont.lfHeight = (LONG)-pFont->mnHeight;
rLogFont.lfWidth = (LONG)pFont->mnWidth;
rLogFont.lfUnderline = 0;
rLogFont.lfStrikeOut = 0;
- rLogFont.lfItalic = (pFont->meItalic) != ITALIC_NONE;
+ rLogFont.lfItalic = (pFont->GetSlant()) != ITALIC_NONE;
rLogFont.lfEscapement = pFont->mnOrientation;
rLogFont.lfOrientation = rLogFont.lfEscapement;
rLogFont.lfClipPrecision = CLIP_DEFAULT_PRECIS;
@@ -1679,7 +1679,7 @@ void WinSalGraphics::GetFontMetric( ImplFontMetricData* pMetric, int nFallbackLe
wchar_t aFaceName[LF_FACESIZE+60];
if( ::GetTextFaceW( mhDC, sizeof(aFaceName)/sizeof(wchar_t), aFaceName ) )
- pMetric->maName = reinterpret_cast<const sal_Unicode*>(aFaceName);
+ pMetric->SetFamilyName(reinterpret_cast<const sal_Unicode*>(aFaceName));
// get the font metric
TEXTMETRICA aWinMetric;
@@ -1690,11 +1690,11 @@ void WinSalGraphics::GetFontMetric( ImplFontMetricData* pMetric, int nFallbackLe
return;
// device independent font attributes
- pMetric->meFamily = ImplFamilyToSal( aWinMetric.tmPitchAndFamily );
- pMetric->mbSymbolFlag = (aWinMetric.tmCharSet == SYMBOL_CHARSET);
- pMetric->meWeight = ImplWeightToSal( aWinMetric.tmWeight );
- pMetric->mePitch = ImplMetricPitchToSal( aWinMetric.tmPitchAndFamily );
- pMetric->meItalic = aWinMetric.tmItalic ? ITALIC_NORMAL : ITALIC_NONE;
+ pMetric->SetFamilyType(ImplFamilyToSal( aWinMetric.tmPitchAndFamily ));
+ pMetric->SetSymbolFlag(aWinMetric.tmCharSet == SYMBOL_CHARSET);
+ pMetric->SetWeight(ImplWeightToSal( aWinMetric.tmWeight ));
+ pMetric->SetPitch(ImplMetricPitchToSal( aWinMetric.tmPitchAndFamily ));
+ pMetric->SetItalic(aWinMetric.tmItalic ? ITALIC_NORMAL : ITALIC_NONE);
pMetric->mnSlant = 0;
// device dependend font attributes
@@ -2037,11 +2037,11 @@ static bool ImplGetFontAttrFromFile( const String& rFontFileURL,
// TODO: use GetTTGlobalFontInfo() to access the font directly
rDFA.mnQuality = 1000;
rDFA.mbDevice = true;
- rDFA.meFamily = FAMILY_DONTKNOW;
- rDFA.meWidthType = WIDTH_DONTKNOW;
- rDFA.meWeight = WEIGHT_DONTKNOW;
- rDFA.meItalic = ITALIC_DONTKNOW;
- rDFA.mePitch = PITCH_DONTKNOW;
+ rDFA.SetFamilyType(FAMILY_DONTKNOW);
+ rDFA.SetWidthType(WIDTH_DONTKNOW);
+ rDFA.SetWeight(WEIGHT_DONTKNOW);
+ rDFA.SetItalic(ITALIC_DONTKNOW);
+ rDFA.SetPitch(PITCH_DONTKNOW);
rDFA.mbSubsettable= true;
rDFA.mbEmbeddable = false;
@@ -2086,30 +2086,30 @@ static bool ImplGetFontAttrFromFile( const String& rFontFileURL,
return false;
// convert byte strings to unicode
- rDFA.maName = String( aBuffer + nNameOfs, osl_getThreadTextEncoding() );
- rDFA.maStyleName = String( aBuffer + nStyleOfs, osl_getThreadTextEncoding() );
+ rDFA.SetFamilyName(String( aBuffer + nNameOfs, osl_getThreadTextEncoding() ));
+ rDFA.SetStyleName(String( aBuffer + nStyleOfs, osl_getThreadTextEncoding() ));
// byte offset 0x4C7: OS2_fsSelection
const char nFSS = aBuffer[ 0x4C7 ];
if( nFSS & 0x01 ) // italic
- rDFA.meItalic = ITALIC_NORMAL;
+ rDFA.SetItalic(ITALIC_NORMAL);
//if( nFSS & 0x20 ) // bold
// rDFA.meWeight = WEIGHT_BOLD;
if( nFSS & 0x40 ) // regular
{
- rDFA.meWeight = WEIGHT_NORMAL;
- rDFA.meItalic = ITALIC_NONE;
+ rDFA.SetWeight(WEIGHT_NORMAL);
+ rDFA.SetItalic(ITALIC_NONE);
}
// byte offsets 0x4D7/0x4D8: wingdi's FW_WEIGHT
int nWinWeight = (aBuffer[0x4D7] & 0xFF) + ((aBuffer[0x4D8] & 0xFF) << 8);
- rDFA.meWeight = ImplWeightToSal( nWinWeight );
+ rDFA.SetWeight(ImplWeightToSal( nWinWeight ));
- rDFA.mbSymbolFlag = false; // TODO
- rDFA.mePitch = PITCH_DONTKNOW; // TODO
+ rDFA.SetSymbolFlag(false); // TODO
+ rDFA.SetPitch(PITCH_DONTKNOW); // TODO
// byte offset 0x4DE: pitch&family
- rDFA.meFamily = ImplFamilyToSal( aBuffer[0x4DE] );
+ rDFA.SetFamilyType(ImplFamilyToSal( aBuffer[0x4DE] ));
// byte offsets 0x4C8/0x4C9: emunits
// byte offsets 0x4CE/0x4CF: winascent
@@ -2128,7 +2128,7 @@ bool WinSalGraphics::AddTempDevFont( ImplDevFontList* pFontList,
RTL_LOGFILE_TRACE1( "WinSalGraphics::AddTempDevFont(): %s", rtl::OUStringToOString( rFontFileURL, RTL_TEXTENCODING_UTF8 ).getStr() );
ImplDevFontAttributes aDFA;
- aDFA.maName = rFontName;
+ aDFA.SetFamilyName(rFontName);
aDFA.mnQuality = 1000;
aDFA.mbDevice = true;
@@ -2137,14 +2137,14 @@ bool WinSalGraphics::AddTempDevFont( ImplDevFontList* pFontList,
aDFA = mpFontAttrCache->GetFontAttr( rFontFileURL );
// Retrieve font name from font resource
- if( !aDFA.maName.Len() )
+ if( !aDFA.GetFamilyName().Len() )
{
ImplGetFontAttrFromFile( rFontFileURL, aDFA );
- if( mpFontAttrCache && aDFA.maName.Len() )
+ if( mpFontAttrCache && aDFA.GetFamilyName().Len() )
mpFontAttrCache->AddFontAttr( rFontFileURL, aDFA );
}
- if ( !aDFA.maName.Len() )
+ if ( !aDFA.GetFamilyName().Len() )
return false;
// remember temp font for cleanup later
@@ -2154,12 +2154,12 @@ bool WinSalGraphics::AddTempDevFont( ImplDevFontList* pFontList,
UINT nPreferedCharSet = DEFAULT_CHARSET;
// create matching FontData struct
- aDFA.mbSymbolFlag = false; // TODO: how to know it without accessing the font?
- aDFA.meFamily = FAMILY_DONTKNOW;
- aDFA.meWidthType = WIDTH_DONTKNOW;
- aDFA.meWeight = WEIGHT_DONTKNOW;
- aDFA.meItalic = ITALIC_DONTKNOW;
- aDFA.mePitch = PITCH_DONTKNOW;
+ aDFA.SetSymbolFlag(false); // TODO: how to know it without accessing the font?
+ aDFA.SetFamilyType(FAMILY_DONTKNOW);
+ aDFA.SetWidthType(WIDTH_DONTKNOW);
+ aDFA.SetWeight(WEIGHT_DONTKNOW);
+ aDFA.SetItalic(ITALIC_DONTKNOW);
+ aDFA.SetPitch(PITCH_DONTKNOW);
aDFA.mbSubsettable= true;
aDFA.mbEmbeddable = false;