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/vid_gdi+.h | 44 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 Src/Winamp/vid_gdi+.h (limited to 'Src/Winamp/vid_gdi+.h') diff --git a/Src/Winamp/vid_gdi+.h b/Src/Winamp/vid_gdi+.h new file mode 100644 index 00000000..449f87c3 --- /dev/null +++ b/Src/Winamp/vid_gdi+.h @@ -0,0 +1,44 @@ +#ifndef _VID_GDIPLUS_H_ +#define _VID_GDIPLUS_H_ + +#include +#include +#include "VideoOutputChild.h" + +using namespace Gdiplus; + +class GDIPVideoOutput : public VideoRenderer { +public: + GDIPVideoOutput(); + virtual ~GDIPVideoOutput(); + virtual int create(HWND parent, VideoAspectAdjuster *_adjuster, int w, int h, unsigned int type, int flipit, double aspectratio); //return 1 if ok + virtual int needChange(); //return 1 if need to renegociate video output + virtual int onPaint(HWND hwnd) { return 0; } //return 1 if override + virtual void displayFrame(const char *buf, int size, int time); + virtual void close(); // hides any output of the video + virtual void timerCallback(); + virtual void drawSubtitle(SubsItem *item) { subs=item; } + virtual void resetSubtitle() { subs=NULL; } + virtual void setVFlip(int on) { flip=on; } + virtual void Refresh(); + +protected: + bool FillFrame(Bitmap *frame, void *buf); + + unsigned int type, w, h, flip, winw, winh; + Graphics * graphics; // on screen canvas + Graphics * graphicsback; // off screen canvas + Bitmap * frame; + HWND parent; + int needschange; + VideoAspectAdjuster *adjuster; + RECT lastrect; + HDC backdc; + void SetupGraphics(); + ULONG_PTR gdiplusToken; + SubsItem *subs; +}; + +extern GDIPVideoOutput gdiplusVideo; + +#endif // _VID_GDIPLUS_H_ -- cgit