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/Plugins/Library/ml_devices/fillRegion.cpp | 134 ++++++++++++++++++++++++++ 1 file changed, 134 insertions(+) create mode 100644 Src/Plugins/Library/ml_devices/fillRegion.cpp (limited to 'Src/Plugins/Library/ml_devices/fillRegion.cpp') 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 -- cgit