diff options
author | Oliver Bolte <obo@openoffice.org> | 2005-01-25 14:33:24 +0000 |
---|---|---|
committer | Oliver Bolte <obo@openoffice.org> | 2005-01-25 14:33:24 +0000 |
commit | 0fc01cdfd7081b2c568fd2a7a3cd243e7376f893 (patch) | |
tree | cb4ac584ca84e683d669b7b67006dbc6bd34474c | |
parent | 2c6392eea1da89ba3a9ffaa5a37a4c8b1502fdf9 (diff) |
INTEGRATION: CWS impress29 (1.31.40); FILE MERGED
2005/01/17 16:49:28 cl 1.31.40.1: #i38583# readded sound and ole interactions
-rw-r--r-- | sd/source/ui/dlg/tpaction.cxx | 217 |
1 files changed, 187 insertions, 30 deletions
diff --git a/sd/source/ui/dlg/tpaction.cxx b/sd/source/ui/dlg/tpaction.cxx index 81b117665947..4e06d88399df 100644 --- a/sd/source/ui/dlg/tpaction.cxx +++ b/sd/source/ui/dlg/tpaction.cxx @@ -2,9 +2,9 @@ * * $RCSfile: tpaction.cxx,v $ * - * $Revision: 1.32 $ + * $Revision: 1.33 $ * - * last change: $Author: rt $ $Date: 2005-01-11 12:11:11 $ + * last change: $Author: obo $ $Date: 2005-01-25 15:33:24 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses @@ -120,6 +120,9 @@ #ifndef _SVX_COLRITEM_HXX //autogen #include <svx/colritem.hxx> #endif +#ifndef _SVDOOLE2_HXX //autogen +#include <svx/svdoole2.hxx> +#endif #ifndef _SFXDOCFILE_HXX //autogen #include <sfx2/docfile.hxx> #endif @@ -237,10 +240,12 @@ SdTPAction::SdTPAction( Window* pWindow, const SfxItemSet& rInAttrs ) : aFtAction ( this, SdResId( FT_ACTION ) ), aLbAction ( this, SdResId( LB_ACTION ) ), + aEdtSound ( this, SdResId( EDT_SOUND ) ), aBtnSearch ( this, SdResId( BTN_SEARCH ) ), aFtTree ( this, SdResId( FT_TREE ) ), aLbTree ( this, SdResId( LB_TREE ) ), aLbTreeDocument ( this, SdResId( LB_TREE_DOCUMENT ) ), + aLbOLEAction ( this, SdResId( LB_OLE_ACTION ) ), aFlSeparator ( this, SdResId( FL_SEPARATOR ) ), aEdtBookmark ( this, SdResId( EDT_BOOKMARK ) ), aEdtDocument ( this, SdResId( EDT_DOCUMENT ) ), @@ -261,25 +266,6 @@ SdTPAction::SdTPAction( Window* pWindow, const SfxItemSet& rInAttrs ) : // diese Page braucht ExchangeSupport SetExchangeSupport(); - pCurrentActions = new List; - pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_NONE, LIST_APPEND); - pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_PREVPAGE, LIST_APPEND); - pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_NEXTPAGE, LIST_APPEND); - pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_FIRSTPAGE, LIST_APPEND); - pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_LASTPAGE, LIST_APPEND); - pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_BOOKMARK, LIST_APPEND); - pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_DOCUMENT, LIST_APPEND); - pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_PROGRAM, LIST_APPEND); - pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_MACRO, LIST_APPEND); - pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_STOPPRESENTATION, LIST_APPEND); - - // Action-Listbox fuellen - for (ULONG nAction = 0; nAction < pCurrentActions->Count(); nAction++) - { - USHORT nRId = GetClickActionSdResId((presentation::ClickAction)(ULONG)pCurrentActions->GetObject(nAction)); - aLbAction.InsertEntry( String( SdResId( nRId ) ) ); - } - aLbAction.SetSelectHdl( LINK( this, SdTPAction, ClickActionHdl ) ); aLbTree.SetSelectHdl( LINK( this, SdTPAction, SelectTreeHdl ) ); aEdtDocument.SetLoseFocusHdl( LINK( this, SdTPAction, CheckFileHdl ) ); @@ -322,6 +308,99 @@ void SdTPAction::SetView( const ::sd::View* pSdView ) void SdTPAction::Construct() { + // OLE-Actionlistbox auffuellen + SdrOle2Obj* pOleObj = NULL; + SdrGrafObj* pGrafObj = NULL; + BOOL bDisableAll = FALSE; + BOOL bOLEAction = FALSE; + + if ( pView->AreObjectsMarked() ) + { + const SdrMarkList& rMarkList = pView->GetMarkedObjectList(); + SdrObject* pObj; + + if (rMarkList.GetMarkCount() == 1) + { + SdrMark* pMark = rMarkList.GetMark(0); + pObj = pMark->GetObj(); + + UINT32 nInv = pObj->GetObjInventor(); + UINT16 nSdrObjKind = pObj->GetObjIdentifier(); + + if (nInv == SdrInventor && nSdrObjKind == OBJ_OLE2) + { + pOleObj = (SdrOle2Obj*) pObj; + } + else if (nInv == SdrInventor && nSdrObjKind == OBJ_GRAF) + { + pGrafObj = (SdrGrafObj*) pObj; + } +// // VCXControl ? +// else if( pObj->IsA( TYPE( VCSbxDrawObject ) ) ) +// { +// bDisableAll = TRUE; +// } + } + } + if( pGrafObj ) + { + bOLEAction = TRUE; + + aVerbVector.push_back( 0 ); + aLbOLEAction.InsertEntry( MnemonicGenerator::EraseAllMnemonicChars( String( SdResId( STR_EDIT_OBJ ) ) ) ); + } + else if( pOleObj ) + { + uno::Reference < embed::XEmbeddedObject > xObj = pOleObj->GetObjRef(); + if ( xObj.is() ) + { + bOLEAction = TRUE; + uno::Sequence < embed::VerbDescriptor > aVerbs; + try + { + aVerbs = xObj->getSupportedVerbs(); + } + catch ( embed::NeedsRunningStateException& ) + { + xObj->changeState( embed::EmbedStates::RUNNING ); + aVerbs = xObj->getSupportedVerbs(); + } + + for( sal_Int32 i=0; i<aVerbs.getLength(); i++ ) + { + embed::VerbDescriptor aVerb = aVerbs[i]; + if( aVerb.VerbAttributes & embed::VerbAttributes::MS_VERBATTR_ONCONTAINERMENU ) + { + String aTmp( aVerb.VerbName ); + aVerbVector.push_back( aVerb.VerbID ); + aLbOLEAction.InsertEntry( MnemonicGenerator::EraseAllMnemonicChars( aTmp ) ); + } + } + } + } + + pCurrentActions = new List; + pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_NONE, LIST_APPEND); + pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_PREVPAGE, LIST_APPEND); + pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_NEXTPAGE, LIST_APPEND); + pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_FIRSTPAGE, LIST_APPEND); + pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_LASTPAGE, LIST_APPEND); + pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_BOOKMARK, LIST_APPEND); + pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_DOCUMENT, LIST_APPEND); + pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_SOUND, LIST_APPEND); + if( bOLEAction && aLbOLEAction.GetEntryCount() ) + pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_VERB, LIST_APPEND ); + pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_PROGRAM, LIST_APPEND); + pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_MACRO, LIST_APPEND); + pCurrentActions->Insert((void*)(ULONG)presentation::ClickAction_STOPPRESENTATION, LIST_APPEND); + + // Action-Listbox fuellen + for (ULONG nAction = 0; nAction < pCurrentActions->Count(); nAction++) + { + USHORT nRId = GetClickActionSdResId((presentation::ClickAction)(ULONG)pCurrentActions->GetObject(nAction)); + aLbAction.InsertEntry( String( SdResId( nRId ) ) ); + } + } // ----------------------------------------------------------------------- @@ -348,7 +427,8 @@ BOOL SdTPAction::FillItemSet( SfxItemSet& rAttrs ) else { String aBaseURL = pDoc->GetDocSh()->GetMedium()->GetBaseURL(); - if( eCA == presentation::ClickAction_DOCUMENT || + if( eCA == presentation::ClickAction_SOUND || + eCA == presentation::ClickAction_DOCUMENT || eCA == presentation::ClickAction_PROGRAM ) aFileName = ::URIHelper::SmartRel2Abs( INetURLObject(aBaseURL), aFileName, URIHelper::GetMaybeFileHdl(), true, false, INetURLObject::WAS_ENCODED, @@ -378,6 +458,13 @@ void SdTPAction::Reset( const SfxItemSet& rAttrs ) else aLbAction.SetNoSelection(); + // aEdtSound + if( rAttrs.GetItemState( ATTR_ACTION_FILENAME ) != SFX_ITEM_DONTCARE ) + { + aFileName = ( ( const SfxStringItem& ) rAttrs.Get( ATTR_ACTION_FILENAME ) ).GetValue(); + SetEditText( aFileName ); + } + switch( eCA ) { case presentation::ClickAction_BOOKMARK: @@ -400,6 +487,7 @@ void SdTPAction::Reset( const SfxItemSet& rAttrs ) ClickActionHdl( this ); aLbAction.SaveValue(); + aEdtSound.SaveValue(); } // ----------------------------------------------------------------------- @@ -451,6 +539,7 @@ void SdTPAction::OpenFileDialog() { // Soundpreview nur fuer Interaktionen mit Sound presentation::ClickAction eCA = GetActualClickAction(); + BOOL bSound = ( eCA == presentation::ClickAction_SOUND ); BOOL bPage = ( eCA == presentation::ClickAction_BOOKMARK ); BOOL bDocument = ( eCA == presentation::ClickAction_DOCUMENT || eCA == presentation::ClickAction_PROGRAM ); @@ -465,7 +554,22 @@ void SdTPAction::OpenFileDialog() { String aFile( GetEditText() ); - if (bMacro) + if (bSound) + { + SdOpenSoundFileDialog aFileDialog; + + if( !aFile.Len() ) + aFile = SvtPathOptions().GetGraphicPath(); + + aFileDialog.SetPath( aFile ); + + if( aFileDialog.Execute() == ERRCODE_NONE ) + { + aFile = aFileDialog.GetPath(); + SetEditText( aFile ); + } + } + else if (bMacro) { Window* pOldWin = Application::GetDefDialogParent(); Application::SetDefDialogParent( this ); @@ -538,8 +642,10 @@ IMPL_LINK( SdTPAction, ClickActionHdl, void *, EMPTYARG ) aFtTree.Hide(); aLbTree.Hide(); aLbTreeDocument.Hide(); + aLbOLEAction.Hide(); aFlSeparator.Hide(); + aEdtSound.Hide(); aEdtBookmark.Hide(); aEdtDocument.Hide(); aEdtProgram.Hide(); @@ -548,20 +654,29 @@ IMPL_LINK( SdTPAction, ClickActionHdl, void *, EMPTYARG ) aBtnSeek.Hide(); break; + case presentation::ClickAction_SOUND: case presentation::ClickAction_PROGRAM: case presentation::ClickAction_MACRO: aFtTree.Hide(); aLbTree.Hide(); aLbTreeDocument.Hide(); + aLbOLEAction.Hide(); aEdtDocument.Hide(); if( eCA == presentation::ClickAction_MACRO ) { + aEdtSound.Hide(); aEdtProgram.Hide(); } else if( eCA == presentation::ClickAction_PROGRAM ) { + aEdtSound.Hide(); + aEdtMacro.Hide(); + } + else if( eCA == presentation::ClickAction_SOUND ) + { + aEdtProgram.Hide(); aEdtMacro.Hide(); } @@ -571,7 +686,9 @@ IMPL_LINK( SdTPAction, ClickActionHdl, void *, EMPTYARG ) case presentation::ClickAction_DOCUMENT: aLbTree.Hide(); + aLbOLEAction.Hide(); + aEdtSound.Hide(); aEdtProgram.Hide(); aEdtMacro.Hide(); aEdtBookmark.Hide(); @@ -580,23 +697,23 @@ IMPL_LINK( SdTPAction, ClickActionHdl, void *, EMPTYARG ) case presentation::ClickAction_BOOKMARK: aLbTreeDocument.Hide(); - + aLbOLEAction.Hide(); + aEdtSound.Hide(); aEdtDocument.Hide(); aEdtProgram.Hide(); aEdtMacro.Hide(); aBtnSearch.Hide(); break; - case presentation::ClickAction_VANISH: - aFtTree.Hide(); + case presentation::ClickAction_VERB: aLbTree.Hide(); - aLbTreeDocument.Hide(); - - aFlSeparator.Hide(); - aEdtBookmark.Hide(); aEdtDocument.Hide(); aEdtProgram.Hide(); + aEdtBookmark.Hide(); aEdtMacro.Hide(); + aBtnSearch.Hide(); + aFlSeparator.Hide(); + aEdtSound.Hide(); aBtnSeek.Hide(); break; } @@ -614,6 +731,15 @@ IMPL_LINK( SdTPAction, ClickActionHdl, void *, EMPTYARG ) // none break; + case presentation::ClickAction_SOUND: + aFlSeparator.Show(); + aEdtSound.Show(); + aEdtSound.Enable(); + aBtnSearch.Show(); + aBtnSearch.Enable(); + aFlSeparator.SetText( String( SdResId( STR_EFFECTDLG_SOUND ) ) ); + break; + case presentation::ClickAction_PROGRAM: case presentation::ClickAction_MACRO: aFlSeparator.Show(); @@ -646,6 +772,13 @@ IMPL_LINK( SdTPAction, ClickActionHdl, void *, EMPTYARG ) CheckFileHdl( NULL ); break; + case presentation::ClickAction_VERB: + aFtTree.Show(); + aLbOLEAction.Show(); + + aFtTree.SetText( String( SdResId( STR_EFFECTDLG_ACTION ) ) ); + break; + case presentation::ClickAction_BOOKMARK: UpdateTree(); @@ -758,6 +891,8 @@ void SdTPAction::SetEditText( String const & rStr ) if( rStr.GetTokenCount( DOCUMENT_TOKEN ) == 2 ) aText = rStr.GetToken( 0, DOCUMENT_TOKEN ); + // fallthrough inteded + case presentation::ClickAction_SOUND: case presentation::ClickAction_PROGRAM: INetURLObject aURL( aText ); @@ -772,6 +907,16 @@ void SdTPAction::SetEditText( String const & rStr ) // set the string to the corresponding control switch( eCA ) { + case presentation::ClickAction_SOUND: + aEdtSound.SetText(aText ); + break; + case presentation::ClickAction_VERB: + { + ::std::vector< long >::iterator aFound( ::std::find( aVerbVector.begin(), aVerbVector.end(), rStr.ToInt32() ) ); + if( aFound != aVerbVector.end() ) + aLbOLEAction.SelectEntryPos( static_cast< short >( aFound - aVerbVector.begin() ) ); + } + break; case presentation::ClickAction_PROGRAM: aEdtProgram.SetText( aText ); break; @@ -827,6 +972,16 @@ String SdTPAction::GetEditText( BOOL bFullDocDestination ) switch( eCA ) { + case presentation::ClickAction_SOUND: + aStr = aEdtSound.GetText(); + break; + case presentation::ClickAction_VERB: + { + const USHORT nPos = aLbOLEAction.GetSelectEntryPos(); + if( nPos < aVerbVector.size() ) + aStr = UniString::CreateFromInt32( aVerbVector[ nPos ] ); + return aStr; + } case presentation::ClickAction_DOCUMENT: aStr = aEdtDocument.GetText(); break; @@ -885,6 +1040,8 @@ USHORT SdTPAction::GetClickActionSdResId( presentation::ClickAction eCA ) case presentation::ClickAction_DOCUMENT: return STR_CLICK_ACTION_DOCUMENT; case presentation::ClickAction_PROGRAM: return STR_CLICK_ACTION_PROGRAM; case presentation::ClickAction_MACRO: return STR_CLICK_ACTION_MACRO; + case presentation::ClickAction_SOUND: return STR_CLICK_ACTION_SOUND; + case presentation::ClickAction_VERB: return STR_CLICK_ACTION_VERB; case presentation::ClickAction_STOPPRESENTATION: return STR_CLICK_ACTION_STOPPRESENTATION; default: DBG_ERROR( "Keine StringResource fuer ClickAction vorhanden!" ); } |