1
0
Fork 0
libreoffice/reportdesign/source/ui/report/SectionView.cxx
Daniel Baumann 8e63e14cf6
Adding upstream version 4:25.2.3.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
2025-06-22 16:20:04 +02:00

249 lines
7.4 KiB
C++

/* -*- 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 <SectionView.hxx>
#include <DesignView.hxx>
#include <RptPage.hxx>
#include <RptObject.hxx>
#include <RptDef.hxx>
#include <svx/svddrgmt.hxx>
#include <ReportSection.hxx>
#include <ReportWindow.hxx>
#include <strings.hxx>
#include <comphelper/diagnose_ex.hxx>
namespace rptui
{
using namespace ::com::sun::star;
OSectionView::OSectionView(
SdrModel& rSdrModel,
OReportSection* _pSectionWindow,
OReportWindow* pEditor)
: SdrView(rSdrModel, _pSectionWindow->GetOutDev())
,m_pReportWindow( pEditor )
,m_pSectionWindow(_pSectionWindow)
{
SetBufferedOutputAllowed(true);
SetBufferedOverlayAllowed(true);
SetPageBorderVisible(false);
SetBordVisible();
SetQuickTextEditMode(false);
}
OSectionView::~OSectionView()
{
}
void OSectionView::MarkListHasChanged()
{
SdrView::MarkListHasChanged();
if ( m_pReportWindow && m_pSectionWindow && !m_pSectionWindow->getPage()->getSpecialMode() )
{
DlgEdHint aHint( RPTUI_HINT_SELECTIONCHANGED );
m_pReportWindow->getReportView()->Broadcast( aHint );
m_pReportWindow->getReportView()->UpdatePropertyBrowserDelayed(*this);
}
}
void OSectionView::MakeVisible( const tools::Rectangle& rRect, vcl::Window& rWin )
{
// visible area
MapMode aMap( rWin.GetMapMode() );
const Point aOrg( aMap.GetOrigin() );
const Size aVisSize( rWin.GetOutDev()->GetOutputSize() );
const tools::Rectangle aVisRect( Point(-aOrg.X(),-aOrg.Y()), aVisSize );
// check, if rectangle is inside visible area
if ( !aVisRect.Contains( rRect ) )
{
// calculate scroll distance; the rectangle must be inside the visible area
sal_Int32 nScrollX = 0, nScrollY = 0;
const sal_Int32 nVisLeft = aVisRect.Left();
const sal_Int32 nVisRight = aVisRect.Right();
const sal_Int32 nVisTop = aVisRect.Top();
const sal_Int32 nVisBottom = aVisRect.Bottom();
// don't scroll beyond the page size
Size aPageSize = m_pSectionWindow->getPage()->GetSize();
const sal_Int32 nPageWidth = aPageSize.Width();
const sal_Int32 nPageHeight = aPageSize.Height();
if ( nVisRight + nScrollX > nPageWidth )
nScrollX = nPageWidth - nVisRight;
if ( nVisLeft + nScrollX < 0 )
nScrollX = -nVisLeft;
if ( nVisBottom + nScrollY > nPageHeight )
nScrollY = nPageHeight - nVisBottom;
if ( nVisTop + nScrollY < 0 )
nScrollY = -nVisTop;
// scroll window
rWin.PaintImmediately();
rWin.Scroll( -nScrollX, -nScrollY );
aMap.SetOrigin( Point( aOrg.X() - nScrollX, aOrg.Y() - nScrollY ) );
rWin.SetMapMode( aMap );
rWin.Invalidate();
if ( m_pReportWindow )
{
const DlgEdHint aHint( RPTUI_HINT_WINDOWSCROLLED );
m_pReportWindow->getReportView()->Broadcast( aHint );
}
}
else
{
rWin.Invalidate(InvalidateFlags::NoErase);
}
}
void OSectionView::Notify( SfxBroadcaster& rBC, const SfxHint& rHint )
{
SdrView::Notify(rBC,rHint);
if (rHint.GetId() != SfxHintId::ThisIsAnSdrHint)
return;
const SdrHint* pSdrHint = static_cast<const SdrHint*>(&rHint);
const SdrObject* pObj = pSdrHint->GetObject();
const SdrHintKind eKind = pSdrHint->GetKind();
// check for change of selected object
if(SdrHintKind::ObjectChange == eKind && pObj && IsObjMarked(pObj))
AdjustMarkHdl();
else if ( eKind == SdrHintKind::ObjectRemoved )
ObjectRemovedInAliveMode(pObj);
}
void OSectionView::ObjectRemovedInAliveMode( const SdrObject* _pObject )
{
const SdrMarkList& rMarkedList = GetMarkedObjectList();
const size_t nMark = rMarkedList.GetMarkCount();
for( size_t i = 0; i < nMark; ++i )
{
SdrObject* pSdrObj = rMarkedList.GetMark(i)->GetMarkedSdrObj();
if (_pObject == pSdrObj)
{
SdrPageView* pPgView = GetSdrPageView();
BrkAction();
MarkObj( pSdrObj, pPgView, true );
break;
}
}
}
void OSectionView::SetMarkedToLayer( SdrLayerID _nLayerNo )
{
if (GetMarkedObjectList().GetMarkCount() == 0)
return;
// #i11702# use SdrUndoObjectLayerChange for undo
// STR_UNDO_SELATTR is "Attributes" - should use a different text later
BegUndo( );
const SdrMarkList& rMark = GetMarkedObjectList();
const size_t nCount = rMark.GetMarkCount();
for (size_t i = 0; i<nCount; ++i)
{
SdrObject* pObj = rMark.GetMark(i)->GetMarkedSdrObj();
if ( dynamic_cast< const OCustomShape *>( pObj ) != nullptr )
{
AddUndo( std::make_unique<SdrUndoObjectLayerChange>( *pObj, pObj->GetLayer(), _nLayerNo) );
pObj->SetLayer( _nLayerNo );
OObjectBase& rBaseObj = dynamic_cast<OObjectBase&>(*pObj);
try
{
rBaseObj.getReportComponent()->setPropertyValue(PROPERTY_OPAQUE,uno::Any(_nLayerNo == RPT_LAYER_FRONT));
}
catch(const uno::Exception&)
{
DBG_UNHANDLED_EXCEPTION("reportdesign");
}
}
}
EndUndo();
// check mark list now instead of later in a timer
CheckMarked();
MarkListHasChanged();
}
bool OSectionView::OnlyShapesMarked() const
{
const SdrMarkList& rMark = GetMarkedObjectList();
const size_t nCount = rMark.GetMarkCount();
if ( !nCount )
return false;
for (size_t i = 0; i<nCount; ++i)
{
SdrObject* pObj = rMark.GetMark(i)->GetMarkedSdrObj();
if ( dynamic_cast< const OCustomShape *>( pObj ) == nullptr )
{
return false;
}
}
return true;
}
bool OSectionView::IsDragResize() const
{
const SdrDragMethod* pDragMethod = GetDragMethod();
if (pDragMethod)
{
bool bMoveOnly = pDragMethod->getMoveOnly();
if (!bMoveOnly)
{
// current marked components will be resized
return true;
}
}
return false;
}
SdrLayerID OSectionView::GetLayerIdOfMarkedObjects() const
{
SdrLayerID nRet = SDRLAYER_NOTFOUND;
const SdrMarkList &rMrkList = GetMarkedObjectList();
for ( size_t i = 0; i < rMrkList.GetMarkCount(); ++i )
{
const SdrObject *pObj = rMrkList.GetMark( i )->GetMarkedSdrObj();
if ( nRet == SDRLAYER_NOTFOUND )
nRet = pObj->GetLayer();
else if ( nRet != pObj->GetLayer() )
{
break;
}
}
return nRet;
}
} // rptui
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */