This commit is contained in:
spx 2011-10-27 00:02:40 +00:00
parent e8b9461541
commit ed2b80fee5

View File

@ -399,9 +399,18 @@ void CMeterWindow::Refresh(bool init, bool all)
// Set the window region // Set the window region
CreateRegion(true); // Clear the region CreateRegion(true); // Clear the region
if (init) ShowWindow(m_Window, SW_SHOWNOACTIVATE); UpdateTransparency(m_AlphaValue, true); // Add/Remove layered flag
Update(false); Update(false);
if (m_BlurMode == BLURMODE_NONE)
{
HideBlur();
}
else
{
ShowBlur();
}
if (m_KeepOnScreen) if (m_KeepOnScreen)
{ {
MapCoordsToScreen(m_ScreenX, m_ScreenY, m_WindowW, m_WindowH); MapCoordsToScreen(m_ScreenX, m_ScreenY, m_WindowW, m_WindowH);
@ -411,6 +420,11 @@ void CMeterWindow::Refresh(bool init, bool all)
ScreenToWindow(); ScreenToWindow();
if (all || oldZPos != m_WindowZPosition)
{
ChangeZPos(m_WindowZPosition, all);
}
// Start the timers // Start the timers
if (m_WindowUpdate >= 0) if (m_WindowUpdate >= 0)
{ {
@ -425,22 +439,6 @@ void CMeterWindow::Refresh(bool init, bool all)
throw CError(L"Unable to set timer!", __LINE__, __FILE__); throw CError(L"Unable to set timer!", __LINE__, __FILE__);
} }
UpdateTransparency(m_AlphaValue, true);
if (all || oldZPos != m_WindowZPosition)
{
ChangeZPos(m_WindowZPosition, all);
}
if (m_BlurMode == BLURMODE_NONE)
{
HideBlur();
}
else
{
ShowBlur();
}
m_Rainmeter->SetCurrentParser(NULL); m_Rainmeter->SetCurrentParser(NULL);
m_Refreshing = false; m_Refreshing = false;
@ -3006,14 +3004,7 @@ void CMeterWindow::UpdateTransparency(int alpha, bool reset)
BLENDFUNCTION blendPixelFunction= {AC_SRC_OVER, 0, alpha, AC_SRC_ALPHA}; BLENDFUNCTION blendPixelFunction= {AC_SRC_OVER, 0, alpha, AC_SRC_ALPHA};
POINT ptWindowScreenPosition = {m_ScreenX, m_ScreenY}; POINT ptWindowScreenPosition = {m_ScreenX, m_ScreenY};
POINT ptSrc = {0, 0}; POINT ptSrc = {0, 0};
SIZE szWindow = {m_WindowW, m_WindowH}; SIZE szWindow = {m_DIBSectionBufferW, m_DIBSectionBufferH};
if (szWindow.cx == 0 || szWindow.cy == 0)
{
// Set dummy size to avoid invalid state
szWindow.cx = 1;
szWindow.cy = 1;
}
HDC dcScreen = GetDC(0); HDC dcScreen = GetDC(0);
HDC dcMemory = CreateCompatibleDC(dcScreen); HDC dcMemory = CreateCompatibleDC(dcScreen);