1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski #ifndef INCLUDED_SLIDESHOW_HYPERLINKAREA_HXX
25*b1cdbd2cSJim Jagielski #define INCLUDED_SLIDESHOW_HYPERLINKAREA_HXX
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski #include <boost/shared_ptr.hpp>
28*b1cdbd2cSJim Jagielski #include <vector>
29*b1cdbd2cSJim Jagielski #include <utility>
30*b1cdbd2cSJim Jagielski 
31*b1cdbd2cSJim Jagielski namespace rtl {
32*b1cdbd2cSJim Jagielski     class OUString;
33*b1cdbd2cSJim Jagielski }
34*b1cdbd2cSJim Jagielski namespace basegfx {
35*b1cdbd2cSJim Jagielski     class B2DRange;
36*b1cdbd2cSJim Jagielski }
37*b1cdbd2cSJim Jagielski 
38*b1cdbd2cSJim Jagielski /* Definition of HyperlinkArea interface */
39*b1cdbd2cSJim Jagielski 
40*b1cdbd2cSJim Jagielski namespace slideshow
41*b1cdbd2cSJim Jagielski {
42*b1cdbd2cSJim Jagielski     namespace internal
43*b1cdbd2cSJim Jagielski     {
44*b1cdbd2cSJim Jagielski         /** HyperlinkArea interface
45*b1cdbd2cSJim Jagielski 
46*b1cdbd2cSJim Jagielski             Implementers of this interface provide information for
47*b1cdbd2cSJim Jagielski             hyperlink sensitive areas.
48*b1cdbd2cSJim Jagielski          */
49*b1cdbd2cSJim Jagielski         class HyperlinkArea
50*b1cdbd2cSJim Jagielski         {
51*b1cdbd2cSJim Jagielski         public:
52*b1cdbd2cSJim Jagielski             typedef std::pair< ::basegfx::B2DRange,
53*b1cdbd2cSJim Jagielski                                ::rtl::OUString >    HyperlinkRegion;
54*b1cdbd2cSJim Jagielski 
55*b1cdbd2cSJim Jagielski             typedef std::vector<HyperlinkRegion>    HyperlinkRegions;
56*b1cdbd2cSJim Jagielski 
57*b1cdbd2cSJim Jagielski             /** Request hyperlink-sensitive areas.
58*b1cdbd2cSJim Jagielski 
59*b1cdbd2cSJim Jagielski 				@return a vector of hyperlink-sensitive areas, plus
60*b1cdbd2cSJim Jagielski 				the URI associated to them.
61*b1cdbd2cSJim Jagielski              */
62*b1cdbd2cSJim Jagielski             virtual HyperlinkRegions getHyperlinkRegions() const = 0;
63*b1cdbd2cSJim Jagielski 
64*b1cdbd2cSJim Jagielski             /** Retrieve priority of link area
65*b1cdbd2cSJim Jagielski 
66*b1cdbd2cSJim Jagielski                 @return the priority of the link area. Link areas with
67*b1cdbd2cSJim Jagielski                 higher priority will receive hyperlink clicks in favor
68*b1cdbd2cSJim Jagielski                 of areas with less priority, if they cover the same
69*b1cdbd2cSJim Jagielski                 place on screen.
70*b1cdbd2cSJim Jagielski              */
71*b1cdbd2cSJim Jagielski             virtual double getHyperlinkPriority() const = 0;
72*b1cdbd2cSJim Jagielski 
73*b1cdbd2cSJim Jagielski             /** Functor struct, for area ordering
74*b1cdbd2cSJim Jagielski 
75*b1cdbd2cSJim Jagielski             	This defines a strict weak ordering of areas, sort key
76*b1cdbd2cSJim Jagielski             	is the object ptr value. Most typical use is for
77*b1cdbd2cSJim Jagielski             	associative containers holding areas.
78*b1cdbd2cSJim Jagielski              */
79*b1cdbd2cSJim Jagielski             struct lessThanArea
80*b1cdbd2cSJim Jagielski             {
81*b1cdbd2cSJim Jagielski                 // make functor adaptable (to boost::bind)
82*b1cdbd2cSJim Jagielski                 typedef bool result_type;
83*b1cdbd2cSJim Jagielski 
operator ()slideshow::internal::HyperlinkArea::lessThanArea84*b1cdbd2cSJim Jagielski                 bool operator()(const boost::shared_ptr< HyperlinkArea >& rLHS,
85*b1cdbd2cSJim Jagielski                                 const boost::shared_ptr< HyperlinkArea >& rRHS) const
86*b1cdbd2cSJim Jagielski                 {
87*b1cdbd2cSJim Jagielski                     const double nPrioL( rLHS->getHyperlinkPriority() );
88*b1cdbd2cSJim Jagielski                     const double nPrioR( rRHS->getHyperlinkPriority() );
89*b1cdbd2cSJim Jagielski 
90*b1cdbd2cSJim Jagielski                     // if prios are equal, tie-break on ptr value
91*b1cdbd2cSJim Jagielski                     return nPrioL == nPrioR ? rLHS.get() < rRHS.get() : nPrioL < nPrioR;
92*b1cdbd2cSJim Jagielski                 }
93*b1cdbd2cSJim Jagielski             };
94*b1cdbd2cSJim Jagielski        };
95*b1cdbd2cSJim Jagielski 
96*b1cdbd2cSJim Jagielski         typedef boost::shared_ptr< HyperlinkArea > HyperlinkAreaSharedPtr;
97*b1cdbd2cSJim Jagielski     }
98*b1cdbd2cSJim Jagielski }
99*b1cdbd2cSJim Jagielski 
100*b1cdbd2cSJim Jagielski #endif /* INCLUDED_SLIDESHOW_HYPERLINKAREA_HXX */
101