mirror of
https://github.com/chibicitiberiu/rainmeter-studio.git
synced 2024-02-24 04:33:31 +00:00
Minor code tweaks & cleanups.
This commit is contained in:
parent
02be3ed29c
commit
dbc021d299
@ -27,9 +27,38 @@ using namespace Gdiplus;
|
|||||||
std::map<std::wstring, Gdiplus::FontFamily*> CMeterString::c_FontFamilies;
|
std::map<std::wstring, Gdiplus::FontFamily*> CMeterString::c_FontFamilies;
|
||||||
std::map<std::wstring, Gdiplus::Font*> CMeterString::c_Fonts;
|
std::map<std::wstring, Gdiplus::Font*> CMeterString::c_Fonts;
|
||||||
|
|
||||||
std::wstring StringToUpper(std::wstring str);
|
void StringToUpper(std::wstring& str)
|
||||||
std::wstring StringToLower(std::wstring str);
|
{
|
||||||
std::wstring StringToProper(std::wstring str);
|
//change each element of the string to upper case
|
||||||
|
std::transform(str.begin(), str.end(), str.begin(), ::towupper);
|
||||||
|
}
|
||||||
|
|
||||||
|
void StringToLower(std::wstring& str)
|
||||||
|
{
|
||||||
|
//change each element of the string to lower case
|
||||||
|
std::transform(str.begin(), str.end(), str.begin(), ::towlower);
|
||||||
|
}
|
||||||
|
|
||||||
|
void StringToProper(std::wstring& str)
|
||||||
|
{
|
||||||
|
//change each element of the string to lower case
|
||||||
|
if (!str.empty())
|
||||||
|
{
|
||||||
|
str[0] = towupper(str[0]);
|
||||||
|
|
||||||
|
for (size_t i = 1; i < str.length(); ++i)
|
||||||
|
{
|
||||||
|
if (str[i-1] == L' ')
|
||||||
|
{
|
||||||
|
str[i] = towupper(str[i]);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
str[i] = towlower(str[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** CMeterString
|
** CMeterString
|
||||||
@ -443,22 +472,21 @@ bool CMeterString::Update()
|
|||||||
|
|
||||||
m_String += tmpText;
|
m_String += tmpText;
|
||||||
}
|
}
|
||||||
m_String += m_Postfix;
|
if (!m_Postfix.empty()) m_String += m_Postfix;
|
||||||
|
|
||||||
switch(m_textCase)
|
switch(m_textCase)
|
||||||
{
|
{
|
||||||
case TEXTCASE_UPPER:
|
case TEXTCASE_UPPER:
|
||||||
m_String = StringToUpper(m_String);
|
StringToUpper(m_String);
|
||||||
break;
|
break;
|
||||||
case TEXTCASE_LOWER:
|
case TEXTCASE_LOWER:
|
||||||
m_String = StringToLower(m_String);
|
StringToLower(m_String);
|
||||||
break;
|
break;
|
||||||
case TEXTCASE_PROPER:
|
case TEXTCASE_PROPER:
|
||||||
m_String = StringToProper(m_String);
|
StringToProper(m_String);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (!m_DimensionsDefined)
|
if (!m_DimensionsDefined)
|
||||||
{
|
{
|
||||||
// Calculate the text size
|
// Calculate the text size
|
||||||
@ -530,58 +558,72 @@ bool CMeterString::DrawString(Graphics& graphics, RectF* rect)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (m_ClipString)
|
||||||
|
{
|
||||||
|
stringFormat.SetTrimming(StringTrimmingEllipsisCharacter);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
stringFormat.SetTrimming(StringTrimmingNone);
|
||||||
|
stringFormat.SetFormatFlags(StringFormatFlagsNoClip | StringFormatFlagsNoWrap);
|
||||||
|
}
|
||||||
|
|
||||||
|
CharacterRange range(0, (int)m_String.length());
|
||||||
|
stringFormat.SetMeasurableCharacterRanges(1, &range);
|
||||||
|
|
||||||
REAL x = (REAL)GetX();
|
REAL x = (REAL)GetX();
|
||||||
REAL y = (REAL)GetY();
|
REAL y = (REAL)GetY();
|
||||||
|
|
||||||
if (rect)
|
if (rect)
|
||||||
{
|
{
|
||||||
PointF pos(x, y);
|
PointF pos(x, y);
|
||||||
graphics.MeasureString(m_String.c_str(), -1, m_Font, pos, rect);
|
graphics.MeasureString(m_String.c_str(), (int)m_String.length(), m_Font, pos, &stringFormat, rect);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
RectF rc((REAL)x, (REAL)y, (REAL)m_W, (REAL)m_H);
|
RectF rc((REAL)x, (REAL)y, (REAL)m_W, (REAL)m_H);
|
||||||
|
|
||||||
if (m_ClipString)
|
if (m_Angle != 0.0f)
|
||||||
{
|
{
|
||||||
stringFormat.SetTrimming(StringTrimmingEllipsisCharacter);
|
REAL angle = m_Angle * 180.0f / 3.14159265f; // Convert to degrees
|
||||||
}
|
graphics.TranslateTransform((Gdiplus::REAL)CMeter::GetX(), y);
|
||||||
else
|
graphics.RotateTransform(angle);
|
||||||
{
|
graphics.TranslateTransform(-(Gdiplus::REAL)CMeter::GetX(), -y);
|
||||||
stringFormat.SetTrimming(StringTrimmingNone);
|
|
||||||
stringFormat.SetFormatFlags(StringFormatFlagsNoClip | StringFormatFlagsNoWrap);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
REAL angle = m_Angle * 180.0f / 3.14159265f; // Convert to degrees
|
switch (m_Effect)
|
||||||
graphics.TranslateTransform((Gdiplus::REAL)CMeter::GetX(), y);
|
|
||||||
graphics.RotateTransform(angle);
|
|
||||||
graphics.TranslateTransform(-(Gdiplus::REAL)CMeter::GetX(), -y);
|
|
||||||
|
|
||||||
if (m_Effect == EFFECT_SHADOW)
|
|
||||||
{
|
{
|
||||||
SolidBrush solidBrush(m_EffectColor);
|
case EFFECT_SHADOW:
|
||||||
RectF rcEffect(rc);
|
{
|
||||||
rcEffect.Offset(1, 1);
|
SolidBrush solidBrush(m_EffectColor);
|
||||||
graphics.DrawString(m_String.c_str(), -1, m_Font, rcEffect, &stringFormat, &solidBrush);
|
RectF rcEffect(rc);
|
||||||
}
|
rcEffect.Offset(1, 1);
|
||||||
else if (m_Effect == EFFECT_BORDER)
|
graphics.DrawString(m_String.c_str(), (int)m_String.length(), m_Font, rcEffect, &stringFormat, &solidBrush);
|
||||||
{
|
break;
|
||||||
SolidBrush solidBrush(m_EffectColor);
|
}
|
||||||
RectF rcEffect(rc);
|
case EFFECT_BORDER:
|
||||||
rcEffect.Offset(0, 1);
|
{
|
||||||
graphics.DrawString(m_String.c_str(), -1, m_Font, rcEffect, &stringFormat, &solidBrush);
|
SolidBrush solidBrush(m_EffectColor);
|
||||||
rcEffect.Offset(1, -1);
|
RectF rcEffect(rc);
|
||||||
graphics.DrawString(m_String.c_str(), -1, m_Font, rcEffect, &stringFormat, &solidBrush);
|
rcEffect.Offset(0, 1);
|
||||||
rcEffect.Offset(-1, -1);
|
graphics.DrawString(m_String.c_str(), (int)m_String.length(), m_Font, rcEffect, &stringFormat, &solidBrush);
|
||||||
graphics.DrawString(m_String.c_str(), -1, m_Font, rcEffect, &stringFormat, &solidBrush);
|
rcEffect.Offset(1, -1);
|
||||||
rcEffect.Offset(-1, 1);
|
graphics.DrawString(m_String.c_str(), (int)m_String.length(), m_Font, rcEffect, &stringFormat, &solidBrush);
|
||||||
graphics.DrawString(m_String.c_str(), -1, m_Font, rcEffect, &stringFormat, &solidBrush);
|
rcEffect.Offset(-1, -1);
|
||||||
|
graphics.DrawString(m_String.c_str(), (int)m_String.length(), m_Font, rcEffect, &stringFormat, &solidBrush);
|
||||||
|
rcEffect.Offset(-1, 1);
|
||||||
|
graphics.DrawString(m_String.c_str(), (int)m_String.length(), m_Font, rcEffect, &stringFormat, &solidBrush);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
SolidBrush solidBrush(m_Color);
|
SolidBrush solidBrush(m_Color);
|
||||||
graphics.DrawString(m_String.c_str(), -1, m_Font, rc, &stringFormat, &solidBrush);
|
graphics.DrawString(m_String.c_str(), (int)m_String.length(), m_Font, rc, &stringFormat, &solidBrush);
|
||||||
|
|
||||||
graphics.ResetTransform();
|
if (m_Angle != 0.0f)
|
||||||
|
{
|
||||||
|
graphics.ResetTransform();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
@ -666,59 +708,6 @@ std::wstring CMeterString::FontPropertiesToString(FontFamily* fontFamily, REAL s
|
|||||||
return stream.str();
|
return stream.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
** FontPropertiesToString
|
|
||||||
**
|
|
||||||
** Static helper to convert font properties to a string so it can be used as a key for the cache map.
|
|
||||||
**
|
|
||||||
*/
|
|
||||||
std::wstring StringToUpper(std::wstring str)
|
|
||||||
{
|
|
||||||
//change each element of the string to upper case
|
|
||||||
for(unsigned int i = 0; i < str.length(); ++i)
|
|
||||||
{
|
|
||||||
str[i] = toupper( str[i] );
|
|
||||||
}
|
|
||||||
|
|
||||||
return str; //return the converted string
|
|
||||||
}
|
|
||||||
|
|
||||||
std::wstring StringToLower(std::wstring str)
|
|
||||||
{
|
|
||||||
//change each element of the string to lower case
|
|
||||||
for(unsigned int i = 0; i < str.length(); ++i)
|
|
||||||
{
|
|
||||||
str[i] = tolower(str[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return str;//return the converted string
|
|
||||||
}
|
|
||||||
|
|
||||||
std::wstring StringToProper(std::wstring str)
|
|
||||||
{
|
|
||||||
//change each element of the string to lower case
|
|
||||||
for(unsigned int i = 0; i < str.length(); ++i)
|
|
||||||
{
|
|
||||||
if(i == 0)
|
|
||||||
{
|
|
||||||
str[i] = toupper( str[i] );
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if(str[i-1] == ' ')
|
|
||||||
{
|
|
||||||
str[i] = toupper(str[i]);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
str[i] = tolower(str[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return str;//return the converted string
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** EnumerateInstalledFontFamilies
|
** EnumerateInstalledFontFamilies
|
||||||
**
|
**
|
||||||
|
@ -124,8 +124,6 @@ CMeterWindow::CMeterWindow(std::wstring& path, std::wstring& config, std::wstrin
|
|||||||
m_SkinName = config;
|
m_SkinName = config;
|
||||||
m_SkinIniFile = iniFile;
|
m_SkinIniFile = iniFile;
|
||||||
|
|
||||||
m_User32Library = GetModuleHandle(L"user32.dll");
|
|
||||||
|
|
||||||
m_UpdateCounter = 0;
|
m_UpdateCounter = 0;
|
||||||
m_FontCollection = NULL;
|
m_FontCollection = NULL;
|
||||||
|
|
||||||
@ -2123,8 +2121,6 @@ bool CMeterWindow::ResizeWindow(bool reset)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Reset size (this is calculated below)
|
// Reset size (this is calculated below)
|
||||||
m_WindowW = 0;
|
|
||||||
m_WindowH = 0;
|
|
||||||
|
|
||||||
if (m_Background)
|
if (m_Background)
|
||||||
{
|
{
|
||||||
@ -2145,11 +2141,13 @@ bool CMeterWindow::ResizeWindow(bool reset)
|
|||||||
m_Background = NULL;
|
m_Background = NULL;
|
||||||
m_BackgroundSize.cx = 0;
|
m_BackgroundSize.cx = 0;
|
||||||
m_BackgroundSize.cy = 0;
|
m_BackgroundSize.cy = 0;
|
||||||
}
|
|
||||||
|
|
||||||
// Calculate the window dimensions
|
m_WindowW = 0;
|
||||||
if(m_Background)
|
m_WindowH = 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
|
// Calculate the window dimensions
|
||||||
m_BackgroundSize.cx = m_Background->GetWidth();
|
m_BackgroundSize.cx = m_Background->GetWidth();
|
||||||
m_BackgroundSize.cy = m_Background->GetHeight();
|
m_BackgroundSize.cy = m_Background->GetHeight();
|
||||||
|
|
||||||
@ -2546,9 +2544,6 @@ void CMeterWindow::UpdateTransparency(int alpha, bool reset)
|
|||||||
SetWindowLong(m_Window, GWL_EXSTYLE, style | WS_EX_LAYERED);
|
SetWindowLong(m_Window, GWL_EXSTYLE, style | WS_EX_LAYERED);
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef BOOL (WINAPI * FPUPDATELAYEREDWINDOW)(HWND hWnd, HDC hdcDst, POINT *pptDst, SIZE *psize, HDC hdcSrc, POINT *pptSrc, COLORREF crKey, BLENDFUNCTION *pblend, DWORD dwFlags);
|
|
||||||
FPUPDATELAYEREDWINDOW UpdateLayeredWindow = (FPUPDATELAYEREDWINDOW)GetProcAddress(m_User32Library, "UpdateLayeredWindow");
|
|
||||||
|
|
||||||
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};
|
||||||
|
@ -276,7 +276,6 @@ private:
|
|||||||
SIZE m_BackgroundSize;
|
SIZE m_BackgroundSize;
|
||||||
|
|
||||||
HWND m_Window; // Handle to the Rainmeter window
|
HWND m_Window; // Handle to the Rainmeter window
|
||||||
HINSTANCE m_User32Library;
|
|
||||||
BOOL m_ChildWindow;
|
BOOL m_ChildWindow;
|
||||||
|
|
||||||
std::wstring m_RightMouseDownAction; // Action to run when right mouse is pressed
|
std::wstring m_RightMouseDownAction; // Action to run when right mouse is pressed
|
||||||
|
Loading…
x
Reference in New Issue
Block a user