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>
27 /** Generic implementation of the difference set computation
30 Type to operate on. Must provide ValueType and TraitsType
33 template< class RangeType
> void doComputeSetDifference(
34 std::vector
< RangeType
>& o_rRanges
,
40 // special-casing the empty rect case (this will fail most
41 // of the times below, because of the DBL_MIN/MAX special
42 // values denoting emptiness in the rectangle.
45 o_rRanges
.push_back( b
);
50 o_rRanges
.push_back( a
);
54 const typename
RangeType::ValueType
ax(a
.getMinX());
55 const typename
RangeType::ValueType
ay(a
.getMinY());
56 const typename
RangeType::TraitsType::DifferenceType
aw(a
.getWidth());
57 const typename
RangeType::TraitsType::DifferenceType
ah(a
.getHeight());
58 const typename
RangeType::ValueType
bx(b
.getMinX());
59 const typename
RangeType::ValueType
by(b
.getMinY());
60 const typename
RangeType::TraitsType::DifferenceType
bw(b
.getWidth());
61 const typename
RangeType::TraitsType::DifferenceType
bh(b
.getHeight());
63 const typename
RangeType::TraitsType::DifferenceType
h0( (by
> ay
) ? by
- ay
: 0 );
64 const typename
RangeType::TraitsType::DifferenceType
h3( (by
+ bh
< ay
+ ah
) ? ay
+ ah
- by
- bh
: 0 );
65 const typename
RangeType::TraitsType::DifferenceType
w1( (bx
> ax
) ? bx
- ax
: 0 );
66 const typename
RangeType::TraitsType::DifferenceType
w2( (ax
+ aw
> bx
+ bw
) ? ax
+ aw
- bx
- bw
: 0 );
67 const typename
RangeType::TraitsType::DifferenceType
h12( (h0
+ h3
< ah
) ? ah
- h0
- h3
: 0 );
69 // TODO(E2): Use numeric_cast instead of static_cast here,
74 static_cast<typename
RangeType::ValueType
>(ax
+aw
),
75 static_cast<typename
RangeType::ValueType
>(ay
+h0
)) );
77 if (w1
> 0 && h12
> 0)
80 static_cast<typename
RangeType::ValueType
>(ay
+h0
),
81 static_cast<typename
RangeType::ValueType
>(ax
+w1
),
82 static_cast<typename
RangeType::ValueType
>(ay
+h0
+h12
)) );
84 if (w2
> 0 && h12
> 0)
86 RangeType(static_cast<typename
RangeType::ValueType
>(bx
+bw
),
87 static_cast<typename
RangeType::ValueType
>(ay
+h0
),
88 static_cast<typename
RangeType::ValueType
>(bx
+bw
+w2
),
89 static_cast<typename
RangeType::ValueType
>(ay
+h0
+h12
)) );
94 static_cast<typename
RangeType::ValueType
>(ay
+h0
+h12
),
95 static_cast<typename
RangeType::ValueType
>(ax
+aw
),
96 static_cast<typename
RangeType::ValueType
>(ay
+h0
+h12
+h3
)) );
100 std::vector
< B2IRange
>& computeSetDifference( std::vector
< B2IRange
>& o_rResult
,
101 const B2IRange
& rFirst
,
102 const B2IRange
& rSecond
)
104 doComputeSetDifference( o_rResult
, rFirst
, rSecond
);
109 std::vector
< B2DRange
>& computeSetDifference( std::vector
< B2DRange
>& o_rResult
,
110 const B2DRange
& rFirst
,
111 const B2DRange
& rSecond
)
113 doComputeSetDifference( o_rResult
, rFirst
, rSecond
);
118 } // end of namespace basegfx
120 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */