|
|
@ -394,8 +394,10 @@ void plDynSurfaceWriter::IInit( void ) |
|
|
|
|
|
|
|
|
|
|
|
void plDynSurfaceWriter::Reset( void ) |
|
|
|
void plDynSurfaceWriter::Reset( void ) |
|
|
|
{ |
|
|
|
{ |
|
|
|
|
|
|
|
#if HS_BUILD_FOR_WIN32 |
|
|
|
fRGBSurface.Release(); |
|
|
|
fRGBSurface.Release(); |
|
|
|
fAlphaSurface.Release(); |
|
|
|
fAlphaSurface.Release(); |
|
|
|
|
|
|
|
#endif |
|
|
|
fCurrTarget = nil; |
|
|
|
fCurrTarget = nil; |
|
|
|
fFlushed = true; |
|
|
|
fFlushed = true; |
|
|
|
|
|
|
|
|
|
|
@ -484,6 +486,7 @@ void plDynSurfaceWriter::SwitchTarget( plDynamicTextMap *target ) |
|
|
|
|
|
|
|
|
|
|
|
// Make sure our surfaces fit
|
|
|
|
// Make sure our surfaces fit
|
|
|
|
bool hadToAllocate = false; |
|
|
|
bool hadToAllocate = false; |
|
|
|
|
|
|
|
#if HS_BUILD_FOR_WIN32 |
|
|
|
if( target != nil ) |
|
|
|
if( target != nil ) |
|
|
|
{ |
|
|
|
{ |
|
|
|
if( !fRGBSurface.WillFit( (UInt16)(target->GetWidth()), (UInt16)(target->GetHeight()) ) ) |
|
|
|
if( !fRGBSurface.WillFit( (UInt16)(target->GetWidth()), (UInt16)(target->GetHeight()) ) ) |
|
|
@ -507,6 +510,7 @@ void plDynSurfaceWriter::SwitchTarget( plDynamicTextMap *target ) |
|
|
|
fAlphaSurface.Release(); |
|
|
|
fAlphaSurface.Release(); |
|
|
|
hadToAllocate = true; |
|
|
|
hadToAllocate = true; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
if( hadToAllocate ) |
|
|
|
if( hadToAllocate ) |
|
|
|
{ |
|
|
|
{ |
|
|
@ -533,6 +537,7 @@ void plDynSurfaceWriter::IEnsureSurfaceUpdated( void ) |
|
|
|
{ |
|
|
|
{ |
|
|
|
UInt32 *srcBits = (UInt32 *)fCurrTarget->GetImage(); |
|
|
|
UInt32 *srcBits = (UInt32 *)fCurrTarget->GetImage(); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#if HS_BUILD_FOR_WIN32 |
|
|
|
// Are we merging in the alpha bits?
|
|
|
|
// Are we merging in the alpha bits?
|
|
|
|
if( fFlags & kSupportAlpha ) |
|
|
|
if( fFlags & kSupportAlpha ) |
|
|
|
{ |
|
|
|
{ |
|
|
@ -568,12 +573,14 @@ void plDynSurfaceWriter::IEnsureSurfaceUpdated( void ) |
|
|
|
destBits += fRGBSurface.fWidth; |
|
|
|
destBits += fRGBSurface.fWidth; |
|
|
|
} |
|
|
|
} |
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
// ALSO, we need to re-update our settings, since different targets
|
|
|
|
// ALSO, we need to re-update our settings, since different targets
|
|
|
|
// can have different fonts or justifications
|
|
|
|
// can have different fonts or justifications
|
|
|
|
ISetFont( fCurrTarget->GetFontFace(), fCurrTarget->GetFontSize(), 0/*fCurrTarget->GetWriterFontFlags()*/, fCurrTarget->GetFontAARGB() ); |
|
|
|
ISetFont( fCurrTarget->GetFontFace(), fCurrTarget->GetFontSize(), 0/*fCurrTarget->GetWriterFontFlags()*/, fCurrTarget->GetFontAARGB() ); |
|
|
|
SetJustify( (Justify)fCurrTarget->GetFontJustify() ); |
|
|
|
SetJustify( (Justify)fCurrTarget->GetFontJustify() ); |
|
|
|
ISetTextColor( fCurrTarget->GetFontColor(), fCurrTarget->GetFontBlockRGB() ); |
|
|
|
hsColorRGBA col = fCurrTarget->GetFontColor(); |
|
|
|
|
|
|
|
ISetTextColor( col, fCurrTarget->GetFontBlockRGB() ); |
|
|
|
|
|
|
|
|
|
|
|
fFlushed = false; |
|
|
|
fFlushed = false; |
|
|
|
} |
|
|
|
} |
|
|
@ -584,11 +591,13 @@ hsBool plDynSurfaceWriter::IsValid( void ) const |
|
|
|
if( fCurrTarget == nil ) |
|
|
|
if( fCurrTarget == nil ) |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#if HS_BUILD_FOR_WIN32 |
|
|
|
if( fRGBSurface.fDC == nil || fRGBSurface.fBitmap == nil ) |
|
|
|
if( fRGBSurface.fDC == nil || fRGBSurface.fBitmap == nil ) |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
|
|
|
|
|
|
|
|
if( ( fFlags & kSupportAlpha ) && ( fAlphaSurface.fDC == nil || fAlphaSurface.fBitmap == nil ) ) |
|
|
|
if( ( fFlags & kSupportAlpha ) && ( fAlphaSurface.fDC == nil || fAlphaSurface.fBitmap == nil ) ) |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
return true; |
|
|
|
return true; |
|
|
|
} |
|
|
|
} |
|
|
@ -696,6 +705,7 @@ void plDynSurfaceWriter::ISetFont( const char *face, UInt16 size, UInt8 fontF |
|
|
|
{ |
|
|
|
{ |
|
|
|
fFlags = ( fFlags & ~kFontShadowed ) | ( fontFlags & kFontShadowed ); |
|
|
|
fFlags = ( fFlags & ~kFontShadowed ) | ( fontFlags & kFontShadowed ); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#if HS_BUILD_FOR_WIN32 |
|
|
|
if( !fRGBSurface.FontMatches( face, size, fontFlags, antiAliasRGB ) ) |
|
|
|
if( !fRGBSurface.FontMatches( face, size, fontFlags, antiAliasRGB ) ) |
|
|
|
fRGBSurface.SetFont( face, size, fontFlags, antiAliasRGB ); |
|
|
|
fRGBSurface.SetFont( face, size, fontFlags, antiAliasRGB ); |
|
|
|
|
|
|
|
|
|
|
@ -704,6 +714,7 @@ void plDynSurfaceWriter::ISetFont( const char *face, UInt16 size, UInt8 fontF |
|
|
|
if( !fAlphaSurface.FontMatches( face, size, fontFlags, !antiAliasRGB ) ) |
|
|
|
if( !fAlphaSurface.FontMatches( face, size, fontFlags, !antiAliasRGB ) ) |
|
|
|
fAlphaSurface.SetFont( face, size, fontFlags, !antiAliasRGB ); |
|
|
|
fAlphaSurface.SetFont( face, size, fontFlags, !antiAliasRGB ); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
#endif |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
//// SetTextColor /////////////////////////////////////////////////////////////
|
|
|
|
//// SetTextColor /////////////////////////////////////////////////////////////
|
|
|
@ -770,7 +781,8 @@ void plDynSurfaceWriter::IRefreshOSJustify( void ) |
|
|
|
if( !IsValid() ) |
|
|
|
if( !IsValid() ) |
|
|
|
return; |
|
|
|
return; |
|
|
|
|
|
|
|
|
|
|
|
UINT justMode; |
|
|
|
#if HS_BUILD_FOR_WIN32 |
|
|
|
|
|
|
|
UInt32 justMode; |
|
|
|
switch( fJustify ) |
|
|
|
switch( fJustify ) |
|
|
|
{ |
|
|
|
{ |
|
|
|
case kLeftJustify: justMode = TA_LEFT; break; |
|
|
|
case kLeftJustify: justMode = TA_LEFT; break; |
|
|
@ -780,6 +792,7 @@ void plDynSurfaceWriter::IRefreshOSJustify( void ) |
|
|
|
::SetTextAlign( fRGBSurface.fDC, justMode ); |
|
|
|
::SetTextAlign( fRGBSurface.fDC, justMode ); |
|
|
|
if( fFlags & kSupportAlpha ) |
|
|
|
if( fFlags & kSupportAlpha ) |
|
|
|
::SetTextAlign( fAlphaSurface.fDC, justMode ); |
|
|
|
::SetTextAlign( fAlphaSurface.fDC, justMode ); |
|
|
|
|
|
|
|
#endif |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
//// DrawString ///////////////////////////////////////////////////////////////
|
|
|
|
//// DrawString ///////////////////////////////////////////////////////////////
|
|
|
@ -1122,4 +1135,4 @@ void plDynSurfaceWriter::DrawClippedImage( UInt16 x, UInt16 y, plMipmap *imag |
|
|
|
::DeleteObject( brush ); |
|
|
|
::DeleteObject( brush ); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
*/ |
|
|
|
*/ |
|
|
|