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/Plugins/Library/ml_devices/fillRegion.cpp | |
| 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/Plugins/Library/ml_devices/fillRegion.cpp')
| -rw-r--r-- | Src/Plugins/Library/ml_devices/fillRegion.cpp | 134 |
1 files changed, 134 insertions, 0 deletions
diff --git a/Src/Plugins/Library/ml_devices/fillRegion.cpp b/Src/Plugins/Library/ml_devices/fillRegion.cpp new file mode 100644 index 00000000..68f0ee23 --- /dev/null +++ b/Src/Plugins/Library/ml_devices/fillRegion.cpp @@ -0,0 +1,134 @@ +#include "main.h" +#include "./fillRegion.h" + +static BOOL +FillRegion_TempRegionFromRect(FillRegion *region, const RECT *rect) +{ + if (NULL == region || NULL == rect) + return FALSE; + + if (NULL == region->tmp) + { + region->tmp = CreateRectRgn(rect->left, rect->top, rect->right, rect->bottom); + if (NULL == region->tmp) + return FALSE; + } + else + { + if (FALSE == SetRectRgn(region->tmp, rect->left, rect->top, rect->right, rect->bottom)) + return FALSE; + } + + return TRUE; +} + +BOOL +FillRegion_Init(FillRegion *region, const RECT *rect) +{ + if (NULL == region) + return FALSE; + + region->fill = (NULL != rect) ? + CreateRectRgn(rect->left, rect->top, rect->right, rect->bottom) : + NULL; + + region->tmp = NULL; + + if (NULL == region->fill) + return FALSE; + + return TRUE; +} + +void +FillRegion_Uninit(FillRegion *region) +{ + if (NULL != region) + { + if (NULL != region->fill) + { + DeleteObject(region->fill); + region->fill = NULL; + } + + if (NULL != region->tmp) + { + DeleteObject(region->tmp); + region->tmp = NULL; + } + } +} + +BOOL +FillRegion_ExcludeRect(FillRegion *region, const RECT *rect) +{ + if (NULL == region || NULL == rect) + return FALSE; + + return (FALSE != FillRegion_TempRegionFromRect(region, rect) && + ERROR != CombineRgn(region->fill, region->fill, region->tmp, RGN_DIFF)); +} + +BOOL +FillRegion_ExcludeRgn(FillRegion *region, HRGN rgn) +{ + if (NULL == region || NULL == rgn) + return FALSE; + + return (ERROR != CombineRgn(region->fill, region->fill, rgn, RGN_DIFF)); +} + +BOOL +FillRegion_AppendRect(FillRegion *region, const RECT *rect) +{ + if (NULL == region || NULL == rect) + return FALSE; + + return (FALSE != FillRegion_TempRegionFromRect(region, rect) && + ERROR != CombineRgn(region->fill, region->fill, region->tmp, RGN_OR)); +} + +BOOL +FillRegion_AppendRgn(FillRegion *region, HRGN rgn) +{ + if (NULL == region || NULL == rgn) + return FALSE; + + return (ERROR != CombineRgn(region->fill, region->fill, rgn, RGN_OR)); +} + +BOOL +FillRegion_BrushFill(FillRegion *region, HDC hdc, HBRUSH brush) +{ + if (NULL == region) + return FALSE; + + return FillRgn(hdc, region->fill, brush); +} + +BOOL +FillRegion_Offset(FillRegion *region, long x, long y) +{ + if (NULL == region) + return FALSE; + + return (ERROR != OffsetRgn(region->fill, x, y)); +} + +BOOL +FillRegion_SetRect(FillRegion *region, const RECT *rect) +{ + if (NULL == region || NULL == rect) + return FALSE; + + return SetRectRgn(region->fill, rect->left, rect->top, rect->right, rect->bottom); +} + +BOOL +FillRegion_SetEmpty(FillRegion *region) +{ + if (NULL == region) + return FALSE; + + return SetRectRgn(region->fill, 0, 0, 0, 0); +}
\ No newline at end of file |
