diff options
author | Jef <jef@targetspot.com> | 2024-09-24 08:54:57 -0400 |
---|---|---|
committer | Jef <jef@targetspot.com> | 2024-09-24 08:54:57 -0400 |
commit | 20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (patch) | |
tree | 12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/Winamp/VideoOutput.h | |
parent | 537bcbc86291b32fc04ae4133ce4d7cac8ebe9a7 (diff) | |
download | winamp-20d28e80a5c861a9d5f449ea911ab75b4f37ad0d.tar.gz |
Initial community commit
Diffstat (limited to 'Src/Winamp/VideoOutput.h')
-rw-r--r-- | Src/Winamp/VideoOutput.h | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/Src/Winamp/VideoOutput.h b/Src/Winamp/VideoOutput.h new file mode 100644 index 00000000..d50faa36 --- /dev/null +++ b/Src/Winamp/VideoOutput.h @@ -0,0 +1,97 @@ +#ifndef NULLSOFT_VIDEOOUTPUTH +#define NULLSOFT_VIDEOOUTPUTH + +extern "C" { +#include "main.h" // would rather not do this. +}; +#include <ddraw.h> + +#include "../nu/AutoLock.h" + +#include "VideoOSD.h" +#include "VideoAspectAdjuster.h" +#include "vid_d3d.h" + +class VideoRenderer; + +extern IVideoOSD *posd; + +#define VIDEO_OPEN_ + +#define SHOW_STREAM_TITLE_AT_TOP 1 +void ResizeVideoWindowToCurrent(); +void updateTrackSubmenu(); +using namespace Nullsoft::Utility; +class VideoOutput : public IVideoOutput, public VideoAspectAdjuster +{ +public: + VideoOutput(HWND parent_hwnd = NULL, int initxpos = CW_USEDEFAULT, int initypos = CW_USEDEFAULT); + ~VideoOutput(); + int open(int w, int h, int vflip, double aspectratio, unsigned int fmt); + void close(); + void draw(void *frame); + void drawSubtitle(SubsItem *item); + void showStatusMsg(const char *text); + void notifyBufferState(int bufferstate); /* 0-255*/ + int get_latency(); + void setcallback(LRESULT (*msgcallback)(void *token, HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam), void *token) { m_msgcallback_tok = token; m_msgcallback = msgcallback; } + void fullscreen(); + void remove_fullscreen(); + int is_fullscreen(); + void adjustAspect(RECT &rd); + INT_PTR extended(INT_PTR param1, INT_PTR param2, INT_PTR param3); + int isVideoPlaying() { return m_opened; } + DWORD GetWidthHeightDWORD() { return width | (height << 16); } + ITrackSelector *getTrackSelector() { return m_tracksel; } + void SetVideoPosition(int x, int y, int width, int height); + HWND getHwnd() { return video_hwnd; } + + void mainthread_Create(); + +private: + void UpdateText(const wchar_t *videoInfo); + + int openUser(int w, int h, int vflip, double aspectratio, unsigned int fmt); + void LoadLogo(); + void OpenVideoSize(int newWidth, int newHeight, double newAspect); + VideoRenderer *FindBestRenderer(); + void PaintLogo(int bufferState); + void DrawLogo(HDC canvas, RECT *canvas_size); + void resetSubtitle(); + void UpdateVideoSize(int newWidth, int newHeight, double aspect = 1.0, int zoom = ID_VIDEOWND_ZOOM100); + bool is_fs, fs_has_resized; + unsigned int last_fullscreen_exit_time; + LRESULT WindowProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam); + static int class_refcnt; + static LRESULT CALLBACK WndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam); + HWND video_hwnd; + double aspect; + int width, height; + unsigned int type; + + + RECT oldfsrect; // the old window rect, BEFORE fullscreen mode was entered + RECT lastfsrect; // the most recent bounding rect when in fullscreen mode + int m_bufferstate; + SubsItem *curSubtitle; + LRESULT (*m_msgcallback)(void *token, HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam); + void *m_msgcallback_tok; + Direct3DVideoOutput *m_video_output; + char *m_statusmsg; + bool m_need_change, m_ignore_change; + bool m_opened; + HBITMAP m_logo; + int m_logo_w, m_logo_h; + int m_lastbufinvalid; + HWND fs_reparented; + HRGN fs_reparented_rgn; + ITrackSelector *m_tracksel; + LockGuard guard, textGuard; + int clickx, clicky; + RGBQUAD *video_palette; +// IVideoOSD osd; + bool userVideo; + bool video_created; +}; + +#endif |