Files
libreoffice/svx/source/dialog/imapwnd.cxx
Stephan Bergmann 54e87df11f Change INetProtocol enumerators to CamelCase
...to avoid clashes with macros and poor warnings about hiding global FILE

Change-Id: I444e8b958f029201b228937e088efabc4b6d3050
2015-04-02 18:33:37 +02:00

849 lines
26 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 <tools/urlobj.hxx>
#include <vcl/msgbox.hxx>
#include <vcl/help.hxx>
#include <sfx2/sfxsids.hrc>
#include <svtools/imaprect.hxx>
#include <svtools/imapcirc.hxx>
#include <svtools/imappoly.hxx>
#include <svl/urlbmk.hxx>
#include <svx/xoutbmp.hxx>
#include <svx/dialmgr.hxx>
#include <svx/dialogs.hrc>
#include <svx/svxids.hrc>
#include <imapdlg.hrc>
#include <imapwnd.hxx>
#include <svx/svdpage.hxx>
#include <svx/svdorect.hxx>
#include <svx/svdocirc.hxx>
#include <svx/svdopath.hxx>
#include <svx/xfltrit.hxx>
#include <svx/svdpagv.hxx>
#include <svl/urihelper.hxx>
#include <svx/xfillit.hxx>
#include <svx/xlineit.hxx>
#include <sfx2/evntconf.hxx>
#include <sot/formats.hxx>
#include <svx/svxdlg.hxx>
#include <basegfx/point/b2dpoint.hxx>
#include <basegfx/polygon/b2dpolygon.hxx>
#include <boost/scoped_ptr.hpp>
using namespace com::sun::star;
using ::com::sun::star::frame::XFrame;
using ::com::sun::star::uno::Reference;
#define TRANSCOL Color( COL_WHITE )
IMapWindow::IMapWindow( vcl::Window* pParent, WinBits nBits, const Reference< XFrame >& rxDocumentFrame ) :
GraphCtrl( pParent, nBits ),
DropTargetHelper( this ),
mxDocumentFrame( rxDocumentFrame )
{
SetWinStyle( WB_SDRMODE );
pItemInfo = new SfxItemInfo[ 1 ];
memset( pItemInfo, 0, sizeof( SfxItemInfo ) );
pIMapPool = new SfxItemPool( OUString("IMapItemPool"),
SID_ATTR_MACROITEM, SID_ATTR_MACROITEM, pItemInfo );
pIMapPool->FreezeIdRanges();
}
IMapWindow::~IMapWindow()
{
SfxItemPool::Free(pIMapPool);
delete[] pItemInfo;
}
Size IMapWindow::GetOptimalSize() const
{
return LogicToPixel(Size(270, 170), MAP_APPFONT);
}
void IMapWindow::SetImageMap( const ImageMap& rImageMap )
{
ReplaceImageMap( rImageMap, false );
}
void IMapWindow::ReplaceImageMap( const ImageMap& rImageMap, bool /*bScaleToGraphic*/ )
{
SdrPage* pPage = 0;
aIMap = rImageMap;
if(GetSdrModel())
{
// try to access page
pPage = GetSdrModel()->GetPage(0L);
}
if(pPage)
{
// clear all draw objects
pPage->Clear();
}
if(GetSdrView())
{
// #i63762# reset selection at view
GetSdrView()->UnmarkAllObj();
}
// create new drawing objects
const sal_uInt16 nCount(rImageMap.GetIMapObjectCount());
for ( sal_uInt16 i(nCount); i > 0; i-- )
{
SdrObject* pNewObj = CreateObj( rImageMap.GetIMapObject( i - 1 ) );
if (pNewObj && pPage)
{
pPage->InsertObject( pNewObj );
}
}
}
bool IMapWindow::ReplaceActualIMapInfo( const NotifyInfo& rNewInfo )
{
const SdrObject* pSdrObj = GetSelectedSdrObject();
IMapObject* pIMapObj;
bool bRet = false;
if ( pSdrObj && ( ( pIMapObj = GetIMapObj( pSdrObj ) ) != NULL ) )
{
pIMapObj->SetURL( rNewInfo.aMarkURL );
pIMapObj->SetAltText( rNewInfo.aMarkAltText );
pIMapObj->SetTarget( rNewInfo.aMarkTarget );
pModel->SetChanged( true );
UpdateInfo( false );
bRet = true;
}
return bRet;
}
const ImageMap& IMapWindow::GetImageMap()
{
if ( pModel->IsChanged() )
{
SdrPage* pPage = (SdrPage*) pModel->GetPage( 0 );
if ( pPage )
{
const size_t nCount = pPage->GetObjCount();
aIMap.ClearImageMap();
for ( size_t i = nCount; i; )
{
--i;
aIMap.InsertIMapObject( *( static_cast<IMapUserData*>( pPage->GetObj( i )->GetUserData( 0 ) )->GetObject() ) );
}
}
pModel->SetChanged( false );
}
return aIMap;
}
void IMapWindow::SetTargetList( TargetList& rTargetList )
{
// Delete old List
aTargetList.clear();
// Fill with the provided list
for( size_t i = 0, n = rTargetList.size(); i < n; ++i )
aTargetList.push_back( rTargetList[ i ] );
pModel->SetChanged( false );
}
SdrObject* IMapWindow::CreateObj( const IMapObject* pIMapObj )
{
Point aPoint;
Rectangle aClipRect( aPoint, GetGraphicSize() );
SdrObject* pSdrObj = NULL;
IMapObjectPtr pCloneIMapObj;
switch( pIMapObj->GetType() )
{
case( IMAP_OBJ_RECTANGLE ):
{
const IMapRectangleObject* pIMapRectObj = static_cast<const IMapRectangleObject*>(pIMapObj);
Rectangle aDrawRect( pIMapRectObj->GetRectangle( false ) );
// clipped on CanvasPane
aDrawRect.Intersection( aClipRect );
pSdrObj = (SdrObject*) new SdrRectObj( aDrawRect );
pCloneIMapObj.reset((IMapObject*) new IMapRectangleObject( *pIMapRectObj ));
}
break;
case( IMAP_OBJ_CIRCLE ):
{
const IMapCircleObject* pIMapCircleObj = static_cast<const IMapCircleObject*>(pIMapObj);
const Point aCenter( pIMapCircleObj->GetCenter( false ) );
const long nRadius = pIMapCircleObj->GetRadius( false );
const Point aOffset( nRadius, nRadius );
Rectangle aCircle( aCenter - aOffset, aCenter + aOffset );
// limited to CanvasPane
aCircle.Intersection( aClipRect );
pSdrObj = (SdrObject*) new SdrCircObj( OBJ_CIRC, aCircle, 0, 36000 );
pCloneIMapObj.reset((IMapObject*) new IMapCircleObject( *pIMapCircleObj ));
}
break;
case( IMAP_OBJ_POLYGON ):
{
const IMapPolygonObject* pIMapPolyObj = static_cast<const IMapPolygonObject*>(pIMapObj);
// If it actually is an ellipse, then another ellipse is created again
if ( pIMapPolyObj->HasExtraEllipse() )
{
Rectangle aDrawRect( pIMapPolyObj->GetExtraEllipse() );
// clipped on CanvasPane
aDrawRect.Intersection( aClipRect );
pSdrObj = (SdrObject*) new SdrCircObj( OBJ_CIRC, aDrawRect, 0, 36000 );
}
else
{
const Polygon& rPoly = pIMapPolyObj->GetPolygon( false );
Polygon aDrawPoly( rPoly );
// clipped on CanvasPane
aDrawPoly.Clip( aClipRect );
basegfx::B2DPolygon aPolygon;
aPolygon.append(aDrawPoly.getB2DPolygon());
pSdrObj = (SdrObject*)new SdrPathObj(OBJ_POLY, basegfx::B2DPolyPolygon(aPolygon));
}
pCloneIMapObj.reset((IMapObject*) new IMapPolygonObject( *pIMapPolyObj ));
}
break;
default:
break;
}
if ( pSdrObj )
{
SfxItemSet aSet( pModel->GetItemPool() );
aSet.Put( XFillStyleItem( drawing::FillStyle_SOLID ) );
aSet.Put( XFillColorItem( "", TRANSCOL ) );
if ( !pIMapObj->IsActive() )
{
aSet.Put( XFillTransparenceItem( 100 ) );
aSet.Put( XLineColorItem( "", Color( COL_RED ) ) );
}
else
{
aSet.Put( XFillTransparenceItem( 50 ) );
aSet.Put( XLineColorItem( "", Color( COL_BLACK ) ) );
}
pSdrObj->SetMergedItemSetAndBroadcast(aSet);
pSdrObj->AppendUserData( new IMapUserData( pCloneIMapObj ) );
pSdrObj->SetUserCall( GetSdrUserCall() );
}
return pSdrObj;
}
void IMapWindow::InitSdrModel()
{
GraphCtrl::InitSdrModel();
SfxItemSet aSet( pModel->GetItemPool() );
aSet.Put( XFillColorItem( "", TRANSCOL ) );
aSet.Put( XFillTransparenceItem( 50 ) );
pView->SetAttributes( aSet );
pView->SetFrameDragSingles( true );
}
void IMapWindow::SdrObjCreated( const SdrObject& rObj )
{
switch( rObj.GetObjIdentifier() )
{
case( OBJ_RECT ):
{
SdrRectObj* pRectObj = const_cast<SdrRectObj*>(static_cast<const SdrRectObj*>(&rObj));
IMapRectangleObject* pObj = new IMapRectangleObject( pRectObj->GetLogicRect(), "", "", "", "", "", true, false );
pRectObj->AppendUserData( new IMapUserData( IMapObjectPtr(pObj) ) );
}
break;
case( OBJ_CIRC ):
{
SdrCircObj* pCircObj = const_cast<SdrCircObj*>( static_cast<const SdrCircObj*>(&rObj) );
SdrPathObj* pPathObj = static_cast<SdrPathObj*>( pCircObj->ConvertToPolyObj( false, false ) );
Polygon aPoly(pPathObj->GetPathPoly().getB2DPolygon(0L));
delete pPathObj;
IMapPolygonObject* pObj = new IMapPolygonObject( Polygon(aPoly), "", "", "", "", "", true, false );
pObj->SetExtraEllipse( aPoly.GetBoundRect() );
pCircObj->AppendUserData( new IMapUserData( IMapObjectPtr(pObj) ) );
}
break;
case( OBJ_POLY ):
case( OBJ_FREEFILL ):
case( OBJ_PATHPOLY ):
case( OBJ_PATHFILL ):
{
SdrPathObj* pPathObj = const_cast<SdrPathObj*>( static_cast<const SdrPathObj*>(&rObj) );
const basegfx::B2DPolyPolygon& rXPolyPoly = pPathObj->GetPathPoly();
if ( rXPolyPoly.count() )
{
Polygon aPoly(rXPolyPoly.getB2DPolygon(0L));
IMapPolygonObject* pObj = new IMapPolygonObject( aPoly, "", "", "", "", "", true, false );
pPathObj->AppendUserData( new IMapUserData( IMapObjectPtr(pObj) ) );
}
}
break;
default:
break;
}
}
void IMapWindow::SdrObjChanged( const SdrObject& rObj )
{
IMapUserData* pUserData = static_cast<IMapUserData*>( rObj.GetUserData( 0 ) );
if ( pUserData )
{
OUString aURL;
OUString aAltText;
OUString aDesc;
OUString aTarget;
IMapObjectPtr pIMapObj = pUserData->GetObject();
bool bActive = true;
if ( pIMapObj.get() )
{
aURL = pIMapObj->GetURL();
aAltText = pIMapObj->GetAltText();
aDesc = pIMapObj->GetDesc();
aTarget = pIMapObj->GetTarget();
bActive = pIMapObj->IsActive();
}
switch( rObj.GetObjIdentifier() )
{
case( OBJ_RECT ):
{
pUserData->ReplaceObject( IMapObjectPtr(new IMapRectangleObject( static_cast<const SdrRectObj&>(rObj).GetLogicRect(),
aURL, aAltText, aDesc, aTarget, "", bActive, false ) ) );
}
break;
case( OBJ_CIRC ):
{
const SdrCircObj& rCircObj = static_cast<const SdrCircObj&>(rObj);
SdrPathObj* pPathObj = static_cast<SdrPathObj*>( rCircObj.ConvertToPolyObj( false, false ) );
Polygon aPoly(pPathObj->GetPathPoly().getB2DPolygon(0L));
IMapPolygonObject* pObj = new IMapPolygonObject( aPoly, aURL, aAltText, aDesc, aTarget, "", bActive, false );
pObj->SetExtraEllipse( aPoly.GetBoundRect() );
// was only created by us temporarily
delete pPathObj;
pUserData->ReplaceObject( IMapObjectPtr(pObj) );
}
break;
case( OBJ_POLY ):
case( OBJ_FREEFILL ):
case( OBJ_PATHPOLY ):
case( OBJ_PATHFILL ):
{
const SdrPathObj& rPathObj = static_cast<const SdrPathObj&>(rObj);
const basegfx::B2DPolyPolygon& rXPolyPoly = rPathObj.GetPathPoly();
if ( rXPolyPoly.count() )
{
Polygon aPoly(rPathObj.GetPathPoly().getB2DPolygon(0L));
IMapPolygonObject* pObj = new IMapPolygonObject( aPoly, aURL, aAltText, aDesc, aTarget, "", bActive, false );
pUserData->ReplaceObject( IMapObjectPtr(pObj) );
}
}
break;
default:
break;
}
}
}
void IMapWindow::MouseButtonUp(const MouseEvent& rMEvt)
{
GraphCtrl::MouseButtonUp( rMEvt );
UpdateInfo( true );
}
void IMapWindow::MarkListHasChanged()
{
GraphCtrl::MarkListHasChanged();
UpdateInfo( false );
}
SdrObject* IMapWindow::GetHitSdrObj( const Point& rPosPixel ) const
{
SdrObject* pObj = NULL;
Point aPt = PixelToLogic( rPosPixel );
if ( Rectangle( Point(), GetGraphicSize() ).IsInside( aPt ) )
{
SdrPage* pPage = (SdrPage*) pModel->GetPage( 0 );
if ( pPage )
{
for ( size_t i = pPage->GetObjCount(); i > 0; )
{
--i;
SdrObject* pTestObj = pPage->GetObj( i );
IMapObject* pIMapObj = GetIMapObj( pTestObj );
if ( pIMapObj && pIMapObj->IsHit( aPt ) )
{
pObj = pTestObj;
break;
}
}
}
}
return pObj;
}
IMapObject* IMapWindow::GetIMapObj( const SdrObject* pSdrObj ) const
{
IMapObject* pIMapObj = NULL;
if ( pSdrObj )
{
IMapUserData* pUserData = static_cast<IMapUserData*>( pSdrObj->GetUserData( 0 ) );
if ( pUserData )
pIMapObj = pUserData->GetObject().get();
}
return pIMapObj;
}
void IMapWindow::Command(const CommandEvent& rCEvt)
{
vcl::Region aRegion;
if ( rCEvt.GetCommand() == COMMAND_CONTEXTMENU )
{
PopupMenu aMenu( SVX_RES( RID_SVXMN_IMAP ) );
const SdrMarkList& rMarkList = pView->GetMarkedObjectList();
const size_t nMarked = rMarkList.GetMarkCount();
aMenu.EnableItem( MN_URL, false );
aMenu.EnableItem( MN_ACTIVATE, false );
aMenu.EnableItem( MN_MACRO, false );
aMenu.EnableItem( MN_MARK_ALL, pModel->GetPage( 0 )->GetObjCount() != pView->GetMarkedObjectCount() );
if ( !nMarked )
{
aMenu.EnableItem( MN_POSITION, false );
aMenu.EnableItem( MN_FRAME_TO_TOP, false );
aMenu.EnableItem( MN_MOREFRONT, false );
aMenu.EnableItem( MN_MOREBACK, false );
aMenu.EnableItem( MN_FRAME_TO_BOTTOM, false );
aMenu.EnableItem( MN_DELETE1, false );
}
else
{
if ( nMarked == 1 )
{
SdrObject* pSdrObj = GetSelectedSdrObject();
aMenu.EnableItem( MN_URL, true );
aMenu.EnableItem( MN_ACTIVATE, true );
aMenu.EnableItem( MN_MACRO, true );
aMenu.CheckItem( MN_ACTIVATE, GetIMapObj( pSdrObj )->IsActive() );
}
aMenu.EnableItem( MN_POSITION, true );
aMenu.EnableItem( MN_FRAME_TO_TOP, true );
aMenu.EnableItem( MN_MOREFRONT, true );
aMenu.EnableItem( MN_MOREBACK, true );
aMenu.EnableItem( MN_FRAME_TO_BOTTOM, true );
aMenu.EnableItem( MN_DELETE1, true );
}
aMenu.SetSelectHdl( LINK( this, IMapWindow, MenuSelectHdl ) );
aMenu.Execute( this, rCEvt.GetMousePosPixel() );
}
else
Window::Command(rCEvt);
}
sal_Int8 IMapWindow::AcceptDrop( const AcceptDropEvent& rEvt )
{
return( ( GetHitSdrObj( rEvt.maPosPixel ) != NULL ) ? rEvt.mnAction : DND_ACTION_NONE );
}
sal_Int8 IMapWindow::ExecuteDrop( const ExecuteDropEvent& rEvt )
{
sal_Int8 nRet = DND_ACTION_NONE;
if( IsDropFormatSupported( SotClipboardFormatId::NETSCAPE_BOOKMARK ) )
{
const OUString aString;
INetBookmark aBookMark( aString, aString );
SdrObject* pSdrObj = GetHitSdrObj( rEvt.maPosPixel );
if( pSdrObj && TransferableDataHelper( rEvt.maDropEvent.Transferable ).GetINetBookmark( SotClipboardFormatId::NETSCAPE_BOOKMARK, aBookMark ) )
{
IMapObject* pIMapObj = GetIMapObj( pSdrObj );
pIMapObj->SetURL( aBookMark.GetURL() );
pIMapObj->SetAltText( aBookMark.GetDescription() );
pModel->SetChanged( true );
pView->UnmarkAll();
pView->MarkObj( pSdrObj, pView->GetSdrPageView() );
UpdateInfo( true );
nRet = rEvt.mnAction;
}
}
return nRet;
}
void IMapWindow::RequestHelp( const HelpEvent& rHEvt )
{
Point aPos = PixelToLogic( ScreenToOutputPixel( rHEvt.GetMousePosPixel() ) );
if ( Help::IsBalloonHelpEnabled() || Help::IsQuickHelpEnabled() )
{
SdrObject* pSdrObj = NULL;
SdrPageView* pPageView = NULL;
if ( pView->PickObj( aPos, pView->getHitTolLog(), pSdrObj, pPageView ) )
{
const IMapObject* pIMapObj = GetIMapObj( pSdrObj );
OUString aStr;
if ( pIMapObj && !( aStr = pIMapObj->GetURL() ).isEmpty() )
{
Rectangle aLogicPix( LogicToPixel( Rectangle( Point(), GetGraphicSize() ) ) );
Rectangle aScreenRect( OutputToScreenPixel( aLogicPix.TopLeft() ),
OutputToScreenPixel( aLogicPix.BottomRight() ) );
if ( Help::IsBalloonHelpEnabled() )
Help::ShowBalloon( this, rHEvt.GetMousePosPixel(), aScreenRect, aStr );
else if ( Help::IsQuickHelpEnabled() )
Help::ShowQuickHelp( this, aScreenRect, aStr );
}
}
else
Window::RequestHelp( rHEvt );
}
}
void IMapWindow::SetCurrentObjState( bool bActive )
{
SdrObject* pObj = GetSelectedSdrObject();
if ( pObj )
{
SfxItemSet aSet( pModel->GetItemPool() );
GetIMapObj( pObj )->SetActive( bActive );
aSet.Put( XFillColorItem( "", TRANSCOL ) );
if ( !bActive )
{
aSet.Put( XFillTransparenceItem( 100 ) );
aSet.Put( XLineColorItem( "", Color( COL_RED ) ) );
}
else
{
aSet.Put( XFillTransparenceItem( 50 ) );
aSet.Put( XLineColorItem( "", Color( COL_BLACK ) ) );
}
pView->SetAttributes( aSet, false );
}
}
void IMapWindow::UpdateInfo( bool bNewObj )
{
if ( aInfoLink.IsSet() )
{
const SdrObject* pSdrObj = GetSelectedSdrObject();
const IMapObject* pIMapObj = pSdrObj ? GetIMapObj( pSdrObj ) : NULL;
aInfo.bNewObj = bNewObj;
if ( pIMapObj )
{
aInfo.bOneMarked = true;
aInfo.aMarkURL = pIMapObj->GetURL();
aInfo.aMarkAltText = pIMapObj->GetAltText();
aInfo.aMarkTarget = pIMapObj->GetTarget();
aInfo.bActivated = pIMapObj->IsActive();
aInfoLink.Call( this );
}
else
{
aInfo.aMarkURL.clear();
aInfo.aMarkAltText.clear();
aInfo.aMarkTarget.clear();
aInfo.bOneMarked = false;
aInfo.bActivated = false;
}
aInfoLink.Call( this );
}
}
void IMapWindow::DoMacroAssign()
{
SdrObject* pSdrObj = GetSelectedSdrObject();
if ( pSdrObj )
{
SfxItemSet aSet( *pIMapPool, SID_ATTR_MACROITEM, SID_ATTR_MACROITEM, SID_EVENTCONFIG, SID_EVENTCONFIG, 0 );
SfxEventNamesItem aNamesItem(SID_EVENTCONFIG);
aNamesItem.AddEvent( "MouseOver", "", SFX_EVENT_MOUSEOVER_OBJECT );
aNamesItem.AddEvent( "MouseOut", "", SFX_EVENT_MOUSEOUT_OBJECT );
aSet.Put( aNamesItem );
SvxMacroItem aMacroItem(SID_ATTR_MACROITEM);
IMapObject* pIMapObj = GetIMapObj( pSdrObj );
aMacroItem.SetMacroTable( pIMapObj->GetMacroTable() );
aSet.Put( aMacroItem, SID_ATTR_MACROITEM );
SvxAbstractDialogFactory* pFact = SvxAbstractDialogFactory::Create();
boost::scoped_ptr<SfxAbstractDialog> pMacroDlg(pFact->CreateSfxDialog( this, aSet, mxDocumentFrame, SID_EVENTCONFIG ));
if ( pMacroDlg && pMacroDlg->Execute() == RET_OK )
{
const SfxItemSet* pOutSet = pMacroDlg->GetOutputItemSet();
pIMapObj->SetMacroTable( static_cast<const SvxMacroItem& >(pOutSet->Get( SID_ATTR_MACROITEM )).GetMacroTable() );
pModel->SetChanged( true );
UpdateInfo( false );
}
}
}
void IMapWindow::DoPropertyDialog()
{
SdrObject* pSdrObj = GetSelectedSdrObject();
if ( pSdrObj )
{
IMapObject* pIMapObj = GetIMapObj( pSdrObj );
SvxAbstractDialogFactory* pFact = SvxAbstractDialogFactory::Create();
if(pFact)
{
boost::scoped_ptr<AbstractURLDlg> aDlg(pFact->CreateURLDialog( this, pIMapObj->GetURL(), pIMapObj->GetAltText(), pIMapObj->GetDesc(),
pIMapObj->GetTarget(), pIMapObj->GetName(), aTargetList ));
DBG_ASSERT(aDlg, "Dialog creation failed!");
if ( aDlg->Execute() == RET_OK )
{
const OUString aURLText( aDlg->GetURL() );
if ( !aURLText.isEmpty() )
{
INetURLObject aObj( aURLText, INetProtocol::File );
DBG_ASSERT( aObj.GetProtocol() != INetProtocol::NotValid, "Invalid URL" );
pIMapObj->SetURL( aObj.GetMainURL( INetURLObject::NO_DECODE ) );
}
else
pIMapObj->SetURL( aURLText );
pIMapObj->SetAltText( aDlg->GetAltText() );
pIMapObj->SetDesc( aDlg->GetDesc() );
pIMapObj->SetTarget( aDlg->GetTarget() );
pIMapObj->SetName( aDlg->GetName() );
pModel->SetChanged( true );
UpdateInfo( true );
}
}
}
}
IMPL_LINK( IMapWindow, MenuSelectHdl, Menu*, pMenu )
{
if (pMenu)
{
sal_uInt16 nId = pMenu->GetCurItemId();
switch(nId)
{
case( MN_URL ):
DoPropertyDialog();
break;
case( MN_MACRO ):
DoMacroAssign();
break;
case( MN_ACTIVATE ):
{
const bool bNewState = !pMenu->IsItemChecked( MN_ACTIVATE );
pMenu->CheckItem( MN_ACTIVATE, bNewState );
SetCurrentObjState( bNewState );
UpdateInfo( false );
}
break;
case( MN_FRAME_TO_TOP ):
pView->PutMarkedToTop();
break;
case( MN_MOREFRONT ):
pView->MovMarkedToTop();
break;
case( MN_MOREBACK ):
pView->MovMarkedToBtm();
break;
case( MN_FRAME_TO_BOTTOM ):
pView->PutMarkedToBtm();
break;
case( MN_MARK_ALL ):
pView->MarkAll();
break;
case( MN_DELETE1 ):
pView->DeleteMarked();
default :
break;
}
}
return 0;
}
void IMapWindow::CreateDefaultObject()
{
SdrPageView* pPageView = pView->GetSdrPageView();
if(pPageView)
{
// calc position and size
Point aPagePos(0, 0); // = pPageView->GetOffset();
Size aPageSize = pPageView->GetPage()->GetSize();
sal_uInt32 nDefaultObjectSizeWidth = aPageSize.Width() / 4;
sal_uInt32 nDefaultObjectSizeHeight = aPageSize.Height() / 4;
aPagePos.X() += (aPageSize.Width() / 2) - (nDefaultObjectSizeWidth / 2);
aPagePos.Y() += (aPageSize.Height() / 2) - (nDefaultObjectSizeHeight / 2);
Rectangle aNewObjectRectangle(aPagePos, Size(nDefaultObjectSizeWidth, nDefaultObjectSizeHeight));
SdrObject* pObj = SdrObjFactory::MakeNewObject( pView->GetCurrentObjInventor(), pView->GetCurrentObjIdentifier(), 0L, pModel);
pObj->SetLogicRect(aNewObjectRectangle);
switch( pObj->GetObjIdentifier() )
{
case OBJ_POLY:
case OBJ_PATHPOLY:
{
basegfx::B2DPolygon aInnerPoly;
aInnerPoly.append(basegfx::B2DPoint(aNewObjectRectangle.BottomLeft().X(), aNewObjectRectangle.BottomLeft().Y()));
aInnerPoly.append(basegfx::B2DPoint(aNewObjectRectangle.TopLeft().X(), aNewObjectRectangle.TopLeft().Y()));
aInnerPoly.append(basegfx::B2DPoint(aNewObjectRectangle.TopCenter().X(), aNewObjectRectangle.TopCenter().Y()));
aInnerPoly.append(basegfx::B2DPoint(aNewObjectRectangle.Center().X(), aNewObjectRectangle.Center().Y()));
aInnerPoly.append(basegfx::B2DPoint(aNewObjectRectangle.RightCenter().X(), aNewObjectRectangle.RightCenter().Y()));
aInnerPoly.append(basegfx::B2DPoint(aNewObjectRectangle.BottomRight().X(), aNewObjectRectangle.BottomRight().Y()));
aInnerPoly.setClosed(true);
static_cast<SdrPathObj*>(pObj)->SetPathPoly(basegfx::B2DPolyPolygon(aInnerPoly));
break;
}
case OBJ_FREEFILL:
case OBJ_PATHFILL:
{
sal_Int32 nWdt(aNewObjectRectangle.GetWidth() / 2);
sal_Int32 nHgt(aNewObjectRectangle.GetHeight() / 2);
basegfx::B2DPolygon aInnerPoly(XPolygon(aNewObjectRectangle.Center(), nWdt, nHgt).getB2DPolygon());
static_cast<SdrPathObj*>(pObj)->SetPathPoly(basegfx::B2DPolyPolygon(aInnerPoly));
break;
}
}
pView->InsertObjectAtView(pObj, *pPageView);
SdrObjCreated( *pObj );
SetCurrentObjState( true );
pView->MarkObj( pObj, pPageView );
}
}
void IMapWindow::KeyInput( const KeyEvent& rKEvt )
{
GraphCtrl::KeyInput( rKEvt );
}
void IMapWindow::SelectFirstObject()
{
SdrPage* pPage = (SdrPage*) pModel->GetPage( 0 );
if( pPage->GetObjCount() != 0 )
{
GrabFocus();
pView->UnmarkAllObj();
pView->MarkNextObj(true);
}
}
void IMapWindow::StartPolyEdit()
{
GrabFocus();
if( !pView->AreObjectsMarked() )
pView->MarkNextObj(true);
const SdrHdlList& rHdlList = pView->GetHdlList();
SdrHdl* pHdl = rHdlList.GetFocusHdl();
if(!pHdl)
{
((SdrHdlList&)rHdlList).TravelFocusHdl(true);
}
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */