From 20d28e80a5c861a9d5f449ea911ab75b4f37ad0d Mon Sep 17 00:00:00 2001 From: Jef Date: Tue, 24 Sep 2024 14:54:57 +0200 Subject: Initial community commit --- Src/Winamp/VideoOSD.h | 53 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 53 insertions(+) create mode 100644 Src/Winamp/VideoOSD.h (limited to 'Src/Winamp/VideoOSD.h') diff --git a/Src/Winamp/VideoOSD.h b/Src/Winamp/VideoOSD.h new file mode 100644 index 00000000..fdc55041 --- /dev/null +++ b/Src/Winamp/VideoOSD.h @@ -0,0 +1,53 @@ +#ifndef NULLSOFT_VIDEOOSDH +#define NULLSOFT_VIDEOOSDH + +/* Video On Screen Display */ +#include + +#define NUM_WIDGETS 11 + +class IVideoOSD +{ +public: + IVideoOSD(); + ~IVideoOSD(); + void SetParent(HWND _parent) + { + parent=_parent; + } + bool Showing(); + bool Ready(); + void Show(); + void Hide(); + void Draw(); + int GetBarHeight(); + bool Mouse(int x, int y, WPARAM wParam, bool moving); // return true if we need to close because of this + + int ctrlrects_ready; + + virtual bool MouseDown(int x, int y, WPARAM wParam) {return false;}; + virtual bool MouseMove(int x, int y, WPARAM wParam) {return false;}; + virtual bool MouseUp(int x, int y, WPARAM wParam) {return false;}; + +protected: + HWND parent; +private: + bool CloseHitTest(int x, int y); + void HitTest(int x, int y, int dragging); + int osdLastClickItem; + + int osdMemBMW; // width of memory bitmap + int osdMemBMH; // height of memory bitmap + int osdLastMouseX; // for WM_MOUSEMOVE thresholding, so osd isn't spastic + int osdLastMouseY; // for WM_MOUSEMOVE thresholding, so osd isn't spastic + RECT ctrlrect[NUM_WIDGETS]; // relative to [i.e. (0,0) is] upper left corner of the black strip @ the bottom + RECT ctrlrect_all; // relative to [i.e. (0,0) is] upper left corner of the black strip @ the bottom + + bool show_osd; + + static void CALLBACK TimerCallback(HWND hwnd, UINT uMsg, UINT_PTR idEvent, DWORD dwTime); + int ignore_mousemove_count; + int last_close_height, last_close_width; +}; + +#endif \ No newline at end of file -- cgit