1*cdf0e10cSrcweir /************************************************************************* 2*cdf0e10cSrcweir * 3*cdf0e10cSrcweir * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4*cdf0e10cSrcweir * 5*cdf0e10cSrcweir * Copyright 2000, 2010 Oracle and/or its affiliates. 6*cdf0e10cSrcweir * 7*cdf0e10cSrcweir * OpenOffice.org - a multi-platform office productivity suite 8*cdf0e10cSrcweir * 9*cdf0e10cSrcweir * This file is part of OpenOffice.org. 10*cdf0e10cSrcweir * 11*cdf0e10cSrcweir * OpenOffice.org is free software: you can redistribute it and/or modify 12*cdf0e10cSrcweir * it under the terms of the GNU Lesser General Public License version 3 13*cdf0e10cSrcweir * only, as published by the Free Software Foundation. 14*cdf0e10cSrcweir * 15*cdf0e10cSrcweir * OpenOffice.org is distributed in the hope that it will be useful, 16*cdf0e10cSrcweir * but WITHOUT ANY WARRANTY; without even the implied warranty of 17*cdf0e10cSrcweir * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18*cdf0e10cSrcweir * GNU Lesser General Public License version 3 for more details 19*cdf0e10cSrcweir * (a copy is included in the LICENSE file that accompanied this code). 20*cdf0e10cSrcweir * 21*cdf0e10cSrcweir * You should have received a copy of the GNU Lesser General Public License 22*cdf0e10cSrcweir * version 3 along with OpenOffice.org. If not, see 23*cdf0e10cSrcweir * <http://www.openoffice.org/license.html> 24*cdf0e10cSrcweir * for a copy of the LGPLv3 License. 25*cdf0e10cSrcweir * 26*cdf0e10cSrcweir ************************************************************************/ 27*cdf0e10cSrcweir 28*cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove 29*cdf0e10cSrcweir #include "precompiled_svx.hxx" 30*cdf0e10cSrcweir #include <svx/sdrmasterpagedescriptor.hxx> 31*cdf0e10cSrcweir #include <svx/sdr/contact/viewcontactofmasterpagedescriptor.hxx> 32*cdf0e10cSrcweir #include <svx/svdpage.hxx> 33*cdf0e10cSrcweir 34*cdf0e10cSrcweir // #i42075# 35*cdf0e10cSrcweir #include <svx/svdobj.hxx> 36*cdf0e10cSrcweir #include <svx/xfillit0.hxx> 37*cdf0e10cSrcweir #include <svl/itemset.hxx> 38*cdf0e10cSrcweir 39*cdf0e10cSrcweir ////////////////////////////////////////////////////////////////////////////// 40*cdf0e10cSrcweir 41*cdf0e10cSrcweir namespace sdr 42*cdf0e10cSrcweir { 43*cdf0e10cSrcweir // ViewContact part 44*cdf0e10cSrcweir sdr::contact::ViewContact* MasterPageDescriptor::CreateObjectSpecificViewContact() 45*cdf0e10cSrcweir { 46*cdf0e10cSrcweir return new sdr::contact::ViewContactOfMasterPageDescriptor(*this); 47*cdf0e10cSrcweir } 48*cdf0e10cSrcweir 49*cdf0e10cSrcweir MasterPageDescriptor::MasterPageDescriptor(SdrPage& aOwnerPage, SdrPage& aUsedPage) 50*cdf0e10cSrcweir : maOwnerPage(aOwnerPage), 51*cdf0e10cSrcweir maUsedPage(aUsedPage), 52*cdf0e10cSrcweir mpViewContact(0L) 53*cdf0e10cSrcweir { 54*cdf0e10cSrcweir // all layers visible 55*cdf0e10cSrcweir maVisibleLayers.SetAll(); 56*cdf0e10cSrcweir 57*cdf0e10cSrcweir // register at used page 58*cdf0e10cSrcweir maUsedPage.AddPageUser(*this); 59*cdf0e10cSrcweir } 60*cdf0e10cSrcweir 61*cdf0e10cSrcweir MasterPageDescriptor::~MasterPageDescriptor() 62*cdf0e10cSrcweir { 63*cdf0e10cSrcweir // de-register at used page 64*cdf0e10cSrcweir maUsedPage.RemovePageUser(*this); 65*cdf0e10cSrcweir 66*cdf0e10cSrcweir if(mpViewContact) 67*cdf0e10cSrcweir { 68*cdf0e10cSrcweir delete mpViewContact; 69*cdf0e10cSrcweir mpViewContact = 0L; 70*cdf0e10cSrcweir } 71*cdf0e10cSrcweir } 72*cdf0e10cSrcweir 73*cdf0e10cSrcweir // ViewContact part 74*cdf0e10cSrcweir sdr::contact::ViewContact& MasterPageDescriptor::GetViewContact() const 75*cdf0e10cSrcweir { 76*cdf0e10cSrcweir if(!mpViewContact) 77*cdf0e10cSrcweir { 78*cdf0e10cSrcweir const_cast< MasterPageDescriptor* >(this)->mpViewContact = 79*cdf0e10cSrcweir const_cast< MasterPageDescriptor* >(this)->CreateObjectSpecificViewContact(); 80*cdf0e10cSrcweir } 81*cdf0e10cSrcweir 82*cdf0e10cSrcweir return *mpViewContact; 83*cdf0e10cSrcweir } 84*cdf0e10cSrcweir 85*cdf0e10cSrcweir // this method is called form the destructor of the referenced page. 86*cdf0e10cSrcweir // do all necessary action to forget the page. It is not necessary to call 87*cdf0e10cSrcweir // RemovePageUser(), that is done form the destructor. 88*cdf0e10cSrcweir void MasterPageDescriptor::PageInDestruction(const SdrPage& /*rPage*/) 89*cdf0e10cSrcweir { 90*cdf0e10cSrcweir maOwnerPage.TRG_ClearMasterPage(); 91*cdf0e10cSrcweir } 92*cdf0e10cSrcweir 93*cdf0e10cSrcweir void MasterPageDescriptor::SetVisibleLayers(const SetOfByte& rNew) 94*cdf0e10cSrcweir { 95*cdf0e10cSrcweir if(rNew != maVisibleLayers) 96*cdf0e10cSrcweir { 97*cdf0e10cSrcweir maVisibleLayers = rNew; 98*cdf0e10cSrcweir GetViewContact().ActionChanged(); 99*cdf0e10cSrcweir } 100*cdf0e10cSrcweir } 101*cdf0e10cSrcweir 102*cdf0e10cSrcweir // operators 103*cdf0e10cSrcweir sal_Bool MasterPageDescriptor::operator==(const MasterPageDescriptor& rCandidate) const 104*cdf0e10cSrcweir { 105*cdf0e10cSrcweir return (&maOwnerPage == &rCandidate.maOwnerPage 106*cdf0e10cSrcweir && &maUsedPage == &rCandidate.maUsedPage 107*cdf0e10cSrcweir && maVisibleLayers == rCandidate.maVisibleLayers); 108*cdf0e10cSrcweir } 109*cdf0e10cSrcweir 110*cdf0e10cSrcweir sal_Bool MasterPageDescriptor::operator!=(const MasterPageDescriptor& rCandidate) const 111*cdf0e10cSrcweir { 112*cdf0e10cSrcweir return (&maOwnerPage != &rCandidate.maOwnerPage 113*cdf0e10cSrcweir || &maUsedPage != &rCandidate.maUsedPage 114*cdf0e10cSrcweir || maVisibleLayers != rCandidate.maVisibleLayers); 115*cdf0e10cSrcweir } 116*cdf0e10cSrcweir 117*cdf0e10cSrcweir const SdrPageProperties* MasterPageDescriptor::getCorrectSdrPageProperties() const 118*cdf0e10cSrcweir { 119*cdf0e10cSrcweir const SdrPage* pCorrectPage = &GetOwnerPage(); 120*cdf0e10cSrcweir const SdrPageProperties* pCorrectProperties = &pCorrectPage->getSdrPageProperties(); 121*cdf0e10cSrcweir 122*cdf0e10cSrcweir if(XFILL_NONE == ((const XFillStyleItem&)pCorrectProperties->GetItemSet().Get(XATTR_FILLSTYLE)).GetValue()) 123*cdf0e10cSrcweir { 124*cdf0e10cSrcweir pCorrectPage = &GetUsedPage(); 125*cdf0e10cSrcweir pCorrectProperties = &pCorrectPage->getSdrPageProperties(); 126*cdf0e10cSrcweir } 127*cdf0e10cSrcweir 128*cdf0e10cSrcweir if(pCorrectPage->IsMasterPage() && !pCorrectProperties->GetStyleSheet()) 129*cdf0e10cSrcweir { 130*cdf0e10cSrcweir // #i110846# Suppress SdrPage FillStyle for MasterPages without StyleSheets, 131*cdf0e10cSrcweir // else the PoolDefault (XFILL_COLOR and Blue8) will be used. Normally, all 132*cdf0e10cSrcweir // MasterPages should have a StyleSheet excactly for this reason, but historically 133*cdf0e10cSrcweir // e.g. the Notes MasterPage has no StyleSheet set (and there maybe others). 134*cdf0e10cSrcweir pCorrectProperties = 0; 135*cdf0e10cSrcweir } 136*cdf0e10cSrcweir 137*cdf0e10cSrcweir return pCorrectProperties; 138*cdf0e10cSrcweir } 139*cdf0e10cSrcweir } // end of namespace sdr 140*cdf0e10cSrcweir 141*cdf0e10cSrcweir ////////////////////////////////////////////////////////////////////////////// 142*cdf0e10cSrcweir // eof 143