blob: 38ced251596b96fcb30910dbf2318f230d57dd7e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* Copyright 2000, 2010 Oracle and/or its affiliates.
*
* OpenOffice.org - a multi-platform office productivity suite
*
* This file is part of OpenOffice.org.
*
* OpenOffice.org is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License version 3
* only, as published by the Free Software Foundation.
*
* OpenOffice.org is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License version 3 for more details
* (a copy is included in the LICENSE file that accompanied this code).
*
* You should have received a copy of the GNU Lesser General Public License
* version 3 along with OpenOffice.org. If not, see
* <http://www.openoffice.org/license.html>
* for a copy of the LGPLv3 License.
*
************************************************************************/
#ifndef _TOCNTNTANCHOREDOBJECTPOSITION_HXX
#define _TOCNTNTANCHOREDOBJECTPOSITION_HXX
#include <anchoredobjectposition.hxx>
class SwFrm;
class SwTxtFrm;
class SwLayoutFrm;
class SwRect;
namespace objectpositioning
{
class SwToCntntAnchoredObjectPosition : public SwAnchoredObjectPosition
{
private:
// calculated data for object position
const SwLayoutFrm* mpVertPosOrientFrm;
// --> OD 2004-06-17 #i26791#
// determine offset to frame anchor position according to the
// positioning alignments
Point maOffsetToFrmAnchorPos;
// data for calculation of position
bool mbAnchorToChar;
const SwFrm* mpToCharOrientFrm;
const SwRect* mpToCharRect;
SwTwips mnToCharTopOfLine;
virtual bool IsAnchoredToChar() const;
virtual const SwFrm* ToCharOrientFrm() const;
virtual const SwRect* ToCharRect() const;
// OD 12.11.2003 #i22341#
virtual SwTwips ToCharTopOfLine() const;
// method to cast <SwAnchoredObjectPosition::GetAnchorFrm()> to
// the needed type
SwTxtFrm& GetAnchorTxtFrm() const;
// *********************************************************************
/** determine frame for horizontal position
OD 04.08.2003
if the given proposed frame is a content frame, the proposed
frame is returned.
otherwise (given proposed frame is a layout frame),
the lower content frames of the proposed frame are checked
for the first, that the anchor or a follow of the anchor.
If none is found, the proposed frame is returned.
@author OD
@param _pProposedFrm
input parameter - proposed frame for horizontal position
@return constant reference to <SwFrm> object, at which the
horizontal position is determined.
*/
const SwFrm& _GetHoriVirtualAnchor( const SwLayoutFrm& _pProposedFrm ) const;
public:
SwToCntntAnchoredObjectPosition( SdrObject& _rDrawObj );
virtual ~SwToCntntAnchoredObjectPosition();
/** calculate position of object
@author OD
*/
virtual void CalcPosition();
/** frame, at which the vertical position is oriented at
@author OD
*/
const SwLayoutFrm& GetVertPosOrientFrm() const;
};
} // namespace objectpositioning
#endif
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|