2014-01-31 20:02:50 +04:00
|
|
|
/**
|
|
|
|
* Copyright © 2014 Thincast Technologies GmbH
|
|
|
|
* Copyright © 2014 Hardening <contact@hardening-consulting.com>
|
|
|
|
*
|
|
|
|
* Permission to use, copy, modify, distribute, and sell this software and
|
|
|
|
* its documentation for any purpose is hereby granted without fee, provided
|
|
|
|
* that the above copyright notice appear in all copies and that both that
|
|
|
|
* copyright notice and this permission notice appear in supporting
|
|
|
|
* documentation, and that the name of the copyright holders not be used in
|
|
|
|
* advertising or publicity pertaining to distribution of the software
|
|
|
|
* without specific, written prior permission. The copyright holders make
|
|
|
|
* no representations about the suitability of this software for any
|
|
|
|
* purpose. It is provided "as is" without express or implied warranty.
|
|
|
|
*
|
|
|
|
* THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS
|
|
|
|
* SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
|
|
|
* FITNESS, IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
|
|
|
* SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER
|
|
|
|
* RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF
|
|
|
|
* CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
|
|
|
|
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __REGION_H___
|
|
|
|
#define __REGION_H___
|
|
|
|
|
2014-03-29 20:37:16 +04:00
|
|
|
#include <freerdp/api.h>
|
2014-01-31 20:02:50 +04:00
|
|
|
#include <freerdp/types.h>
|
|
|
|
|
2014-07-08 06:24:17 +04:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2014-01-31 20:02:50 +04:00
|
|
|
struct _REGION16_DATA;
|
|
|
|
typedef struct _REGION16_DATA REGION16_DATA;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief
|
|
|
|
*/
|
|
|
|
struct _REGION16 {
|
|
|
|
RECTANGLE_16 extents;
|
|
|
|
REGION16_DATA *data;
|
|
|
|
};
|
|
|
|
typedef struct _REGION16 REGION16;
|
|
|
|
|
2014-09-19 06:18:58 +04:00
|
|
|
/** computes if two rectangles are equal
|
|
|
|
* @param r1 first rectangle
|
|
|
|
* @param r2 second rectangle
|
|
|
|
* @return if the two rectangles are equal
|
|
|
|
*/
|
|
|
|
FREERDP_API BOOL rectangles_equal(const RECTANGLE_16 *r1, const RECTANGLE_16 *r2);
|
|
|
|
|
2014-01-31 20:02:50 +04:00
|
|
|
/** computes if two rectangles intersect
|
|
|
|
* @param r1 first rectangle
|
|
|
|
* @param r2 second rectangle
|
|
|
|
* @return if the two rectangles intersect
|
|
|
|
*/
|
2014-03-29 20:37:16 +04:00
|
|
|
FREERDP_API BOOL rectangles_intersects(const RECTANGLE_16 *r1, const RECTANGLE_16 *r2);
|
2014-01-31 20:02:50 +04:00
|
|
|
|
|
|
|
/** computes the intersection of two rectangles
|
|
|
|
* @param r1 first rectangle
|
|
|
|
* @param r2 second rectangle
|
|
|
|
* @param dst resulting intersection
|
|
|
|
* @return if the two rectangles intersect
|
|
|
|
*/
|
2014-03-29 20:37:16 +04:00
|
|
|
FREERDP_API BOOL rectangles_intersection(const RECTANGLE_16 *r1, const RECTANGLE_16 *r2, RECTANGLE_16 *dst);
|
2014-01-31 20:02:50 +04:00
|
|
|
|
|
|
|
/** initialize a region16
|
|
|
|
* @param region the region to initialise
|
|
|
|
*/
|
2014-03-29 20:37:16 +04:00
|
|
|
FREERDP_API void region16_init(REGION16 *region);
|
2014-01-31 20:02:50 +04:00
|
|
|
|
|
|
|
/** @return the number of rectangles of this region16 */
|
2014-03-29 20:37:16 +04:00
|
|
|
FREERDP_API int region16_n_rects(const REGION16 *region);
|
2014-01-31 20:02:50 +04:00
|
|
|
|
2016-02-12 03:34:48 +03:00
|
|
|
/** returns a pointer to rectangles and the number of rectangles in this region.
|
|
|
|
* nbRects can be set to NULL if not interested in the number of rectangles.
|
2014-01-31 20:02:50 +04:00
|
|
|
* @param region the input region
|
2016-02-12 03:34:48 +03:00
|
|
|
* @param nbRects if non-NULL returns the number of rectangles
|
2014-01-31 20:02:50 +04:00
|
|
|
* @return a pointer on the rectangles
|
|
|
|
*/
|
2016-04-05 18:07:45 +03:00
|
|
|
FREERDP_API const RECTANGLE_16 *region16_rects(const REGION16 *region, UINT32 *nbRects);
|
2014-01-31 20:02:50 +04:00
|
|
|
|
|
|
|
/** @return the extents rectangle of this region */
|
2014-03-29 20:37:16 +04:00
|
|
|
FREERDP_API const RECTANGLE_16 *region16_extents(const REGION16 *region);
|
2014-01-31 20:02:50 +04:00
|
|
|
|
2014-09-11 00:27:24 +04:00
|
|
|
/** returns if the rectangle is empty
|
|
|
|
* @param rect
|
|
|
|
* @return if the rectangle is empty
|
|
|
|
*/
|
|
|
|
FREERDP_API BOOL rectangle_is_empty(const RECTANGLE_16 *rect);
|
|
|
|
|
2014-01-31 20:02:50 +04:00
|
|
|
/** returns if the region is empty
|
|
|
|
* @param region
|
|
|
|
* @return if the region is empty
|
|
|
|
*/
|
2014-03-29 20:37:16 +04:00
|
|
|
FREERDP_API BOOL region16_is_empty(const REGION16 *region);
|
2014-01-31 20:02:50 +04:00
|
|
|
|
|
|
|
/** clears the region, the region is resetted to a (0,0,0,0) region
|
|
|
|
* @param region
|
|
|
|
*/
|
2014-03-29 20:37:16 +04:00
|
|
|
FREERDP_API void region16_clear(REGION16 *region);
|
2014-01-31 20:02:50 +04:00
|
|
|
|
|
|
|
/** dumps the region on stderr
|
|
|
|
* @param region the region to dump
|
|
|
|
*/
|
2014-03-29 20:37:16 +04:00
|
|
|
FREERDP_API void region16_print(const REGION16 *region);
|
2014-01-31 20:02:50 +04:00
|
|
|
|
|
|
|
/** copies the region to another region
|
|
|
|
* @param dst destination region
|
|
|
|
* @param src source region
|
|
|
|
* @return if the operation was successful (false meaning out-of-memory)
|
|
|
|
*/
|
2014-03-29 20:37:16 +04:00
|
|
|
FREERDP_API BOOL region16_copy(REGION16 *dst, const REGION16 *src);
|
2014-01-31 20:02:50 +04:00
|
|
|
|
|
|
|
/** adds a rectangle in src and stores the resulting region in dst
|
|
|
|
* @param dst destination region
|
|
|
|
* @param src source region
|
|
|
|
* @param rect the rectangle to add
|
|
|
|
* @return if the operation was successful (false meaning out-of-memory)
|
|
|
|
*/
|
2014-03-29 20:37:16 +04:00
|
|
|
FREERDP_API BOOL region16_union_rect(REGION16 *dst, const REGION16 *src, const RECTANGLE_16 *rect);
|
2014-01-31 20:02:50 +04:00
|
|
|
|
|
|
|
/** returns if a rectangle intersects the region
|
|
|
|
* @param src the region
|
|
|
|
* @param arg2 the rectangle
|
|
|
|
* @return if region and rectangle intersect
|
|
|
|
*/
|
2014-03-29 20:37:16 +04:00
|
|
|
FREERDP_API BOOL region16_intersects_rect(const REGION16 *src, const RECTANGLE_16 *arg2);
|
2014-01-31 20:02:50 +04:00
|
|
|
|
|
|
|
/** computes the intersection between a region and a rectangle
|
|
|
|
* @param dst destination region
|
|
|
|
* @param src the source region
|
|
|
|
* @param arg2 the rectangle that intersects
|
|
|
|
* @return if the operation was successful (false meaning out-of-memory)
|
|
|
|
*/
|
2014-03-29 20:37:16 +04:00
|
|
|
FREERDP_API BOOL region16_intersect_rect(REGION16 *dst, const REGION16 *src, const RECTANGLE_16 *arg2);
|
2014-01-31 20:02:50 +04:00
|
|
|
|
|
|
|
/** release internal data associated with this region
|
|
|
|
* @param region the region to release
|
|
|
|
*/
|
2014-03-29 20:37:16 +04:00
|
|
|
FREERDP_API void region16_uninit(REGION16 *region);
|
2014-01-31 20:02:50 +04:00
|
|
|
|
2014-07-08 06:24:17 +04:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
2014-01-31 20:02:50 +04:00
|
|
|
|
|
|
|
#endif /* __REGION_H___ */
|