mirror of
				https://github.com/chibicitiberiu/rainmeter-studio.git
				synced 2024-02-24 04:33:31 +00:00 
			
		
		
		
	Additional changes to custom mouse cursors
This commit is contained in:
		| @@ -3158,7 +3158,7 @@ void CMeterWindow::HandleButtons(POINT pos, BUTTONPROC proc, bool execute) | ||||
|  | ||||
| 		if (!cursor && | ||||
| 			((*j)->HasMouseAction() || button) && | ||||
| 			(*j)->GetMouse().GetCursorType() != MOUSECURSOR_ARROW && | ||||
| 			(*j)->GetMouse().GetCursorState() && | ||||
| 			(*j)->HitTest(pos.x, pos.y)) | ||||
| 		{ | ||||
| 			cursor = (*j)->GetMouse().GetCursor(); | ||||
|   | ||||
| @@ -24,7 +24,8 @@ | ||||
|  | ||||
| CMouse::CMouse() : | ||||
| 	m_CursorType(MOUSECURSOR_HAND), | ||||
| 	m_CustomCursor() | ||||
| 	m_CustomCursor(), | ||||
| 	m_CursorState(true) | ||||
| { | ||||
| } | ||||
|  | ||||
| @@ -49,18 +50,14 @@ void CMouse::ReadOptions(CConfigParser& parser, const WCHAR* section, CMeterWind | ||||
| 	m_OverAction = parser.ReadString(section, L"MouseOverAction", L"", false); | ||||
| 	m_LeaveAction = parser.ReadString(section, L"MouseLeaveAction", L"", false); | ||||
|  | ||||
| 	const WCHAR* mouseCursor = parser.ReadString(section, L"MouseActionCursor", L"").c_str(); | ||||
| 	m_CursorState = 0!=parser.ReadInt(section, L"MouseActionCursor", meterWindow->GetMouse().GetCursorState()); | ||||
|  | ||||
| 	// For backwards compatibility | ||||
| 	int mouseCursorInt = (*mouseCursor == L'(') ? CConfigParser::ParseInt(mouseCursor, 0) : -1; | ||||
|  | ||||
| 	if (mouseCursorInt == 1 || | ||||
| 		_wcsicmp(mouseCursor, L"HAND") == 0) | ||||
| 	const WCHAR* mouseCursor = parser.ReadString(section, L"MouseActionCursorName", L"").c_str(); | ||||
| 	if (_wcsicmp(mouseCursor, L"HAND") == 0) | ||||
| 	{ | ||||
| 		m_CursorType = MOUSECURSOR_HAND; | ||||
| 	} | ||||
| 	else if (mouseCursorInt == 0 || | ||||
| 		_wcsicmp(mouseCursor, L"ARROW") == 0) | ||||
| 	else if (_wcsicmp(mouseCursor, L"ARROW") == 0) | ||||
| 	{ | ||||
| 		m_CursorType = MOUSECURSOR_ARROW; | ||||
| 	} | ||||
| @@ -91,10 +88,10 @@ void CMouse::ReadOptions(CConfigParser& parser, const WCHAR* section, CMeterWind | ||||
| 	else | ||||
| 	{ | ||||
| 		// Inherit from [Rainmeter]. | ||||
| 		m_CursorType = meterWindow->GetMouse().m_CursorType; | ||||
| 		m_CursorType = meterWindow->GetMouse().GetCursorType(); | ||||
| 		if (m_CursorType == MOUSECURSOR_CUSTOM) | ||||
| 		{ | ||||
| 			mouseCursor = meterWindow->GetParser().ReadString(L"Rainmeter", L"MouseActionCursor", L"").c_str();; | ||||
| 			mouseCursor = meterWindow->GetParser().ReadString(L"Rainmeter", L"MouseActionCursorName", L"").c_str(); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
|   | ||||
| @@ -56,6 +56,7 @@ public: | ||||
|  | ||||
| 	MOUSECURSOR GetCursorType() const { return m_CursorType; } | ||||
| 	HCURSOR GetCursor() const; | ||||
| 	bool GetCursorState() const {return m_CursorState; } | ||||
|  | ||||
| 	void DestroyCustomCursor(); | ||||
|  | ||||
| @@ -88,6 +89,7 @@ private: | ||||
|  | ||||
| 	MOUSECURSOR m_CursorType; | ||||
| 	HCURSOR m_CustomCursor; | ||||
| 	bool m_CursorState; | ||||
| }; | ||||
|  | ||||
| #endif | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Brian
					Brian