summaryrefslogtreecommitdiff
path: root/basctl/source/dlged/dlgedview.cxx
diff options
context:
space:
mode:
authorMichael Stahl <mstahl@redhat.com>2012-01-28 20:52:45 +0100
committerMichael Stahl <mstahl@redhat.com>2012-01-28 20:52:45 +0100
commit2e626373db2412ac22e8c5c27a60d11cd29e875b (patch)
tree9e9f67205cd5b72f1031721273e1534a3a1e5b0f /basctl/source/dlged/dlgedview.cxx
parentf7ee7bbd5174b084f018c2ec94d8c70c98ee04da (diff)
replace obsolete "master" branch with README that points at new repoHEADmaster-deletedmaster
Diffstat (limited to 'basctl/source/dlged/dlgedview.cxx')
-rw-r--r--basctl/source/dlged/dlgedview.cxx217
1 files changed, 0 insertions, 217 deletions
diff --git a/basctl/source/dlged/dlgedview.cxx b/basctl/source/dlged/dlgedview.cxx
deleted file mode 100644
index eed522548..000000000
--- a/basctl/source/dlged/dlgedview.cxx
+++ /dev/null
@@ -1,217 +0,0 @@
-/* -*- 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.
- *
- ************************************************************************/
-
-// MARKER(update_precomp.py): autogen include statement, do not remove
-#include "precompiled_basctl.hxx"
-
-
-#include "dlgedview.hxx"
-#include "dlged.hxx"
-#include <dlgedpage.hxx>
-
-#include <svx/svxids.hrc>
-#include <sfx2/viewfrm.hxx>
-
-#include <basidesh.hxx>
-#include <iderdll.hxx>
-#include "dlgedobj.hxx"
-
-TYPEINIT1( DlgEdView, SdrView );
-
-//----------------------------------------------------------------------------
-
-DlgEdView::DlgEdView( SdrModel* pModel, OutputDevice* pOut, DlgEditor* pEditor )
- :SdrView( pModel, pOut )
- ,pDlgEditor( pEditor )
-{
- // #114898#
- SetBufferedOutputAllowed(true);
- SetBufferedOverlayAllowed(true);
-}
-
-//----------------------------------------------------------------------------
-
-DlgEdView::~DlgEdView()
-{
-}
-
-//----------------------------------------------------------------------------
-
-void DlgEdView::MarkListHasChanged()
-{
- SdrView::MarkListHasChanged();
-
- DlgEdHint aHint( DLGED_HINT_SELECTIONCHANGED );
- if ( pDlgEditor )
- {
- pDlgEditor->Broadcast( aHint );
- pDlgEditor->UpdatePropertyBrowserDelayed();
- }
-}
-
-//----------------------------------------------------------------------------
-
-void DlgEdView::MakeVisible( const Rectangle& rRect, Window& rWin )
-{
- // visible area
- MapMode aMap( rWin.GetMapMode() );
- Point aOrg( aMap.GetOrigin() );
- Size aVisSize( rWin.GetOutputSize() );
- Rectangle RectTmp( Point(-aOrg.X(),-aOrg.Y()), aVisSize );
- Rectangle aVisRect( RectTmp );
-
- // check, if rectangle is inside visible area
- if ( !aVisRect.IsInside( rRect ) )
- {
- // calculate scroll distance; the rectangle must be inside the visible area
- sal_Int32 nScrollX = 0, nScrollY = 0;
-
- sal_Int32 nVisLeft = aVisRect.Left();
- sal_Int32 nVisRight = aVisRect.Right();
- sal_Int32 nVisTop = aVisRect.Top();
- sal_Int32 nVisBottom = aVisRect.Bottom();
-
- sal_Int32 nDeltaX = pDlgEditor->GetHScroll()->GetLineSize();
- sal_Int32 nDeltaY = pDlgEditor->GetVScroll()->GetLineSize();
-
- while ( rRect.Right() > nVisRight + nScrollX )
- nScrollX += nDeltaX;
-
- while ( rRect.Left() < nVisLeft + nScrollX )
- nScrollX -= nDeltaX;
-
- while ( rRect.Bottom() > nVisBottom + nScrollY )
- nScrollY += nDeltaY;
-
- while ( rRect.Top() < nVisTop + nScrollY )
- nScrollY -= nDeltaY;
-
- // don't scroll beyond the page size
- Size aPageSize = pDlgEditor->GetPage()->GetSize();
- sal_Int32 nPageWidth = aPageSize.Width();
- 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.Update();
- rWin.Scroll( -nScrollX, -nScrollY );
- aMap.SetOrigin( Point( aOrg.X() - nScrollX, aOrg.Y() - nScrollY ) );
- rWin.SetMapMode( aMap );
- rWin.Update();
- rWin.Invalidate();
-
- // update scroll bars
- if ( pDlgEditor )
- pDlgEditor->UpdateScrollBars();
-
- DlgEdHint aHint( DLGED_HINT_WINDOWSCROLLED );
- if ( pDlgEditor )
- pDlgEditor->Broadcast( aHint );
- }
-}
-
-//----------------------------------------------------------------------------
-
-SdrObject* impLocalHitCorrection(SdrObject* pRetval, const Point& rPnt, sal_uInt16 nTol)
-{
- DlgEdObj* pDlgEdObj = dynamic_cast< DlgEdObj* >(pRetval);
-
- if(pDlgEdObj)
- {
- bool bExcludeInner(false);
-
- if(0 != dynamic_cast< DlgEdForm* >(pRetval))
- {
- // from DlgEdForm::CheckHit; exclude inner for DlgEdForm
- bExcludeInner = true;
- }
- else if(pDlgEdObj->supportsService("com.sun.star.awt.UnoControlGroupBoxModel"))
- {
- // from DlgEdObj::CheckHit; exclude inner for group shapes
- bExcludeInner = true;
- }
-
- if(bExcludeInner)
- {
- // use direct model data; it's a DlgEdObj, so GetLastBoundRect()
- // will access aOutRect directly
- const Rectangle aOuterRectangle(pDlgEdObj->GetLastBoundRect());
-
- if(!aOuterRectangle.IsEmpty()
- && RECT_EMPTY != aOuterRectangle.Right()
- && RECT_EMPTY != aOuterRectangle.Bottom())
- {
- basegfx::B2DRange aOuterRange(
- aOuterRectangle.Left(), aOuterRectangle.Top(),
- aOuterRectangle.Right(), aOuterRectangle.Bottom());
-
- if(nTol)
- {
- aOuterRange.grow(-1.0 * nTol);
- }
-
- if(aOuterRange.isInside(basegfx::B2DPoint(rPnt.X(), rPnt.Y())))
- {
- pRetval = 0;
- }
- }
- }
- }
-
- return pRetval;
-}
-
-SdrObject* DlgEdView::CheckSingleSdrObjectHit(const Point& rPnt, sal_uInt16 nTol, SdrObject* pObj, SdrPageView* pPV, sal_uLong nOptions, const SetOfByte* pMVisLay) const
-{
- // call parent
- SdrObject* pRetval = SdrView::CheckSingleSdrObjectHit(rPnt, nTol, pObj, pPV, nOptions, pMVisLay);
-
- if(pRetval)
- {
- // check hitted object locally
- pRetval = impLocalHitCorrection(pRetval, rPnt, nTol);
- }
-
- return pRetval;
-}
-
-//----------------------------------------------------------------------------
-// eof
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */