diff options
author | Jean-Francois Mauguit <jfmauguit@mac.com> | 2024-09-24 09:03:25 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-09-24 09:03:25 -0400 |
commit | bab614c421ed7ae329d26bf028c4a3b1d2450f5a (patch) | |
tree | 12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/omBrowser/graphicsObject.h | |
parent | 4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff) | |
parent | 20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff) | |
download | winamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz |
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/omBrowser/graphicsObject.h')
-rw-r--r-- | Src/omBrowser/graphicsObject.h | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/Src/omBrowser/graphicsObject.h b/Src/omBrowser/graphicsObject.h new file mode 100644 index 00000000..9ce94cf2 --- /dev/null +++ b/Src/omBrowser/graphicsObject.h @@ -0,0 +1,45 @@ +#ifndef NULLSOFT_WINAMP_UTILITY_GRAPHICS_OBJECT_HEADER +#define NULLSOFT_WINAMP_UTILITY_GRAPHICS_OBJECT_HEADER + +#if defined(_MSC_VER) && (_MSC_VER >= 1020) +#pragma once +#endif + +#include "./ifc_omgraphics.h" + + +class GraphicsObject : public ifc_omgraphics +{ +protected: + GraphicsObject(); + ~GraphicsObject(); + +public: + static HRESULT CreateInstance(GraphicsObject **instance); + +public: + /* Dispatchable */ + size_t AddRef(); + size_t Release(); + int QueryInterface(GUID interface_guid, void **object); + + /* ifc_omgraphics */ + HRESULT GetDistance(COLORREF rgb1, COLORREF rgb2, int *distance); + HRESULT GetDarker(COLORREF rgb1, COLORREF rgb2, COLORREF *result); + HRESULT BlendColor(COLORREF rgbTop, COLORREF rgbBottom, int alpha, COLORREF *result); + HRESULT Colorize(BYTE *pixels, long cx, long cy, WORD bpp, COLORREF rgbBk, COLORREF rgbFg, BOOL removeAlpha); + HRESULT BlendOnColor(HBITMAP hbmp, RECT *prcPart, BOOL premult, COLORREF rgb); + HRESULT BlendOnColor2(BYTE *pixels, int bitmapCX, int bitmapCY, long x, long y, long cx, long cy, WORD bpp, BOOL premult, COLORREF rgb); + HRESULT Premultiply(BYTE *pixels, long cx, long cy); + HRESULT AlphaBlend(HDC hdcDest, const RECT *rectDest, HDC hdcSrc, const RECT *rectSrc, BLENDFUNCTION blendFunction); + HRESULT AnimateRotation(HDC hdc, HBITMAP bitmapFrame, int frameCount, COLORREF rgbBk, BOOL fKeepSize, HBITMAP *result); + +protected: + size_t ref; + +protected: + RECVS_DISPATCH; +}; + + +#endif // NULLSOFT_WINAMP_UTILITY_GRAPHICS_OBJECT_HEADER
\ No newline at end of file |