1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #include <basegfx/range/b2drange.hxx>
21 #include <basegfx/range/b2irange.hxx>
22 #include <basegfx/range/b2ibox.hxx>
29 /** Generic implementation of the difference set computation
32 Type to operate on. Must provide ValueType and TraitsType
35 template< class RangeType
> void doComputeSetDifference(
36 ::std::vector
< RangeType
>& o_rRanges
,
42 // special-casing the empty rect case (this will fail most
43 // of the times below, because of the DBL_MIN/MAX special
44 // values denoting emptyness in the rectangle.
47 o_rRanges
.push_back( b
);
52 o_rRanges
.push_back( a
);
56 const typename
RangeType::ValueType
ax(a
.getMinX());
57 const typename
RangeType::ValueType
ay(a
.getMinY());
58 const typename
RangeType::TraitsType::DifferenceType
aw(a
.getWidth());
59 const typename
RangeType::TraitsType::DifferenceType
ah(a
.getHeight());
60 const typename
RangeType::ValueType
bx(b
.getMinX());
61 const typename
RangeType::ValueType
by(b
.getMinY());
62 const typename
RangeType::TraitsType::DifferenceType
bw(b
.getWidth());
63 const typename
RangeType::TraitsType::DifferenceType
bh(b
.getHeight());
65 const typename
RangeType::TraitsType::DifferenceType
h0( (by
> ay
) ? by
- ay
: 0 );
66 const typename
RangeType::TraitsType::DifferenceType
h3( (by
+ bh
< ay
+ ah
) ? ay
+ ah
- by
- bh
: 0 );
67 const typename
RangeType::TraitsType::DifferenceType
w1( (bx
> ax
) ? bx
- ax
: 0 );
68 const typename
RangeType::TraitsType::DifferenceType
w2( (ax
+ aw
> bx
+ bw
) ? ax
+ aw
- bx
- bw
: 0 );
69 const typename
RangeType::TraitsType::DifferenceType
h12( (h0
+ h3
< ah
) ? ah
- h0
- h3
: 0 );
71 // TODO(E2): Use numeric_cast instead of static_cast here,
76 static_cast<typename
RangeType::ValueType
>(ax
+aw
),
77 static_cast<typename
RangeType::ValueType
>(ay
+h0
)) );
79 if (w1
> 0 && h12
> 0)
82 static_cast<typename
RangeType::ValueType
>(ay
+h0
),
83 static_cast<typename
RangeType::ValueType
>(ax
+w1
),
84 static_cast<typename
RangeType::ValueType
>(ay
+h0
+h12
)) );
86 if (w2
> 0 && h12
> 0)
88 RangeType(static_cast<typename
RangeType::ValueType
>(bx
+bw
),
89 static_cast<typename
RangeType::ValueType
>(ay
+h0
),
90 static_cast<typename
RangeType::ValueType
>(bx
+bw
+w2
),
91 static_cast<typename
RangeType::ValueType
>(ay
+h0
+h12
)) );
96 static_cast<typename
RangeType::ValueType
>(ay
+h0
+h12
),
97 static_cast<typename
RangeType::ValueType
>(ax
+aw
),
98 static_cast<typename
RangeType::ValueType
>(ay
+h0
+h12
+h3
)) );
102 ::std::vector
< B2IRange
>& computeSetDifference( ::std::vector
< B2IRange
>& o_rResult
,
103 const B2IRange
& rFirst
,
104 const B2IRange
& rSecond
)
106 doComputeSetDifference( o_rResult
, rFirst
, rSecond
);
111 ::std::vector
< B2DRange
>& computeSetDifference( ::std::vector
< B2DRange
>& o_rResult
,
112 const B2DRange
& rFirst
,
113 const B2DRange
& rSecond
)
115 doComputeSetDifference( o_rResult
, rFirst
, rSecond
);
120 } // end of namespace basegfx
122 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */