mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-24 05:44:10 +00:00
Bug 661471. Part 6.2: Handle dynamic changes to Cleartype enabled/disabled. r=jfkthame
This commit is contained in:
parent
b7d0fa0010
commit
dca8b7c2d3
@ -772,8 +772,10 @@ nsPresContext::GetUserPreferences()
|
||||
}
|
||||
|
||||
void
|
||||
nsPresContext::AppUnitsPerDevPixelChanged()
|
||||
nsPresContext::InvalidateThebesLayers()
|
||||
{
|
||||
if (!mShell)
|
||||
return;
|
||||
nsIFrame* rootFrame = mShell->FrameManager()->GetRootFrame();
|
||||
if (rootFrame) {
|
||||
// FrameLayerBuilder caches invalidation-related values that depend on the
|
||||
@ -781,6 +783,12 @@ nsPresContext::AppUnitsPerDevPixelChanged()
|
||||
// is completely flushed.
|
||||
FrameLayerBuilder::InvalidateThebesLayersInSubtree(rootFrame);
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
nsPresContext::AppUnitsPerDevPixelChanged()
|
||||
{
|
||||
InvalidateThebesLayers();
|
||||
|
||||
mDeviceContext->FlushFontCache();
|
||||
|
||||
@ -868,6 +876,7 @@ nsPresContext::UpdateAfterPreferencesChanged()
|
||||
mShell->SetPreferenceStyleRules(PR_TRUE);
|
||||
}
|
||||
|
||||
InvalidateThebesLayers();
|
||||
mDeviceContext->FlushFontCache();
|
||||
|
||||
nsChangeHint hint = nsChangeHint(0);
|
||||
|
@ -1049,6 +1049,7 @@ protected:
|
||||
|
||||
NS_HIDDEN_(void) UpdateCharSet(const nsAFlatCString& aCharSet);
|
||||
|
||||
void InvalidateThebesLayers();
|
||||
void AppUnitsPerDevPixelChanged();
|
||||
|
||||
PRBool MayHavePaintEventListener();
|
||||
|
@ -4458,6 +4458,35 @@ nsWindow::ProcessMessageForPlugin(const MSG &aMsg,
|
||||
return PR_TRUE;
|
||||
}
|
||||
|
||||
static void ForceFontUpdate()
|
||||
{
|
||||
// update device context font cache
|
||||
// Dirty but easiest way:
|
||||
// Changing nsIPrefBranch entry which triggers callbacks
|
||||
// and flows into calling mDeviceContext->FlushFontCache()
|
||||
// to update the font cache in all the instance of Browsers
|
||||
static const char kPrefName[] = "font.internaluseonly.changed";
|
||||
PRBool fontInternalChange =
|
||||
Preferences::GetBool(kPrefName, PR_FALSE);
|
||||
Preferences::SetBool(kPrefName, !fontInternalChange);
|
||||
}
|
||||
|
||||
static PRBool CleartypeSettingChanged()
|
||||
{
|
||||
static int currentQuality = -1;
|
||||
BYTE quality = cairo_win32_get_system_text_quality();
|
||||
|
||||
if (currentQuality == quality)
|
||||
return PR_FALSE;
|
||||
|
||||
if (currentQuality < 0) {
|
||||
currentQuality = quality;
|
||||
return PR_FALSE;
|
||||
}
|
||||
currentQuality = quality;
|
||||
return PR_TRUE;
|
||||
}
|
||||
|
||||
// The main windows message processing method.
|
||||
PRBool nsWindow::ProcessMessage(UINT msg, WPARAM &wParam, LPARAM &lParam,
|
||||
LRESULT *aRetValue)
|
||||
@ -4620,15 +4649,7 @@ PRBool nsWindow::ProcessMessage(UINT msg, WPARAM &wParam, LPARAM &lParam,
|
||||
fontEnum->UpdateFontList(&didChange);
|
||||
//didChange is TRUE only if new font langGroup is added to the list.
|
||||
if (didChange) {
|
||||
// update device context font cache
|
||||
// Dirty but easiest way:
|
||||
// Changing nsIPrefBranch entry which triggers callbacks
|
||||
// and flows into calling mDeviceContext->FlushFontCache()
|
||||
// to update the font cache in all the instance of Browsers
|
||||
const char* kPrefName = "font.internaluseonly.changed";
|
||||
PRBool fontInternalChange =
|
||||
Preferences::GetBool(kPrefName, PR_FALSE);
|
||||
Preferences::SetBool(kPrefName, !fontInternalChange);
|
||||
ForceFontUpdate();
|
||||
}
|
||||
} //if (NS_SUCCEEDED(rv))
|
||||
}
|
||||
@ -4811,6 +4832,13 @@ PRBool nsWindow::ProcessMessage(UINT msg, WPARAM &wParam, LPARAM &lParam,
|
||||
break;
|
||||
|
||||
case WM_PAINT:
|
||||
if (CleartypeSettingChanged()) {
|
||||
ForceFontUpdate();
|
||||
gfxFontCache *fc = gfxFontCache::GetCache();
|
||||
if (fc) {
|
||||
fc->Flush();
|
||||
}
|
||||
}
|
||||
*aRetValue = (int) OnPaint(NULL, 0);
|
||||
result = PR_TRUE;
|
||||
break;
|
||||
|
Loading…
x
Reference in New Issue
Block a user