/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you under the Apache * License, Version 2.0 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace ::com::sun::star::uno; using namespace ::com::sun::star::drawing; using namespace ::com::sun::star::frame; SwDPage::SwDPage(SwDrawModel& rNewModel, bool bMasterPage) : FmFormPage(rNewModel, bMasterPage), pGridLst( nullptr ), pDoc(&rNewModel.GetDoc()) { } SwDPage::~SwDPage() { } void SwDPage::lateInit(const SwDPage& rSrcPage) { FmFormPage::lateInit( rSrcPage ); if ( rSrcPage.pGridLst ) { pGridLst.reset( new SdrPageGridFrameList ); for ( sal_uInt16 i = 0; i != rSrcPage.pGridLst->GetCount(); ++i ) pGridLst->Insert( ( *rSrcPage.pGridLst )[ i ] ); } } SwDPage* SwDPage::Clone(SdrModel* const pNewModel) const { SwDrawModel& rSwDrawModel(static_cast< SwDrawModel& >(nullptr == pNewModel ? getSdrModelFromSdrPage() : *pNewModel)); SwDPage* pClonedSwDPage( new SwDPage( rSwDrawModel, IsMasterPage())); pClonedSwDPage->lateInit(*this); return pClonedSwDPage; } SdrObject* SwDPage::ReplaceObject( SdrObject* pNewObj, size_t nObjNum ) { SdrObject *pOld = GetObj( nObjNum ); OSL_ENSURE( pOld, "Oups, Object not replaced" ); SdrObjUserCall* pContact; if ( nullptr != ( pContact = GetUserCall(pOld) ) && RES_DRAWFRMFMT == static_cast(pContact)->GetFormat()->Which()) static_cast(pContact)->ChangeMasterObject( pNewObj ); return FmFormPage::ReplaceObject( pNewObj, nObjNum ); } void InsertGridFrame( SdrPageGridFrameList *pLst, const SwFrame *pPg ) { SwRect aPrt( pPg->getFramePrintArea() ); aPrt += pPg->getFrameArea().Pos(); const tools::Rectangle aUser( aPrt.SVRect() ); const tools::Rectangle aPaper( pPg->getFrameArea().SVRect() ); pLst->Insert( SdrPageGridFrame( aPaper, aUser ) ); } const SdrPageGridFrameList* SwDPage::GetGridFrameList( const SdrPageView* pPV, const tools::Rectangle *pRect ) const { SwViewShell* pSh = static_cast< SwDrawModel& >(getSdrModelFromSdrPage()).GetDoc().getIDocumentLayoutAccess().GetCurrentViewShell(); if(pSh) { for(SwViewShell& rShell : pSh->GetRingContainer()) { if(rShell.Imp()->GetPageView() == pPV) { pSh = &rShell; break; } } if ( pGridLst ) const_cast(this)->pGridLst->Clear(); else const_cast(this)->pGridLst.reset( new SdrPageGridFrameList ); if ( pRect ) { //The drawing demands all pages which overlap with the rest. const SwRect aRect( *pRect ); const SwFrame *pPg = pSh->GetLayout()->Lower(); do { if ( pPg->getFrameArea().IsOver( aRect ) ) ::InsertGridFrame( const_cast(this)->pGridLst.get(), pPg ); pPg = pPg->GetNext(); } while ( pPg ); } else { //The drawing demands all visible pages const SwFrame *pPg = pSh->Imp()->GetFirstVisPage(pSh->GetOut()); if ( pPg ) do { ::InsertGridFrame( const_cast(this)->pGridLst.get(), pPg ); pPg = pPg->GetNext(); } while ( pPg && pPg->getFrameArea().IsOver( pSh->VisArea() ) ); } } return pGridLst.get(); } bool SwDPage::RequestHelp( vcl::Window* pWindow, SdrView const * pView, const HelpEvent& rEvt ) { assert( pDoc ); bool bContinue = true; if( rEvt.GetMode() & ( HelpEventMode::QUICK | HelpEventMode::BALLOON )) { Point aPos( rEvt.GetMousePosPixel() ); aPos = pWindow->ScreenToOutputPixel( aPos ); aPos = pWindow->PixelToLogic( aPos ); SdrPageView* pPV; SdrObject* pObj = pView->PickObj(aPos, 0, pPV, SdrSearchOptions::PICKMACRO); SwVirtFlyDrawObj* pDrawObj = dynamic_cast(pObj); if (pDrawObj) { SwFlyFrame *pFly = pDrawObj->GetFlyFrame(); const SwFormatURL &rURL = pFly->GetFormat()->GetURL(); OUString sText; if( rURL.GetMap() ) { IMapObject *pTmpObj = pFly->GetFormat()->GetIMapObject( aPos, pFly ); if( pTmpObj ) { sText = pTmpObj->GetAltText(); if ( sText.isEmpty() ) sText = URIHelper::removePassword( pTmpObj->GetURL(), INetURLObject::EncodeMechanism::WasEncoded, INetURLObject::DecodeMechanism::Unambiguous); } } else if ( !rURL.GetURL().isEmpty() ) { sText = URIHelper::removePassword( rURL.GetURL(), INetURLObject::EncodeMechanism::WasEncoded, INetURLObject::DecodeMechanism::Unambiguous); if( rURL.IsServerMap() ) { // then append the relative pixel position!! Point aPt( aPos ); aPt -= pFly->getFrameArea().Pos(); // without MapMode-Offset !!!!! // without MapMode-Offset, without Offset, w ... !!!!! aPt = pWindow->LogicToPixel( aPt, MapMode( MapUnit::MapTwip ) ); sText += "?" + OUString::number( aPt.getX() ) + "," + OUString::number( aPt.getY() ); } } if ( !sText.isEmpty() ) { // #i80029# bool bExecHyperlinks = pDoc->GetDocShell()->IsReadOnly(); if ( !bExecHyperlinks ) { SvtSecurityOptions aSecOpts; bExecHyperlinks = !aSecOpts.IsOptionSet( SvtSecurityOptions::EOption::CtrlClickHyperlink ); if ( !bExecHyperlinks ) sText = SwViewShell::GetShellRes()->aLinkCtrlClick + ": " + sText; else sText = SwViewShell::GetShellRes()->aLinkClick + ": " + sText; } // then display the help: tools::Rectangle aRect( rEvt.GetMousePosPixel(), Size(1,1) ); if( rEvt.GetMode() & HelpEventMode::BALLOON ) { Help::ShowBalloon( pWindow, rEvt.GetMousePosPixel(), aRect, sText ); } else { Help::ShowQuickHelp( pWindow, aRect, sText ); } bContinue = false; } } } if( bContinue ) bContinue = !FmFormPage::RequestHelp( pWindow, pView, rEvt ); return bContinue; } Reference< XInterface > SwDPage::createUnoPage() { assert( pDoc ); Reference < XInterface > xRet; SwDocShell* pDocShell = pDoc->GetDocShell(); if ( pDocShell ) { Reference xModel = pDocShell->GetBaseModel(); Reference xPageSupp(xModel, UNO_QUERY); xRet = xPageSupp->getDrawPage(); } return xRet; } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */