Line data Source code
1 : /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 : /*
3 : * This file is part of the LibreOffice project.
4 : *
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/.
8 : *
9 : * This file incorporates work covered by the following license notice:
10 : *
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 .
18 : */
19 :
20 : #include <hintids.hxx>
21 : #include <tools/poly.hxx>
22 : #include <svl/stritem.hxx>
23 : #include <svx/contdlg.hxx>
24 : #include <vcl/svapp.hxx>
25 : #include <docary.hxx>
26 : #include <doc.hxx>
27 : #include <fmtcol.hxx>
28 : #include <ndnotxt.hxx>
29 : #include <ndgrf.hxx>
30 : #include <ndole.hxx>
31 : #include <ndindex.hxx>
32 : #include <hints.hxx>
33 : #include <istyleaccess.hxx>
34 : #include <SwStyleNameMapper.hxx>
35 :
36 : #include <frmfmt.hxx>
37 :
38 0 : SwNoTxtNode::SwNoTxtNode( const SwNodeIndex & rWhere,
39 : const sal_uInt8 nNdType,
40 : SwGrfFmtColl *pGrfColl,
41 : SwAttrSet* pAutoAttr ) :
42 : SwCntntNode( rWhere, nNdType, pGrfColl ),
43 : pContour( 0 ),
44 : bAutomaticContour( sal_False ),
45 : bContourMapModeValid( sal_True ),
46 0 : bPixelContour( sal_False )
47 : {
48 : // Should this set a hard attribute?
49 0 : if( pAutoAttr )
50 0 : SetAttr( *pAutoAttr );
51 0 : }
52 :
53 0 : SwNoTxtNode::~SwNoTxtNode()
54 : {
55 0 : delete pContour;
56 0 : }
57 :
58 : /// Creates an AttrSet for all derivations with ranges for frame-
59 : /// and graphics-attributes.
60 0 : void SwNoTxtNode::NewAttrSet( SwAttrPool& rPool )
61 : {
62 : OSL_ENSURE( !mpAttrSet.get(), "AttrSet is already set" );
63 0 : SwAttrSet aNewAttrSet( rPool, aNoTxtNodeSetRange );
64 :
65 : // put names of parent style and conditional style:
66 0 : const SwFmtColl* pFmtColl = GetFmtColl();
67 0 : OUString sVal;
68 0 : SwStyleNameMapper::FillProgName( pFmtColl->GetName(), sVal, nsSwGetPoolIdFromName::GET_POOLID_TXTCOLL, true );
69 0 : SfxStringItem aFmtColl( RES_FRMATR_STYLE_NAME, sVal );
70 0 : aNewAttrSet.Put( aFmtColl );
71 :
72 0 : aNewAttrSet.SetParent( &GetFmtColl()->GetAttrSet() );
73 0 : mpAttrSet = GetDoc()->GetIStyleAccess().getAutomaticStyle( aNewAttrSet, IStyleAccess::AUTO_STYLE_NOTXT );
74 0 : }
75 :
76 : /// Dummies for loading/saving of persistent data
77 : /// when working with graphics and OLE objects
78 0 : bool SwNoTxtNode::RestorePersistentData()
79 : {
80 0 : return true;
81 : }
82 :
83 0 : bool SwNoTxtNode::SavePersistentData()
84 : {
85 0 : return true;
86 : }
87 :
88 0 : void SwNoTxtNode::SetContour( const PolyPolygon *pPoly, sal_Bool bAutomatic )
89 : {
90 0 : delete pContour;
91 0 : if ( pPoly )
92 0 : pContour = new PolyPolygon( *pPoly );
93 : else
94 0 : pContour = 0;
95 0 : bAutomaticContour = bAutomatic;
96 0 : bContourMapModeValid = sal_True;
97 0 : bPixelContour = sal_False;
98 0 : }
99 :
100 0 : void SwNoTxtNode::CreateContour()
101 : {
102 : OSL_ENSURE( !pContour, "Contour available." );
103 0 : pContour = new PolyPolygon(SvxContourDlg::CreateAutoContour(GetGraphic()));
104 0 : bAutomaticContour = sal_True;
105 0 : bContourMapModeValid = sal_True;
106 0 : bPixelContour = sal_False;
107 0 : }
108 :
109 0 : const PolyPolygon *SwNoTxtNode::HasContour() const
110 : {
111 0 : if( !bContourMapModeValid )
112 : {
113 0 : const MapMode aGrfMap( GetGraphic().GetPrefMapMode() );
114 0 : bool bPixelGrf = aGrfMap.GetMapUnit() == MAP_PIXEL;
115 0 : const MapMode aContourMap( bPixelGrf ? MAP_PIXEL : MAP_100TH_MM );
116 0 : if( bPixelGrf ? !bPixelContour : aGrfMap != aContourMap )
117 : {
118 : // #i102238#
119 0 : double nGrfDPIx = 0.0;
120 0 : double nGrfDPIy = 0.0;
121 : {
122 0 : if ( !bPixelGrf && bPixelContour )
123 : {
124 0 : const Size aGrfPixelSize( GetGraphic().GetSizePixel() );
125 0 : const Size aGrfPrefMapModeSize( GetGraphic().GetPrefSize() );
126 0 : if ( aGrfMap.GetMapUnit() == MAP_INCH )
127 : {
128 0 : nGrfDPIx = aGrfPixelSize.Width() / ( (double)aGrfMap.GetScaleX() * aGrfPrefMapModeSize.Width() );
129 0 : nGrfDPIy = aGrfPixelSize.Height() / ( (double)aGrfMap.GetScaleY() * aGrfPrefMapModeSize.Height() );
130 : }
131 : else
132 : {
133 : const Size aGrf1000thInchSize =
134 : OutputDevice::LogicToLogic( aGrfPrefMapModeSize,
135 0 : aGrfMap, MAP_1000TH_INCH );
136 0 : nGrfDPIx = 1000.0 * aGrfPixelSize.Width() / aGrf1000thInchSize.Width();
137 0 : nGrfDPIy = 1000.0 * aGrfPixelSize.Height() / aGrf1000thInchSize.Height();
138 : }
139 : }
140 : }
141 : OSL_ENSURE( !bPixelGrf || aGrfMap == aContourMap,
142 : "scale factor for pixel unsupported" );
143 : OutputDevice* pOutDev =
144 0 : (bPixelGrf || bPixelContour) ? Application::GetDefaultDevice()
145 0 : : 0;
146 0 : sal_uInt16 nPolyCount = pContour->Count();
147 0 : for( sal_uInt16 j=0; j<nPolyCount; j++ )
148 : {
149 0 : Polygon& rPoly = (*pContour)[j];
150 :
151 0 : sal_uInt16 nCount = rPoly.GetSize();
152 0 : for( sal_uInt16 i=0 ; i<nCount; i++ )
153 : {
154 0 : if( bPixelGrf )
155 0 : rPoly[i] = pOutDev->LogicToPixel( rPoly[i],
156 0 : aContourMap );
157 0 : else if( bPixelContour )
158 : {
159 0 : rPoly[i] = pOutDev->PixelToLogic( rPoly[i], aGrfMap );
160 : // #i102238#
161 0 : if ( nGrfDPIx != 0 && nGrfDPIy != 0 )
162 : {
163 0 : rPoly[i] = Point( rPoly[i].getX() * pOutDev->ImplGetDPIX() / nGrfDPIx,
164 0 : rPoly[i].getY() * pOutDev->ImplGetDPIY() / nGrfDPIy );
165 : }
166 : }
167 : else
168 0 : rPoly[i] = OutputDevice::LogicToLogic( rPoly[i],
169 : aContourMap,
170 0 : aGrfMap );
171 : }
172 : }
173 : }
174 0 : ((SwNoTxtNode *)this)->bContourMapModeValid = sal_True;
175 0 : ((SwNoTxtNode *)this)->bPixelContour = sal_False;
176 : }
177 :
178 0 : return pContour;
179 : }
180 :
181 0 : void SwNoTxtNode::GetContour( PolyPolygon &rPoly ) const
182 : {
183 : OSL_ENSURE( pContour, "Contour not available." );
184 0 : rPoly = *HasContour();
185 0 : }
186 :
187 0 : void SwNoTxtNode::SetContourAPI( const PolyPolygon *pPoly )
188 : {
189 0 : delete pContour;
190 0 : if ( pPoly )
191 0 : pContour = new PolyPolygon( *pPoly );
192 : else
193 0 : pContour = 0;
194 0 : bContourMapModeValid = sal_False;
195 0 : }
196 :
197 0 : sal_Bool SwNoTxtNode::GetContourAPI( PolyPolygon &rContour ) const
198 : {
199 0 : if( !pContour )
200 0 : return sal_False;
201 :
202 0 : rContour = *pContour;
203 0 : if( bContourMapModeValid )
204 : {
205 0 : const MapMode aGrfMap( GetGraphic().GetPrefMapMode() );
206 0 : const MapMode aContourMap( MAP_100TH_MM );
207 : OSL_ENSURE( aGrfMap.GetMapUnit() != MAP_PIXEL ||
208 : aGrfMap == MapMode( MAP_PIXEL ),
209 : "scale factor for pixel unsupported" );
210 0 : if( aGrfMap.GetMapUnit() != MAP_PIXEL &&
211 0 : aGrfMap != aContourMap )
212 : {
213 0 : sal_uInt16 nPolyCount = rContour.Count();
214 0 : for( sal_uInt16 j=0; j<nPolyCount; j++ )
215 : {
216 : // --> OD #i102238# - use the right <PolyPolygon> instance
217 0 : Polygon& rPoly = rContour[j];
218 : // <--
219 :
220 0 : sal_uInt16 nCount = rPoly.GetSize();
221 0 : for( sal_uInt16 i=0 ; i<nCount; i++ )
222 : {
223 0 : rPoly[i] = OutputDevice::LogicToLogic( rPoly[i], aGrfMap,
224 0 : aContourMap );
225 : }
226 : }
227 0 : }
228 : }
229 :
230 0 : return sal_True;
231 : }
232 :
233 0 : sal_Bool SwNoTxtNode::IsPixelContour() const
234 : {
235 : sal_Bool bRet;
236 0 : if( bContourMapModeValid )
237 : {
238 0 : const MapMode aGrfMap( GetGraphic().GetPrefMapMode() );
239 0 : bRet = aGrfMap.GetMapUnit() == MAP_PIXEL;
240 : }
241 : else
242 : {
243 0 : bRet = bPixelContour;
244 : }
245 :
246 0 : return bRet;
247 : }
248 :
249 0 : Graphic SwNoTxtNode::GetGraphic() const
250 : {
251 0 : Graphic aRet;
252 0 : if ( GetGrfNode() )
253 : {
254 0 : ((SwGrfNode*)this)->SwapIn( true );
255 0 : aRet = ((SwGrfNode*)this)->GetGrf();
256 : }
257 : else
258 : {
259 : OSL_ENSURE( GetOLENode(), "new type of Node?" );
260 0 : aRet = *((SwOLENode*)this)->SwOLENode::GetGraphic();
261 : }
262 0 : return aRet;
263 : }
264 :
265 : // #i73249#
266 0 : void SwNoTxtNode::SetTitle( const OUString& rTitle, bool bBroadcast )
267 : {
268 : // Title attribute of <SdrObject> replaces own AlternateText attribute
269 0 : SwFlyFrmFmt* pFlyFmt = dynamic_cast<SwFlyFrmFmt*>(GetFlyFmt());
270 : OSL_ENSURE( pFlyFmt, "<SwNoTxtNode::SetTitle(..)> - missing <SwFlyFrmFmt> instance" );
271 0 : if ( !pFlyFmt )
272 : {
273 0 : return;
274 : }
275 :
276 0 : pFlyFmt->SetObjTitle( rTitle, bBroadcast );
277 : }
278 :
279 0 : OUString SwNoTxtNode::GetTitle() const
280 : {
281 0 : const SwFlyFrmFmt* pFlyFmt = dynamic_cast<const SwFlyFrmFmt*>(GetFlyFmt());
282 : OSL_ENSURE( pFlyFmt, "<SwNoTxtNode::GetTitle(..)> - missing <SwFlyFrmFmt> instance" );
283 0 : if ( !pFlyFmt )
284 : {
285 0 : return OUString();
286 : }
287 :
288 0 : return pFlyFmt->GetObjTitle();
289 : }
290 :
291 0 : void SwNoTxtNode::SetDescription( const OUString& rDescription, bool bBroadcast )
292 : {
293 0 : SwFlyFrmFmt* pFlyFmt = dynamic_cast<SwFlyFrmFmt*>(GetFlyFmt());
294 : OSL_ENSURE( pFlyFmt, "<SwNoTxtNode::SetDescription(..)> - missing <SwFlyFrmFmt> instance" );
295 0 : if ( !pFlyFmt )
296 : {
297 0 : return;
298 : }
299 :
300 0 : pFlyFmt->SetObjDescription( rDescription, bBroadcast );
301 : }
302 :
303 0 : OUString SwNoTxtNode::GetDescription() const
304 : {
305 0 : const SwFlyFrmFmt* pFlyFmt = dynamic_cast<const SwFlyFrmFmt*>(GetFlyFmt());
306 : OSL_ENSURE( pFlyFmt, "<SwNoTxtNode::GetDescription(..)> - missing <SwFlyFrmFmt> instance" );
307 0 : if ( !pFlyFmt )
308 : {
309 0 : return OUString();
310 : }
311 :
312 0 : return pFlyFmt->GetObjDescription();
313 : }
314 :
315 : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|