1 /**************************************************************
2  *
3  * Licensed to the Apache Software Foundation (ASF) under one
4  * or more contributor license agreements.  See the NOTICE file
5  * distributed with this work for additional information
6  * regarding copyright ownership.  The ASF licenses this file
7  * to you under the Apache License, Version 2.0 (the
8  * "License"); you may not use this file except in compliance
9  * with the License.  You may obtain a copy of the License at
10  *
11  *   http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing,
14  * software distributed under the License is distributed on an
15  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16  * KIND, either express or implied.  See the License for the
17  * specific language governing permissions and limitations
18  * under the License.
19  *
20  *************************************************************/
21 
22 
23 #ifndef _ANCHOREDOBJECTPOSITION_HXX
24 #define _ANCHOREDOBJECTPOSITION_HXX
25 
26 #include <swtypes.hxx>
27 // OD 2004-03-16 #i11860#
28 #include <frame.hxx>
29 
30 class SdrObject;
31 class SwFrm;
32 class SwFlyFrm;
33 class SwContact;
34 class SwFrmFmt;
35 class SwRect;
36 class SvxLRSpaceItem;
37 class SvxULSpaceItem;
38 class SwFmtHoriOrient;
39 // OD 2004-03-23 #i26701#
40 class SwAnchoredObject;
41 
42 namespace objectpositioning
43 {
44     class SwEnvironmentOfAnchoredObject;
45 
46     class SwAnchoredObjectPosition
47     {
48         private:
49             // object to be positioned
50             SdrObject& mrDrawObj;
51 
52          // information about object
53             // does the object represents a Writer fly frame
54             bool mbIsObjFly;
55             // OD 2004-03-23 #i26791# - anchored object the object belongs to;
56             SwAnchoredObject* mpAnchoredObj;
57             // frame the object is anchored at
58             SwFrm* mpAnchorFrm;
59             // contact object
60             SwContact* mpContact;
61             // frame format
62             const SwFrmFmt* mpFrmFmt;
63             // --> OD 2006-03-15 #i62875#
64             bool mbFollowTextFlow;
65             // <--
66             // --> OD 2006-03-15 #i62875#
67             // for compatibility option <DoNotCaptureDrawObjsOnPage>
68             bool mbDoNotCaptureAnchoredObj;
69             // <--
70 
71             /** determine information about object
72 
73                 OD 30.07.2003 #110978#
74                 member <mbIsObjFly>, <mpAnchoredObj>, <mpAnchorFrm>, <mpContact>
75                 and <mpFrmFmt> are set
76 
77                 @author OD
78             */
79             void _GetInfoAboutObj();
80 
81             // --> OD 2006-03-15 #i62875#
82             // --> OD 2009-09-01 #mongolianlayout# - add parameter <bVertL2R>
83             SwTwips _ImplAdjustVertRelPos( const SwTwips nTopOfAnch,
84                                            const bool bVert,
85                                            const bool bVertL2R,
86                                            const SwFrm&  rPageAlignLayFrm,
87                                            const SwTwips nProposedRelPosY,
88                                            const bool bFollowTextFlow,
89                                            const bool bCheckBottom = true ) const;
90             SwTwips _ImplAdjustHoriRelPos( const SwFrm&  _rPageAlignLayFrm,
91                                            const SwTwips _nProposedRelPosX ) const;
92             // <--
93 
94         protected:
95             SwAnchoredObjectPosition( SdrObject& _rDrawObj );
96             virtual ~SwAnchoredObjectPosition();
97 
98          // accessors for object and its corresponding data/information
GetObject() const99             inline SdrObject& GetObject() const
100             {
101                 return mrDrawObj;
102             }
IsObjFly() const103             inline bool IsObjFly() const
104             {
105                 return mbIsObjFly;
106             }
GetAnchoredObj() const107             inline SwAnchoredObject& GetAnchoredObj() const
108             {
109                 return *mpAnchoredObj;
110             }
GetAnchorFrm() const111             inline SwFrm& GetAnchorFrm() const
112             {
113                 return *mpAnchorFrm;
114             }
GetContact() const115             inline SwContact& GetContact() const
116             {
117                 return *mpContact;
118             }
GetFrmFmt() const119             inline const SwFrmFmt& GetFrmFmt() const
120             {
121                 return *mpFrmFmt;
122             }
123             // --> OD 2006-03-15 #i62875#
DoesObjFollowsTextFlow() const124             inline bool DoesObjFollowsTextFlow() const
125             {
126                 return mbFollowTextFlow;
127             }
128             // <--
129 
130          // virtual methods providing data for to character anchored objects.
131             virtual bool IsAnchoredToChar() const;
132             virtual const SwFrm* ToCharOrientFrm() const;
133             virtual const SwRect* ToCharRect() const;
134             // OD 12.11.2003 #i22341#
135             virtual SwTwips ToCharTopOfLine() const;
136 
137         // *********************************************************************
138             /** helper method to determine top of a frame for the vertical
139                 object positioning
140 
141                 OD 2004-03-11 #i11860#
142 
143                 @author OD
144             */
145             SwTwips _GetTopForObjPos( const SwFrm& _rFrm,
146                                       const SwRectFn& _fnRect,
147                                       const bool _bVert ) const;
148 
149         // *********************************************************************
150             void _GetVertAlignmentValues( const SwFrm& _rVertOrientFrm,
151                                           const SwFrm& _rPageAlignLayFrm,
152                                           const sal_Int16 _eRelOrient,
153                                           SwTwips&      _orAlignAreaHeight,
154                                           SwTwips&      _orAlignAreaOffset ) const;
155 
156         // *********************************************************************
157         // --> OD 2004-06-17 #i26791# - add output parameter <_roVertOffsetToFrmAnchorPos>
158             SwTwips _GetVertRelPos( const SwFrm& _rVertOrientFrm,
159                                     const SwFrm& _rPageAlignLayFrm,
160                                     const sal_Int16 _eVertOrient,
161                                     const sal_Int16 _eRelOrient,
162                                     const SwTwips          _nVertPos,
163                                     const SvxLRSpaceItem& _rLRSpacing,
164                                     const SvxULSpaceItem& _rULSpacing,
165                                     SwTwips& _roVertOffsetToFrmAnchorPos ) const;
166 
167         // *********************************************************************
168             /** adjust calculated vertical in order to keep object inside
169                 'page' alignment layout frame.
170 
171                 OD 2004-07-22 #i31805# - add parameter <bCheckBottom>
172                 OD 2004-10-08 #i26945# - add parameter <bFollowTextFlow>
173                 OD 2006-03-15 #i62875# - made inline, intrinsic actions moved
174                 to private method <_ImplAdjustVertRelPos>, which is only
175                 called, if <mbDoNotCaptureAnchoredObj> not set.
176                 OD 2009-09-01 #mongolianlayout# - add parameter <bVertL2R>
177 
178                 @param nTopOfAnch
179                 input parameter - 'vertical' position, at which the relative
180                 position of the object is calculated from.
181 
182                 @param bVert
183                 input parameter - boolean, indicating, if object is in vertical
184                 layout.
185 
186                 @param bVertL2R
187                 input parameter - boolean, indicating, if object is in mongolian
188                 layout (vertical left-to-right layout).
189 
190                 @param rPageAlignLayFrm
191                 input parameter - layout frame, which determines the 'page area'
192                 the object has to be vertical positioned in.
193 
194                 @param nProposedRelPosY
195                 input parameter - proposed relative vertical position, which
196                 will be adjusted.
197 
198                 @param bFollowTextFlow
199                 input parameter - value of attribute 'Follow text flow' of the
200                 anchored object.
201 
202                 @param bCheckBottom
203                 input parameter - boolean indicating, if bottom of anchored
204                 object has to be checked and thus, (if needed) the proposed
205                 relative position has to be adjusted. default value <true>
206 
207                 @author OD
208             */
_AdjustVertRelPos(const SwTwips nTopOfAnch,const bool bVert,const bool bVertL2R,const SwFrm & rPageAlignLayFrm,const SwTwips nProposedRelPosY,const bool bFollowTextFlow,const bool bCheckBottom=true) const209             inline SwTwips _AdjustVertRelPos( const SwTwips nTopOfAnch,
210                                               const bool bVert,
211                                               const bool bVertL2R,
212                                               const SwFrm& rPageAlignLayFrm,
213                                               const SwTwips nProposedRelPosY,
214                                               const bool bFollowTextFlow,
215                                               const bool bCheckBottom = true ) const
216             {
217                 return !mbDoNotCaptureAnchoredObj
218                        ? _ImplAdjustVertRelPos( nTopOfAnch, bVert, bVertL2R,
219                                                 rPageAlignLayFrm,
220                                                 nProposedRelPosY,
221                                                 bFollowTextFlow,
222                                                 bCheckBottom )
223                        : nProposedRelPosY;
224             }
225 
226         // *********************************************************************
227             /** calculate relative horizontal position
228 
229                 --> OD 2004-06-17 #i26791# - add output parameter
230                 <_roHoriOffsetToFrmAnchorPos>
231 
232                 @author OD
233 
234                 @param _rHoriOrientFrm
235                 input parameter - frame the horizontal position of the object
236                 is oriented at.
237 
238                 @param _rEnvOfObj
239                 input parameter - object instance to retrieve environment
240                 information about the object
241 
242                 @param _rHoriOrient
243                 input parameter - horizontal positioning and alignment, for which
244                 the relative position is calculated.
245 
246                 @param _rLRSpacing
247                 input parameter - left and right spacing of the object to the text
248 
249                 @param _rULSpacing
250                 input parameter - upper and lower spacing of the object to the text
251 
252                 @param _bObjWrapThrough
253                 input parameter - boolean indicating, if object has wrap mode
254                 'wrap through'.
255 
256                 @param _nRelPosY
257                 input parameter - relative vertical position
258 
259                 @param _roHoriOffsetToFrmAnchorPos
260                 output parameter - 'horizontal' offset to frame anchor position
261                 according to the alignment
262 
263                 @return relative horizontal position in SwTwips
264             */
265             SwTwips _CalcRelPosX( const SwFrm& _rHoriOrientFrm,
266                                   const SwEnvironmentOfAnchoredObject& _rEnvOfObj,
267                                   const SwFmtHoriOrient& _rHoriOrient,
268                                   const SvxLRSpaceItem& _rLRSpacing,
269                                   const SvxULSpaceItem& _rULSpacing,
270                                   const bool _bObjWrapThrough,
271                                   const SwTwips _nRelPosY,
272                                   SwTwips& _roHoriOffsetToFrmAnchorPos
273                                 ) const;
274 
275         // *********************************************************************
276             /** adjust calculated horizontal in order to keep object inside
277                 'page' alignment layout frame for object type position TO_CNTNT
278 
279                 OD 2006-03-15 #i62875# - made inline, intrinsic actions moved
280                 to private method <_ImplAdjustHoriRelPos>, which is only
281                 called, if <mbDoNotCaptureAnchoredObj> not set.
282 
283                 @author OD
284 
285                 @param _rPageAlignLayFrm
286                 input paramter - layout frame, which determines the 'page area'
287                 the object has to be horizontal positioned in.
288 
289                 @param _nProposedRelPosX
290                 input parameter - proposed relative horizontal position, which
291                 will be adjusted.
292 
293                 @return adjusted relative horizontal position in SwTwips.
294             */
_AdjustHoriRelPos(const SwFrm & _rPageAlignLayFrm,const SwTwips _nProposedRelPosX) const295             inline SwTwips _AdjustHoriRelPos( const SwFrm&  _rPageAlignLayFrm,
296                                               const SwTwips _nProposedRelPosX ) const
297             {
298                 return !mbDoNotCaptureAnchoredObj
299                        ? _ImplAdjustHoriRelPos( _rPageAlignLayFrm, _nProposedRelPosX )
300                        : _nProposedRelPosX;
301             }
302 
303         // *********************************************************************
304             /** toggle given horizontal orientation and relative alignment
305 
306                 @author OD
307 
308                 @param _bToggleLeftRight
309                 input parameter - boolean indicating, if horizontal orientation
310                 and relative alignment has to be toggled.
311 
312                 @param _ioeHoriOrient
313                 input/output parameter - horizontal orientation, that is toggled,
314                 if needed.
315 
316                 @param _iopeRelOrient
317                 optional input/output parameter (default value NULL)
318                 - if set, relative alignment, that is toggled, if needed.
319             */
320             void _ToggleHoriOrientAndAlign( const bool _bToggleLeftRight,
321                                             sal_Int16& _ioeHoriOrient,
322                                             sal_Int16& _iopeRelOrient
323                                           ) const;
324 
325         // *********************************************************************
326             /** determine alignment values for horizontal position of object
327 
328                 @author OD
329 
330                 @param _rHoriOrientFrm
331                 input parameter - frame the horizontal position of the object
332                 is oriented at.
333 
334                 @param _rPageAlignLayFrm
335                 input paramter - layout frame, which determines the 'page area'
336                 the object has to be horizontal positioned in.
337 
338                 @param _eRelOrient
339                 input parameter - horizontal relative alignment, for which
340                 the relative position is calculated.
341 
342                 @param _bToggleLeftRight
343                 input parameter - boolean indicating, if left/right alignments
344                 have to be toggled.
345 
346                 @param _bObjWrapThrough
347                 input parameter - boolean indicating, if object has wrap mode
348                 'wrap through'.
349                 important note: value is only relevant, if _rHoriOrientFrm is
350                                 a text frame.
351 
352                 @param _orAlignAreaWidth
353                 output parameter - width in SwTwips of the area the horizontal
354                 position is aligned to.
355 
356                 @param _orAlignAreaOffset
357                 output parameter - offset in SwTwips of the area the horizontal
358                 position is aligned to. offset is given to the 'left' of the
359                 anchor position.
360 
361                 @param _obAlignedRelToPage
362                 output parameter - boolean indicating, that object is aligned
363                 to 'page area'.
364             */
365             void _GetHoriAlignmentValues( const SwFrm&  _rHoriOrientFrm,
366                                           const SwFrm&  _rPageAlignLayFrm,
367                                           const sal_Int16 _eRelOrient,
368                                           const bool    _bObjWrapThrough,
369                                           SwTwips&      _orAlignAreaWidth,
370                                           SwTwips&      _orAlignAreaOffset,
371                                           bool&         _obAlignedRelToPage ) const;
372 
373         // *********************************************************************
374             /** adjust calculated horizontal position in order to draw object
375                 aside other objects with same positioning
376 
377                 @author OD
378 
379                 @param _rHoriOrientFrm
380                 input parameter - frame the horizontal position of the object
381                 is oriented at.
382 
383                 @param _nProposedRelPosX
384                 input parameter - proposed relative horizontal position, which
385                 will be adjusted.
386 
387                 @param _nRelPosY
388                 input parameter - relative vertical position
389 
390                 @param _eHoriOrient
391                 input parameter - horizontal position of object
392 
393                 @param _eRelOrient
394                 inpt parameter - alignment of object
395 
396                 @param _rLRSpacing
397                 input parameter - left and right spacing of the object to the text
398 
399                 @param _rULSpacing
400                 input parameter - upper and lower spacing of the object to the text
401 
402                 @param _bEvenPage
403                 input parameter - boolean indicating, if object is on an even page.
404 
405                 @return adjusted relative horizontal position in SwTwips
406             */
407             SwTwips _AdjustHoriRelPosForDrawAside( const SwFrm&  _rHoriOrientFrm,
408                                                    const SwTwips _nProposedRelPosX,
409                                                    const SwTwips _nRelPosY,
410                                                    const sal_Int16 _eHoriOrient,
411                                                    const sal_Int16 _eRelOrient,
412                                                    const SvxLRSpaceItem& _rLRSpacing,
413                                                    const SvxULSpaceItem& _rULSpacing,
414                                                    const bool _bEvenPage
415                                                  ) const;
416 
417         // *********************************************************************
418             /** detemine, if object has to draw aside given fly frame
419 
420                 method used by <_AdjustHoriRelPosForDrawAside(..)>
421 
422                 @author OD
423 
424                 @param _pFly
425                 input parameter - fly frame the draw aside check is done for.
426 
427                 @param _rObjRect
428                 input parameter - proposed object rectangle
429 
430                 @param _pObjContext
431                 input parameter - context of the object
432 
433                 @param _nObjIndex
434                 input parameter - index of the anchor frame of the object
435 
436                 @param _bEvenPage
437                 input parameter - boolean indicating, if object is on an even page.
438 
439                 @param _eHoriOrient
440                 input parameter - horizontal position of object
441 
442                 @param _eRelOrient
443                 inpt parameter - alignment of object
444 
445                 @return boolean indicating, if object has to be drawn aside
446                 given fly frame.
447             */
448             bool _DrawAsideFly( const SwFlyFrm* _pFly,
449                                 const SwRect&   _rObjRect,
450                                 const SwFrm*    _pObjContext,
451                                 const sal_uLong     _nObjIndex,
452                                 const bool      _bEvenPage,
453                                 const sal_Int16 _eHoriOrient,
454                                 const sal_Int16 _eRelOrient
455                               ) const;
456 
457         // *********************************************************************
458             /** determine, if object has to draw aside another object
459 
460                 the different alignments of the objects determines, if one has
461                 to draw aside another one. Thus, the given alignment are checked
462                 against each other, which one has to be drawn aside the other one.
463                 depending on parameter _bLeft check is done for left or right
464                 positioning.
465                 method used by <_DrawAsideFly(..)>
466 
467                 @author OD
468 
469                 @param _eRelOrient1
470                 input parameter - alignment 1
471 
472                 @param _eRelOrient2
473                 input parameter - alignment 2
474 
475                 @param _bLeft
476                 input parameter - boolean indicating, if check is done for left
477                 or for right positioning.
478 
479                 @return boolean indicating, if an object with an alignment
480                 <_eRelOrient1> has to be drawn aside an object with an
481                 alignment <_eRelOrient2>
482             */
483             bool _Minor( sal_Int16 _eRelOrient1,
484                          sal_Int16 _eRelOrient2,
485                          bool             _bLeft ) const;
486 
487         public:
488             virtual void CalcPosition() = 0;
489     };
490 } // namespace objectpositioning
491 
492 #endif
493