Commit 8a50a0bd authored by Olivier Teulière's avatar Olivier Teulière

* ./modules/gui/win32/dragdrop.cpp: we can now drag and drop video

   files on the interface or on the playlist (Closes: #10).
 * ./modules/gui/win32/playlist.cpp: factorized a lot of code.
 * ./modules/gui/win32/*: reorganized some code here and there.
parent e4d0eaae
...@@ -19,8 +19,8 @@ BORLAND_win32 = \ ...@@ -19,8 +19,8 @@ BORLAND_win32 = \
modules/gui/win32/win32.bpf \ modules/gui/win32/win32.bpf \
\ \
modules/gui/win32/about.cpp \ modules/gui/win32/about.cpp \
modules/gui/win32/control.cpp \
modules/gui/win32/disc.cpp \ modules/gui/win32/disc.cpp \
modules/gui/win32/dragdrop.cpp \
modules/gui/win32/mainframe.cpp \ modules/gui/win32/mainframe.cpp \
modules/gui/win32/menu.cpp \ modules/gui/win32/menu.cpp \
modules/gui/win32/messages.cpp \ modules/gui/win32/messages.cpp \
...@@ -39,8 +39,8 @@ BORLAND_win32 = \ ...@@ -39,8 +39,8 @@ BORLAND_win32 = \
modules/gui/win32/preferences.dfm \ modules/gui/win32/preferences.dfm \
\ \
modules/gui/win32/about.h \ modules/gui/win32/about.h \
modules/gui/win32/control.h \
modules/gui/win32/disc.h \ modules/gui/win32/disc.h \
modules/gui/win32/dragdrop.h \
modules/gui/win32/mainframe.h \ modules/gui/win32/mainframe.h \
modules/gui/win32/menu.h \ modules/gui/win32/menu.h \
modules/gui/win32/messages.h \ modules/gui/win32/messages.h \
......
/*****************************************************************************
* control.cpp: functions to handle stream control buttons.
*****************************************************************************
* Copyright (C) 2002 VideoLAN
*
* Authors: Olivier Teuliere <ipkiss@via.ecp.fr>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
*****************************************************************************/
#include <vcl.h>
#include <vlc/vlc.h>
#include <vlc/intf.h>
#include "win32_common.h"
extern intf_thread_t *p_intfGlobal;
/****************************************************************************
* Control functions: this is where the functions are defined
****************************************************************************
* These functions are used by toolbuttons callbacks
****************************************************************************/
bool ControlBack( TObject *Sender )
{
/* FIXME: TODO */
return false;
}
bool ControlStop( TObject *Sender )
{
playlist_t * p_playlist = (playlist_t *)
vlc_object_find( p_intfGlobal, VLC_OBJECT_PLAYLIST, FIND_ANYWHERE );
if( p_playlist == NULL )
{
return false;
}
playlist_Stop( p_playlist );
vlc_object_release( p_playlist );
return true;
}
bool ControlPlay( TObject *Sender )
{
playlist_t * p_playlist = (playlist_t *)
vlc_object_find( p_intfGlobal, VLC_OBJECT_PLAYLIST, FIND_ANYWHERE );
if( p_playlist == NULL )
{
p_intfGlobal->p_sys->p_window->OpenFileActionExecute( Sender );
return false;
}
vlc_mutex_lock( &p_playlist->object_lock );
if( p_playlist->i_size )
{
vlc_mutex_unlock( &p_playlist->object_lock );
playlist_Play( p_playlist );
vlc_object_release( p_playlist );
}
else
{
vlc_mutex_unlock( &p_playlist->object_lock );
vlc_object_release( p_playlist );
p_intfGlobal->p_sys->p_window->OpenFileActionExecute( Sender );
}
return true;
}
bool ControlPause( TObject *Sender )
{
if( p_intfGlobal->p_sys->p_input != NULL )
{
input_SetStatus( p_intfGlobal->p_sys->p_input, INPUT_STATUS_PAUSE );
}
return true;
}
bool ControlSlow( TObject *Sender )
{
if( p_intfGlobal->p_sys->p_input != NULL )
{
input_SetStatus( p_intfGlobal->p_sys->p_input, INPUT_STATUS_SLOWER );
}
return true;
}
bool ControlFast( TObject *Sender )
{
if( p_intfGlobal->p_sys->p_input != NULL )
{
input_SetStatus( p_intfGlobal->p_sys->p_input, INPUT_STATUS_FASTER );
}
return true;
}
...@@ -63,14 +63,6 @@ void __fastcall TDiscDlg::BitBtnCancelClick( TObject *Sender ) ...@@ -63,14 +63,6 @@ void __fastcall TDiscDlg::BitBtnCancelClick( TObject *Sender )
void __fastcall TDiscDlg::BitBtnOkClick( TObject *Sender ) void __fastcall TDiscDlg::BitBtnOkClick( TObject *Sender )
{ {
AnsiString Device, Source, Method, Title, Chapter; AnsiString Device, Source, Method, Title, Chapter;
playlist_t * p_playlist;
p_playlist = (playlist_t *)
vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST, FIND_ANYWHERE );
if( p_playlist == NULL )
{
return;
}
Hide(); Hide();
...@@ -78,13 +70,9 @@ void __fastcall TDiscDlg::BitBtnOkClick( TObject *Sender ) ...@@ -78,13 +70,9 @@ void __fastcall TDiscDlg::BitBtnOkClick( TObject *Sender )
/* Check which method was activated */ /* Check which method was activated */
if( RadioGroupType->ItemIndex == 0 ) if( RadioGroupType->ItemIndex == 0 )
{
Method = "dvd"; Method = "dvd";
}
else else
{
Method = "vcd"; Method = "vcd";
}
/* Select title and chapter */ /* Select title and chapter */
Title.sprintf( "%d", SpinEditTitle->Value ); Title.sprintf( "%d", SpinEditTitle->Value );
...@@ -92,13 +80,9 @@ void __fastcall TDiscDlg::BitBtnOkClick( TObject *Sender ) ...@@ -92,13 +80,9 @@ void __fastcall TDiscDlg::BitBtnOkClick( TObject *Sender )
/* Build source name and add it to playlist */ /* Build source name and add it to playlist */
Source = Method + ":" + Device + "@" + Title + "," + Chapter; Source = Method + ":" + Device + "@" + Title + "," + Chapter;
playlist_Add( p_playlist, Source.c_str(),
PLAYLIST_APPEND | PLAYLIST_GO, PLAYLIST_END );
/* update the display */
p_intf->p_sys->p_playwin->UpdateGrid( p_playlist );
vlc_object_release( p_playlist ); p_intf->p_sys->p_playwin->Add( Source, PLAYLIST_APPEND | PLAYLIST_GO,
PLAYLIST_END );
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TDiscDlg::RadioGroupTypeClick( TObject *Sender ) void __fastcall TDiscDlg::RadioGroupTypeClick( TObject *Sender )
......
/*****************************************************************************
* dragdrop.cpp: drag and drop management
*****************************************************************************
* Copyright (C) 2002 VideoLAN
*
* Authors: Olivier Teuliere <ipkiss@via.ecp.fr>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
*****************************************************************************/
#include <vcl.h>
#pragma hdrstop
#include "dragdrop.h"
//---------------------------------------------------------------------------
__fastcall TDropTarget::TDropTarget( HWND HForm ) : IDropTarget()
{
FormHandle = HForm;
References = 1;
}
//---------------------------------------------------------------------------
__fastcall TDropTarget::~TDropTarget()
{
}
//---------------------------------------------------------------------------
/* helper routine to notify Form of drop on target */
void __fastcall TDropTarget::HandleDrop( HDROP HDrop )
{
SendMessage( FormHandle, WM_OLEDROP, (WPARAM)HDrop, 0 );
}
//---------------------------------------------------------------------------
STDMETHODIMP TDropTarget::QueryInterface( REFIID iid, void FAR* FAR* ppv )
{
/* tell other objects about our capabilities */
if( iid == IID_IUnknown || iid == IID_IDropTarget )
{
*ppv = this;
AddRef();
return S_OK;
}
*ppv = NULL;
return ResultFromScode( E_NOINTERFACE );
}
//---------------------------------------------------------------------------
STDMETHODIMP_(ULONG) TDropTarget::AddRef()
{
return ++References;
}
//---------------------------------------------------------------------------
STDMETHODIMP_(ULONG) TDropTarget::Release()
{
if( --References == 0 )
{
delete this;
return 0;
}
return References;
}
//---------------------------------------------------------------------------
/* Indicates whether a drop can be accepted, and, if so,
* the effect of the drop */
STDMETHODIMP TDropTarget::DragEnter( LPDATAOBJECT pDataObj, DWORD grfKeyState,
POINTL pt, DWORD *pdwEffect )
{
FORMATETC fmtetc;
fmtetc.cfFormat = CF_HDROP;
fmtetc.ptd = NULL;
fmtetc.dwAspect = DVASPECT_CONTENT;
fmtetc.lindex = -1;
fmtetc.tymed = TYMED_HGLOBAL;
/* Check that the drag source provides CF_HDROP,
* which is the only format we accept */
if( pDataObj->QueryGetData( &fmtetc ) == S_OK )
*pdwEffect = DROPEFFECT_COPY;
else
*pdwEffect = DROPEFFECT_NONE;
return S_OK;
}
//---------------------------------------------------------------------------
/* for visual feedback */
STDMETHODIMP TDropTarget::DragOver( DWORD grfKeyState, POINTL pt,
DWORD *pdwEffect )
{
return S_OK;
}
//---------------------------------------------------------------------------
/* remove visual feedback */
STDMETHODIMP TDropTarget::DragLeave()
{
return S_OK;
}
//---------------------------------------------------------------------------
/* something has been dropped */
STDMETHODIMP TDropTarget::Drop( LPDATAOBJECT pDataObj, DWORD grfKeyState,
POINTL pt, DWORD *pdwEffect )
{
/* user has dropped on us -- get the CF_HDROP data from drag source */
FORMATETC fmtetc;
fmtetc.cfFormat = CF_HDROP;
fmtetc.ptd = NULL;
fmtetc.dwAspect = DVASPECT_CONTENT;
fmtetc.lindex = -1;
fmtetc.tymed = TYMED_HGLOBAL;
STGMEDIUM medium;
HRESULT hr = pDataObj->GetData( &fmtetc, &medium );
if( !FAILED(hr) )
{
/* grab a pointer to the data */
HGLOBAL HFiles = medium.hGlobal;
HDROP HDrop = (HDROP)GlobalLock( HFiles );
/* call the helper routine which will notify the Form of the drop */
HandleDrop( HDrop );
/* release the pointer to the memory */
GlobalUnlock( HFiles );
ReleaseStgMedium( &medium );
}
else
{
*pdwEffect = DROPEFFECT_NONE;
return hr;
}
return S_OK;
}
/***************************************************************************** /*****************************************************************************
* control.h: prototypes for control functions. * dragdrop.h: drag and drop management
***************************************************************************** *****************************************************************************
* Copyright (C) 2002 VideoLAN * Copyright (C) 2002 VideoLAN
* *
...@@ -20,10 +20,40 @@ ...@@ -20,10 +20,40 @@
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA. * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
*****************************************************************************/ *****************************************************************************/
bool ControlBack ( TObject *Sender ); #ifndef dragdropH
bool ControlStop ( TObject *Sender ); #define dragdropH
bool ControlPlay ( TObject *Sender ); //---------------------------------------------------------------------------
bool ControlPause( TObject *Sender ); #include <ole2.h>
bool ControlSlow ( TObject *Sender );
bool ControlFast ( TObject *Sender );
#define WM_OLEDROP WM_USER + 1
//---------------------------------------------------------------------------
class TDropTarget : public IDropTarget
{
public:
__fastcall TDropTarget( HWND HForm );
__fastcall ~TDropTarget();
protected:
/* IUnknown methods */
STDMETHOD(QueryInterface)( REFIID riid, void FAR* FAR* ppvObj );
STDMETHOD_(ULONG, AddRef)();
STDMETHOD_(ULONG, Release)();
/* IDropTarget methods */
STDMETHOD(DragEnter)( LPDATAOBJECT pDataObj, DWORD grfKeyState,
POINTL pt, DWORD *pdwEffect );
STDMETHOD(DragOver)( DWORD grfKeyState, POINTL pt, DWORD *pdwEffect );
STDMETHOD(DragLeave)();
STDMETHOD(Drop)( LPDATAOBJECT pDataObj, DWORD grfKeyState,
POINTL pt, DWORD *pdwEffect );
private:
unsigned long References;
HWND FormHandle;
/* helper function */
void __fastcall HandleDrop( HDROP HDrop );
};
//---------------------------------------------------------------------------
#endif
...@@ -27,9 +27,9 @@ ...@@ -27,9 +27,9 @@
#include <vlc/intf.h> #include <vlc/intf.h>
#include <vlc/vout.h> #include <vlc/vout.h>
#include "dragdrop.h"
#include "mainframe.h" #include "mainframe.h"
#include "menu.h" #include "menu.h"
#include "control.h"
#include "disc.h" #include "disc.h"
#include "network.h" #include "network.h"
#include "about.h" #include "about.h"
...@@ -42,7 +42,6 @@ ...@@ -42,7 +42,6 @@
#include "netutils.h" #include "netutils.h"
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
//#pragma package(smart_init)
#pragma link "CSPIN" #pragma link "CSPIN"
#pragma resource "*.dfm" #pragma resource "*.dfm"
...@@ -66,8 +65,18 @@ __fastcall TMainFrameDlg::TMainFrameDlg( ...@@ -66,8 +65,18 @@ __fastcall TMainFrameDlg::TMainFrameDlg(
Caption = VOUT_TITLE " (Win32 interface)"; Caption = VOUT_TITLE " (Win32 interface)";
StringListPref = new TStringList(); StringListPref = new TStringList();
Translate( this ); Translate( this );
/* drag and drop stuff */
/* initialize the OLE library */
OleInitialize( NULL );
/* TDropTarget will send the WM_OLEDROP message to the form */
lpDropTarget = (LPDROPTARGET)new TDropTarget( this->Handle );
CoLockObjectExternal( lpDropTarget, true, true );
/* register the form as a drop target */
RegisterDragDrop( this->Handle, lpDropTarget );
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
__fastcall TMainFrameDlg::~TMainFrameDlg() __fastcall TMainFrameDlg::~TMainFrameDlg()
...@@ -96,8 +105,6 @@ void __fastcall TMainFrameDlg::TrackBarChange( TObject *Sender ) ...@@ -96,8 +105,6 @@ void __fastcall TMainFrameDlg::TrackBarChange( TObject *Sender )
* the stream. It is called whenever the slider changes its value. * the stream. It is called whenever the slider changes its value.
* The lock has to be taken before the function is called */ * The lock has to be taken before the function is called */
// vlc_mutex_lock( &p_intf->p_sys->p_input->stream.stream_lock );
if( p_intf->p_sys->p_input != NULL ) if( p_intf->p_sys->p_input != NULL )
{ {
#define p_area p_intf->p_sys->p_input->stream.p_selected_area #define p_area p_intf->p_sys->p_input->stream.p_selected_area
...@@ -109,8 +116,6 @@ void __fastcall TMainFrameDlg::TrackBarChange( TObject *Sender ) ...@@ -109,8 +116,6 @@ void __fastcall TMainFrameDlg::TrackBarChange( TObject *Sender )
( p_area->i_size * Value ) / (off_t)SLIDER_MAX_VALUE ); ( p_area->i_size * Value ) / (off_t)SLIDER_MAX_VALUE );
#undef p_area #undef p_area
} }
// vlc_mutex_unlock( &p_intf->p_sys->p_input->stream.stream_lock );
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TMainFrameDlg::FormClose( TObject *Sender, void __fastcall TMainFrameDlg::FormClose( TObject *Sender,
...@@ -120,6 +125,14 @@ void __fastcall TMainFrameDlg::FormClose( TObject *Sender, ...@@ -120,6 +125,14 @@ void __fastcall TMainFrameDlg::FormClose( TObject *Sender,
p_intf->p_vlc->b_die = VLC_TRUE; p_intf->p_vlc->b_die = VLC_TRUE;
vlc_mutex_unlock( &p_intf->change_lock ); vlc_mutex_unlock( &p_intf->change_lock );
/* remove the form from the list of drop targets */
RevokeDragDrop( this->Handle );
lpDropTarget->Release();
CoLockObjectExternal( lpDropTarget, false, true );
/* uninitialize the OLE library */
OleUninitialize();
/* we don't destroy the form immediatly */ /* we don't destroy the form immediatly */
Action = caHide; Action = caHide;
} }
...@@ -131,28 +144,13 @@ void __fastcall TMainFrameDlg::FormClose( TObject *Sender, ...@@ -131,28 +144,13 @@ void __fastcall TMainFrameDlg::FormClose( TObject *Sender,
****************************************************************************/ ****************************************************************************/
void __fastcall TMainFrameDlg::OpenFileActionExecute( TObject *Sender ) void __fastcall TMainFrameDlg::OpenFileActionExecute( TObject *Sender )
{ {
AnsiString FileName;
playlist_t * p_playlist;
p_playlist = (playlist_t *)vlc_object_find( p_intf,
VLC_OBJECT_PLAYLIST, FIND_ANYWHERE );
if( p_playlist == NULL )
{
return;
}
if( OpenDialog1->Execute() ) if( OpenDialog1->Execute() )
{ {
/* add the new file to the interface playlist */ /* add the new file to the interface playlist */
FileName = OpenDialog1->FileName; p_intf->p_sys->p_playwin->Add( OpenDialog1->FileName,
playlist_Add( p_playlist, (char*)FileName.c_str(), PLAYLIST_APPEND | PLAYLIST_GO,
PLAYLIST_APPEND | PLAYLIST_GO, PLAYLIST_END ); PLAYLIST_END );
/* update the plugin display */
p_intf->p_sys->p_playwin->UpdateGrid( p_playlist );
}; };
vlc_object_release( p_playlist );
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TMainFrameDlg::OpenDiscActionExecute( TObject *Sender ) void __fastcall TMainFrameDlg::OpenDiscActionExecute( TObject *Sender )
...@@ -206,16 +204,7 @@ void __fastcall TMainFrameDlg::PlaylistActionExecute( TObject *Sender ) ...@@ -206,16 +204,7 @@ void __fastcall TMainFrameDlg::PlaylistActionExecute( TObject *Sender )
} }
else else
{ {
playlist_t * p_playlist; p_playwin->UpdateGrid();
p_playlist = (playlist_t *)vlc_object_find( p_intf,
VLC_OBJECT_PLAYLIST, FIND_ANYWHERE );
if( p_playlist == NULL )
{
return;
}
p_playwin->UpdateGrid( p_playlist );
vlc_object_release( p_playlist );
p_playwin->Show(); p_playwin->Show();
} }
} }
...@@ -239,32 +228,32 @@ void __fastcall TMainFrameDlg::AboutActionExecute( TObject *Sender ) ...@@ -239,32 +228,32 @@ void __fastcall TMainFrameDlg::AboutActionExecute( TObject *Sender )
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TMainFrameDlg::BackActionExecute( TObject *Sender ) void __fastcall TMainFrameDlg::BackActionExecute( TObject *Sender )
{ {
ControlBack( Sender ); /* TODO */
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TMainFrameDlg::PlayActionExecute( TObject *Sender ) void __fastcall TMainFrameDlg::PlayActionExecute( TObject *Sender )
{ {
ControlPlay( Sender ); p_intf->p_sys->p_playwin->Play();
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TMainFrameDlg::PauseActionExecute( TObject *Sender ) void __fastcall TMainFrameDlg::PauseActionExecute( TObject *Sender )
{ {
ControlPause( Sender ); p_intf->p_sys->p_playwin->Pause();
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TMainFrameDlg::StopActionExecute( TObject *Sender ) void __fastcall TMainFrameDlg::StopActionExecute( TObject *Sender )
{ {
ControlStop( Sender ); p_intf->p_sys->p_playwin->Stop();
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TMainFrameDlg::SlowActionExecute( TObject *Sender ) void __fastcall TMainFrameDlg::SlowActionExecute( TObject *Sender )
{ {
ControlSlow( Sender ); p_intf->p_sys->p_playwin->Slow();
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TMainFrameDlg::FastActionExecute( TObject *Sender ) void __fastcall TMainFrameDlg::FastActionExecute( TObject *Sender )
{ {
ControlFast( Sender ); p_intf->p_sys->p_playwin->Fast();
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TMainFrameDlg::PreviousActionExecute(TObject *Sender) void __fastcall TMainFrameDlg::PreviousActionExecute(TObject *Sender)
...@@ -330,9 +319,41 @@ void __fastcall TMainFrameDlg::EjectActionExecute( TObject *Sender ) ...@@ -330,9 +319,41 @@ void __fastcall TMainFrameDlg::EjectActionExecute( TObject *Sender )
//-------------------------------------------------------------------------- //--------------------------------------------------------------------------
/*****************************************************************************
* External drop handling
*****************************************************************************/
void __fastcall TMainFrameDlg::OnDrop( TMessage &Msg )
{
/* find the number of files dropped */
int num_files = DragQueryFile( (HDROP)Msg.WParam, 0xFFFFFFFF,
(LPSTR)NULL, NULL );
/* append each file to the playlist */
for( int i = 0; i < num_files; i++ )
{
/* find the length of the filename */
int name_length = DragQueryFile( (HDROP)Msg.WParam, i, NULL, NULL ) + 1;
/* get the filename */
char *FileName = new char[name_length];
DragQueryFile( (HDROP)Msg.WParam, i, FileName, name_length );
/* add the new file to the playlist */
p_intf->p_sys->p_playwin->Add( FileName, PLAYLIST_APPEND | PLAYLIST_GO,
PLAYLIST_END );
delete[] FileName;
}
DragFinish( (HDROP)Msg.WParam );
Msg.Result = 0;
}
//--------------------------------------------------------------------------
/***************************************************************************** /*****************************************************************************
* Menu and popup callbacks * Menu and popup callbacks
****************************************************************************/ *****************************************************************************/
void __fastcall TMainFrameDlg::MenuHideinterfaceClick( TObject *Sender ) void __fastcall TMainFrameDlg::MenuHideinterfaceClick( TObject *Sender )
{ {
this->SendToBack(); this->SendToBack();
......
...@@ -37,6 +37,14 @@ ...@@ -37,6 +37,14 @@
#include <ExtCtrls.hpp> #include <ExtCtrls.hpp>
#include "CSPIN.h" #include "CSPIN.h"
#include <ActnList.hpp> #include <ActnList.hpp>
#include <oleidl.h> /* for drag and drop */
/*****************************************************************************
* This message is sent to the controls registered as drop targets
*****************************************************************************/
#define WM_OLEDROP WM_USER + 1
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
class TMainFrameDlg : public TForm class TMainFrameDlg : public TForm
{ {
...@@ -193,6 +201,11 @@ __published: // IDE-managed Components ...@@ -193,6 +201,11 @@ __published: // IDE-managed Components
void __fastcall NextChapterActionExecute( TObject *Sender ); void __fastcall NextChapterActionExecute( TObject *Sender );
private: // User declarations private: // User declarations
intf_thread_t *p_intf; intf_thread_t *p_intf;
/* drag and drop handling */
LPDROPTARGET lpDropTarget;
BEGIN_MESSAGE_MAP
MESSAGE_HANDLER( WM_OLEDROP, TMessage, OnDrop )
END_MESSAGE_MAP( TForm )
public: // User declarations public: // User declarations
TStringList *StringListPref; /* stores config dialogs */ TStringList *StringListPref; /* stores config dialogs */
__fastcall TMainFrameDlg( TComponent* Owner, intf_thread_t *_p_intf ); __fastcall TMainFrameDlg( TComponent* Owner, intf_thread_t *_p_intf );
...@@ -209,6 +222,7 @@ public: // User declarations ...@@ -209,6 +222,7 @@ public: // User declarations
void __fastcall PopupAudioClick( TObject *Sender ); void __fastcall PopupAudioClick( TObject *Sender );
void __fastcall PopupSubtitleClick( TObject *Sender ); void __fastcall PopupSubtitleClick( TObject *Sender );
void __fastcall PopupNavigationClick( TObject *Sender ); void __fastcall PopupNavigationClick( TObject *Sender );
void __fastcall OnDrop( TMessage &Msg );
}; };
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
#endif #endif
...@@ -32,8 +32,8 @@ ...@@ -32,8 +32,8 @@
void __fastcall Translate( TForm *Form ) void __fastcall Translate( TForm *Form )
{ {
#if 0 #if 0
Form->Hint = N_( Form->Hint ); Form->Hint = _( Form->Hint );
Form->Caption = N_( Form->Caption ); Form->Caption = _( Form->Caption );
int i; int i;
for( i = 0; i < Form->ComponentCount; i++ ) for( i = 0; i < Form->ComponentCount; i++ )
...@@ -49,12 +49,12 @@ void __fastcall Translate( TForm *Form ) ...@@ -49,12 +49,12 @@ void __fastcall Translate( TForm *Form )
if( Component->InheritsFrom( __classid( TControl ) ) ) if( Component->InheritsFrom( __classid( TControl ) ) )
{ {
TControl *Object = (TControl *) Component; TControl *Object = (TControl *) Component;
Object->Hint = N_( Object->Hint ); Object->Hint = _( Object->Hint );
} }
else if( Component->InheritsFrom( __classid( TMenuItem ) ) ) else if( Component->InheritsFrom( __classid( TMenuItem ) ) )
{ {
TMenuItem *Object = (TMenuItem *) Component; TMenuItem *Object = (TMenuItem *) Component;
Object->Hint = N_( Object->Hint ); Object->Hint = _( Object->Hint );
} }
} }
...@@ -64,47 +64,47 @@ void __fastcall Translate( TForm *Form ) ...@@ -64,47 +64,47 @@ void __fastcall Translate( TForm *Form )
if( Component->InheritsFrom( __classid( TMenuItem ) ) ) if( Component->InheritsFrom( __classid( TMenuItem ) ) )
{ {
TMenuItem *Object = (TMenuItem *) Component; TMenuItem *Object = (TMenuItem *) Component;
Object->Caption = N_( Object->Caption ); Object->Caption = _( Object->Caption );
} }
else if( Component->InheritsFrom( __classid( TLabel ) ) ) else if( Component->InheritsFrom( __classid( TLabel ) ) )
{ {
TLabel *Object = (TLabel *) Component; TLabel *Object = (TLabel *) Component;
Object->Caption = N_( Object->Caption ); Object->Caption = _( Object->Caption );
} }
else if( Component->InheritsFrom( __classid( TButton ) ) ) else if( Component->InheritsFrom( __classid( TButton ) ) )
{ {
TButton *Object = (TButton *) Component; TButton *Object = (TButton *) Component;
Object->Caption = N_( Object->Caption ); Object->Caption = _( Object->Caption );
} }
else if( Component->InheritsFrom( __classid( TToolButton ) ) ) else if( Component->InheritsFrom( __classid( TToolButton ) ) )
{ {
TToolButton *Object = (TToolButton *) Component; TToolButton *Object = (TToolButton *) Component;
Object->Caption = N_( Object->Caption ); Object->Caption = _( Object->Caption );
} }
else if( Component->InheritsFrom( __classid( TRadioButton ) ) ) else if( Component->InheritsFrom( __classid( TRadioButton ) ) )
{ {
TRadioButton *Object = (TRadioButton *) Component; TRadioButton *Object = (TRadioButton *) Component;
Object->Caption = N_( Object->Caption ); Object->Caption = _( Object->Caption );
} }
else if( Component->InheritsFrom( __classid( TCheckBox ) ) ) else if( Component->InheritsFrom( __classid( TCheckBox ) ) )
{ {
TCheckBox *Object = (TCheckBox *) Component; TCheckBox *Object = (TCheckBox *) Component;
Object->Caption = N_( Object->Caption ); Object->Caption = _( Object->Caption );
} }
else if( Component->InheritsFrom( __classid( TRadioGroup ) ) ) else if( Component->InheritsFrom( __classid( TRadioGroup ) ) )
{ {
TRadioGroup *Object = (TRadioGroup *) Component; TRadioGroup *Object = (TRadioGroup *) Component;
Object->Caption = N_( Object->Caption ); Object->Caption = _( Object->Caption );
} }
else if( Component->InheritsFrom( __classid( TGroupBox ) ) ) else if( Component->InheritsFrom( __classid( TGroupBox ) ) )
{ {
TGroupBox *Object = (TGroupBox *) Component; TGroupBox *Object = (TGroupBox *) Component;
Object->Caption = N_( Object->Caption ); Object->Caption = _( Object->Caption );
} }
else if( Component->InheritsFrom( __classid( TTabSheet ) ) ) else if( Component->InheritsFrom( __classid( TTabSheet ) ) )
{ {
TTabSheet *Object = (TTabSheet *) Component; TTabSheet *Object = (TTabSheet *) Component;
Object->Caption = N_( Object->Caption ); Object->Caption = _( Object->Caption );
} }
else if( Component->InheritsFrom( __classid( TListView ) ) ) else if( Component->InheritsFrom( __classid( TListView ) ) )
{ {
...@@ -112,7 +112,7 @@ void __fastcall Translate( TForm *Form ) ...@@ -112,7 +112,7 @@ void __fastcall Translate( TForm *Form )
int iCol; int iCol;
for( iCol = 0; iCol < Object->Columns->Count; iCol++ ) for( iCol = 0; iCol < Object->Columns->Count; iCol++ )
Object->Columns->Items[iCol]->Caption = Object->Columns->Items[iCol]->Caption =
N_( Object->Columns->Items[iCol]->Caption ); _( Object->Columns->Items[iCol]->Caption );
} }
} }
...@@ -122,12 +122,12 @@ void __fastcall Translate( TForm *Form ) ...@@ -122,12 +122,12 @@ void __fastcall Translate( TForm *Form )
if( Component->InheritsFrom( __classid( TEdit ) ) ) if( Component->InheritsFrom( __classid( TEdit ) ) )
{ {
TEdit *Object = (TEdit *) Component; TEdit *Object = (TEdit *) Component;
Object->Text = N_( Object->Text ); Object->Text = _( Object->Text );
} }
else if( Component->InheritsFrom( __classid( TComboBox ) ) ) else if( Component->InheritsFrom( __classid( TComboBox ) ) )
{ {
TComboBox *Object = (TComboBox *) Component; TComboBox *Object = (TComboBox *) Component;
Object->Text = N_( Object->Text ); Object->Text = _( Object->Text );
} }
} }
} }
......
...@@ -90,14 +90,6 @@ void __fastcall TNetworkDlg::BitBtnOkClick( TObject *Sender ) ...@@ -90,14 +90,6 @@ void __fastcall TNetworkDlg::BitBtnOkClick( TObject *Sender )
AnsiString Channel = ComboBoxCSAddress->Text; AnsiString Channel = ComboBoxCSAddress->Text;
unsigned int i_channel_port = SpinEditCSPort->Value; unsigned int i_channel_port = SpinEditCSPort->Value;
unsigned int i_port; unsigned int i_port;
playlist_t * p_playlist;
p_playlist = (playlist_t *)
vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST, FIND_ANYWHERE );
if( p_playlist == NULL )
{
return;
}
Hide(); Hide();
...@@ -112,11 +104,9 @@ void __fastcall TNetworkDlg::BitBtnOkClick( TObject *Sender ) ...@@ -112,11 +104,9 @@ void __fastcall TNetworkDlg::BitBtnOkClick( TObject *Sender )
/* Build source name */ /* Build source name */
Source = "udp:@:" + IntToStr( i_port ); Source = "udp:@:" + IntToStr( i_port );
playlist_Add( p_playlist, Source.c_str(), p_intf->p_sys->p_playwin->Add( Source,
PLAYLIST_APPEND | PLAYLIST_GO, PLAYLIST_END ); PLAYLIST_APPEND | PLAYLIST_GO,
PLAYLIST_END );
/* update the display */
p_intf->p_sys->p_playwin->UpdateGrid( p_playlist );
break; break;
/* UDP Multicast */ /* UDP Multicast */
...@@ -128,12 +118,9 @@ void __fastcall TNetworkDlg::BitBtnOkClick( TObject *Sender ) ...@@ -128,12 +118,9 @@ void __fastcall TNetworkDlg::BitBtnOkClick( TObject *Sender )
/* Build source name */ /* Build source name */
Source = "udp:@" + Address + ":" + IntToStr( i_port ); Source = "udp:@" + Address + ":" + IntToStr( i_port );
playlist_Add( p_playlist, Source.c_str(), p_intf->p_sys->p_playwin->Add( Source,
PLAYLIST_APPEND | PLAYLIST_GO, PLAYLIST_END ); PLAYLIST_APPEND | PLAYLIST_GO,
PLAYLIST_END );
/* update the display */
p_intf->p_sys->p_playwin->UpdateGrid( p_playlist );
break;
/* Channel server */ /* Channel server */
case 2: case 2:
...@@ -164,15 +151,12 @@ void __fastcall TNetworkDlg::BitBtnOkClick( TObject *Sender ) ...@@ -164,15 +151,12 @@ void __fastcall TNetworkDlg::BitBtnOkClick( TObject *Sender )
Source = "http://" + Address; Source = "http://" + Address;
} }
playlist_Add( p_playlist, Source.c_str(), p_intf->p_sys->p_playwin->Add( Source,
PLAYLIST_APPEND | PLAYLIST_GO, PLAYLIST_END ); PLAYLIST_APPEND | PLAYLIST_GO,
PLAYLIST_END );
/* update the display */
p_intf->p_sys->p_playwin->UpdateGrid( p_playlist );
break; break;
} }
vlc_object_release( p_playlist );
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TNetworkDlg::ChangeEnabled( int i_selected ) void __fastcall TNetworkDlg::ChangeEnabled( int i_selected )
......
...@@ -27,20 +27,51 @@ ...@@ -27,20 +27,51 @@
#include <vlc/intf.h> #include <vlc/intf.h>
#include "playlist.h" #include "playlist.h"
#include "dragdrop.h"
#include "misc.h" #include "misc.h"
#include "win32_common.h" #include "win32_common.h"
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
//#pragma package(smart_init)
#pragma resource "*.dfm" #pragma resource "*.dfm"
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
__fastcall TPlaylistDlg::TPlaylistDlg( _fastcall TPlaylistDlg::TPlaylistDlg(
TComponent* Owner, intf_thread_t *_p_intf ) : TForm( Owner ) TComponent* Owner, intf_thread_t *_p_intf ) : TForm( Owner )
{ {
p_intf = _p_intf; p_intf = _p_intf;
Icon = p_intf->p_sys->p_window->Icon; Icon = p_intf->p_sys->p_window->Icon;
Translate( this ); Translate( this );
/* store a pointer to the core playlist */
p_playlist = (playlist_t *)
vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST, FIND_ANYWHERE );
if( p_playlist == NULL )
{
msg_Err( p_intf, "cannot find a playlist object" );
}
/* drag and drop stuff */
/* initialize the OLE library */
OleInitialize( NULL );
/* TDropTarget will send the WM_OLEDROP message to the form */
lpDropTarget = (LPDROPTARGET)new TDropTarget( this->Handle );
CoLockObjectExternal( lpDropTarget, true, true );
/* register the listview as a drop target */
RegisterDragDrop( ListViewPlaylist->Handle, lpDropTarget );
}
//---------------------------------------------------------------------------
__fastcall TPlaylistDlg::~TPlaylistDlg()
{
/* release the core playlist */
vlc_object_release( p_playlist );
/* remove the listview from the list of drop targets */
RevokeDragDrop( ListViewPlaylist->Handle );
lpDropTarget->Release();
CoLockObjectExternal( lpDropTarget, false, true );
/* uninitialize the OLE library */
OleUninitialize();
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
char * __fastcall TPlaylistDlg::rindex( char *s, char c ) char * __fastcall TPlaylistDlg::rindex( char *s, char c )
...@@ -64,6 +95,16 @@ char * __fastcall TPlaylistDlg::rindex( char *s, char c ) ...@@ -64,6 +95,16 @@ char * __fastcall TPlaylistDlg::rindex( char *s, char c )
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
/*****************************************************************************
* External drop handling
*****************************************************************************/
void __fastcall TPlaylistDlg::OnDrop( TMessage &Msg )
{
p_intf->p_sys->p_window->OnDrop( Msg );
}
//--------------------------------------------------------------------------
/***************************************************************************** /*****************************************************************************
* Event handlers * Event handlers
****************************************************************************/ ****************************************************************************/
...@@ -88,12 +129,8 @@ void __fastcall TPlaylistDlg::PlayStreamActionExecute( TObject *Sender ) ...@@ -88,12 +129,8 @@ void __fastcall TPlaylistDlg::PlayStreamActionExecute( TObject *Sender )
TListItem *ItemStart; TListItem *ItemStart;
TItemStates Focused; TItemStates Focused;
playlist_t * p_playlist = (playlist_t *)
vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST, FIND_ANYWHERE );
if( p_playlist == NULL ) if( p_playlist == NULL )
{
return; return;
}
/* search the selected item */ /* search the selected item */
if( ListViewPlaylist->SelCount > 0 ) if( ListViewPlaylist->SelCount > 0 )
...@@ -110,10 +147,8 @@ void __fastcall TPlaylistDlg::PlayStreamActionExecute( TObject *Sender ) ...@@ -110,10 +147,8 @@ void __fastcall TPlaylistDlg::PlayStreamActionExecute( TObject *Sender )
Item = ListViewPlaylist->GetNextItem( ItemStart, sdAll, Focused ); Item = ListViewPlaylist->GetNextItem( ItemStart, sdAll, Focused );
} }
playlist_Goto( p_playlist, Item->Index - 1 ); playlist_Goto( p_playlist, Item->Index );
} }
vlc_object_release( p_playlist );
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TPlaylistDlg::ListViewPlaylistKeyDown( TObject *Sender, void __fastcall TPlaylistDlg::ListViewPlaylistKeyDown( TObject *Sender,
...@@ -140,13 +175,9 @@ void __fastcall TPlaylistDlg::ListViewPlaylistCustomDrawItem( ...@@ -140,13 +175,9 @@ void __fastcall TPlaylistDlg::ListViewPlaylistCustomDrawItem(
/* set the background color */ /* set the background color */
if( Item->Index == p_intf->p_sys->i_playing ) if( Item->Index == p_intf->p_sys->i_playing )
{
Sender->Canvas->Brush->Color = clRed; Sender->Canvas->Brush->Color = clRed;
}
else else
{
Sender->Canvas->Brush->Color = clWhite; Sender->Canvas->Brush->Color = clWhite;
}
Sender->Canvas->FillRect( Rect ); Sender->Canvas->FillRect( Rect );
} }
...@@ -178,10 +209,8 @@ void __fastcall TPlaylistDlg::MenuAddUrlClick( TObject *Sender ) ...@@ -178,10 +209,8 @@ void __fastcall TPlaylistDlg::MenuAddUrlClick( TObject *Sender )
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TPlaylistDlg::DeleteSelectionActionExecute( TObject *Sender ) void __fastcall TPlaylistDlg::DeleteSelectionActionExecute( TObject *Sender )
{ {
#if 0 /* PLAYLIST TARASS */
/* user wants to delete a file in the queue */ /* user wants to delete a file in the queue */
int i_pos; int i_pos;
playlist_t *p_playlist = p_intf->p_vlc->p_playlist;
/* lock the struct */ /* lock the struct */
vlc_mutex_lock( &p_intf->change_lock ); vlc_mutex_lock( &p_intf->change_lock );
...@@ -195,18 +224,15 @@ void __fastcall TPlaylistDlg::DeleteSelectionActionExecute( TObject *Sender ) ...@@ -195,18 +224,15 @@ void __fastcall TPlaylistDlg::DeleteSelectionActionExecute( TObject *Sender )
} }
} }
/* Rebuild the ListView */ /* rebuild the ListView */
UpdateGrid( p_playlist ); UpdateGrid();
vlc_mutex_unlock( &p_intf->change_lock ); vlc_mutex_unlock( &p_intf->change_lock );
#endif
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TPlaylistDlg::DeleteAllActionExecute( TObject *Sender ) void __fastcall TPlaylistDlg::DeleteAllActionExecute( TObject *Sender )
{ {
#if 0 /* PLAYLIST TARASS */ int i_pos;
int i_pos;
playlist_t *p_playlist = p_intf->p_vlc->p_playlist;
/* lock the struct */ /* lock the struct */
vlc_mutex_lock( &p_intf->change_lock ); vlc_mutex_lock( &p_intf->change_lock );
...@@ -218,18 +244,15 @@ void __fastcall TPlaylistDlg::DeleteAllActionExecute( TObject *Sender ) ...@@ -218,18 +244,15 @@ void __fastcall TPlaylistDlg::DeleteAllActionExecute( TObject *Sender )
} }
/* Rebuild the ListView */ /* Rebuild the ListView */
UpdateGrid( p_playlist ); UpdateGrid();
vlc_mutex_unlock( &p_intf->change_lock ); vlc_mutex_unlock( &p_intf->change_lock );
#endif
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TPlaylistDlg::InvertSelectionActionExecute( TObject *Sender ) void __fastcall TPlaylistDlg::InvertSelectionActionExecute( TObject *Sender )
{ {
#if 0 /* PLAYLIST TARASS */
#define NOT( var ) ( (var) ? false : true ) #define NOT( var ) ( (var) ? false : true )
int i_pos; int i_pos;
playlist_t *p_playlist = p_intf->p_vlc->p_playlist;
TListItems *Items = ListViewPlaylist->Items; TListItems *Items = ListViewPlaylist->Items;
/* delete the items from the last to the first */ /* delete the items from the last to the first */
...@@ -238,7 +261,6 @@ void __fastcall TPlaylistDlg::InvertSelectionActionExecute( TObject *Sender ) ...@@ -238,7 +261,6 @@ void __fastcall TPlaylistDlg::InvertSelectionActionExecute( TObject *Sender )
Items->Item[i_pos]->Selected = NOT( Items->Item[i_pos]->Selected ); Items->Item[i_pos]->Selected = NOT( Items->Item[i_pos]->Selected );
} }
#undef NOT #undef NOT
#endif
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TPlaylistDlg::CropSelectionActionExecute( TObject *Sender ) void __fastcall TPlaylistDlg::CropSelectionActionExecute( TObject *Sender )
...@@ -250,9 +272,60 @@ void __fastcall TPlaylistDlg::CropSelectionActionExecute( TObject *Sender ) ...@@ -250,9 +272,60 @@ void __fastcall TPlaylistDlg::CropSelectionActionExecute( TObject *Sender )
/***************************************************************************** /*****************************************************************************
* Useful functions, needed by the event handlers * Useful functions, needed by the event handlers or by other windows
****************************************************************************/ ****************************************************************************/
void __fastcall TPlaylistDlg::UpdateGrid( playlist_t * p_playlist ) void __fastcall TPlaylistDlg::Add( AnsiString FileName, int i_mode, int i_pos )
{
if( p_playlist == NULL )
return;
playlist_Add( p_playlist, FileName.c_str(), i_mode, i_pos );
/* refresh the display */
UpdateGrid();
}
//---------------------------------------------------------------------------
void __fastcall TPlaylistDlg::Stop()
{
if( p_playlist == NULL )
return;
playlist_Stop( p_playlist );
}
//---------------------------------------------------------------------------
void __fastcall TPlaylistDlg::Play()
{
if( p_playlist == NULL )
return;
playlist_Play( p_playlist );
}
//---------------------------------------------------------------------------
void __fastcall TPlaylistDlg::Pause()
{
if( p_intf->p_sys->p_input != NULL )
{
input_SetStatus( p_intf->p_sys->p_input, INPUT_STATUS_PAUSE );
}
}
//---------------------------------------------------------------------------
void __fastcall TPlaylistDlg::Slow()
{
if( p_intf->p_sys->p_input != NULL )
{
input_SetStatus( p_intf->p_sys->p_input, INPUT_STATUS_SLOWER );
}
}
//---------------------------------------------------------------------------
void __fastcall TPlaylistDlg::Fast()
{
if( p_intf->p_sys->p_input != NULL )
{
input_SetStatus( p_intf->p_sys->p_input, INPUT_STATUS_FASTER );
}
}
//---------------------------------------------------------------------------
void __fastcall TPlaylistDlg::UpdateGrid()
{ {
int i_dummy; int i_dummy;
char *FileName; char *FileName;
...@@ -294,12 +367,8 @@ void __fastcall TPlaylistDlg::UpdateGrid( playlist_t * p_playlist ) ...@@ -294,12 +367,8 @@ void __fastcall TPlaylistDlg::UpdateGrid( playlist_t * p_playlist )
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TPlaylistDlg::Manage() void __fastcall TPlaylistDlg::Manage()
{ {
playlist_t * p_playlist = (playlist_t *)
vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST, FIND_ANYWHERE );
if( p_playlist == NULL ) if( p_playlist == NULL )
{
return; return;
}
vlc_mutex_lock( &p_playlist->object_lock ); vlc_mutex_lock( &p_playlist->object_lock );
...@@ -308,50 +377,34 @@ void __fastcall TPlaylistDlg::Manage() ...@@ -308,50 +377,34 @@ void __fastcall TPlaylistDlg::Manage()
p_intf->p_sys->i_playing = p_playlist->i_index; p_intf->p_sys->i_playing = p_playlist->i_index;
/* update the background color */ /* update the background color */
UpdateGrid( p_playlist ); UpdateGrid();
} }
vlc_mutex_unlock( &p_playlist->object_lock ); vlc_mutex_unlock( &p_playlist->object_lock );
vlc_object_release( p_playlist );
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TPlaylistDlg::DeleteItem( int i_pos ) void __fastcall TPlaylistDlg::DeleteItem( int i_pos )
{ {
playlist_t * p_playlist = (playlist_t *)
vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST, FIND_ANYWHERE );
if( p_playlist == NULL ) if( p_playlist == NULL )
{
return; return;
}
playlist_Delete( p_playlist, i_pos ); playlist_Delete( p_playlist, i_pos );
vlc_object_release( p_playlist );
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TPlaylistDlg::Previous() void __fastcall TPlaylistDlg::Previous()
{ {
playlist_t * p_playlist = (playlist_t *)
vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST, FIND_ANYWHERE );
if( p_playlist == NULL ) if( p_playlist == NULL )
{
return; return;
}
playlist_Prev( p_playlist ); playlist_Prev( p_playlist );
vlc_object_release( p_playlist );
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
void __fastcall TPlaylistDlg::Next() void __fastcall TPlaylistDlg::Next()
{ {
playlist_t * p_playlist = (playlist_t *)
vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST, FIND_ANYWHERE );
if( p_playlist == NULL ) if( p_playlist == NULL )
{
return; return;
}
playlist_Next( p_playlist ); playlist_Next( p_playlist );
vlc_object_release( p_playlist );
} }
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
...@@ -33,6 +33,13 @@ ...@@ -33,6 +33,13 @@
#include <ComCtrls.hpp> #include <ComCtrls.hpp>
#include <ActnList.hpp> #include <ActnList.hpp>
#include <oleidl.h> /* for drag and drop */
/*****************************************************************************
* This message is sent to the controls registered as drop targets
*****************************************************************************/
#define WM_OLEDROP WM_USER + 1
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
class TPlaylistDlg : public TForm class TPlaylistDlg : public TForm
{ {
...@@ -84,9 +91,23 @@ __published: // IDE-managed Components ...@@ -84,9 +91,23 @@ __published: // IDE-managed Components
private: // User declarations private: // User declarations
char * __fastcall rindex( char *s, char c ); char * __fastcall rindex( char *s, char c );
intf_thread_t *p_intf; intf_thread_t *p_intf;
playlist_t *p_playlist;
/* drag and drop handling */
LPDROPTARGET lpDropTarget;
BEGIN_MESSAGE_MAP
MESSAGE_HANDLER( WM_OLEDROP, TMessage, OnDrop )
END_MESSAGE_MAP( TForm )
void __fastcall OnDrop( TMessage &Msg );
public: // User declarations public: // User declarations
__fastcall TPlaylistDlg( TComponent* Owner, intf_thread_t *_p_intf ); __fastcall TPlaylistDlg( TComponent* Owner, intf_thread_t *_p_intf );
void __fastcall UpdateGrid( playlist_t * p_playlist ); __fastcall ~TPlaylistDlg();
void __fastcall Add( AnsiString FileName, int i_mode, int i_pos );
void __fastcall Stop();
void __fastcall Play();
void __fastcall Pause();
void __fastcall Slow();
void __fastcall Fast();
void __fastcall UpdateGrid();
void __fastcall Manage(); void __fastcall Manage();
void __fastcall DeleteItem( int i_pos ); void __fastcall DeleteItem( int i_pos );
void __fastcall Previous(); void __fastcall Previous();
......
...@@ -5,11 +5,11 @@ USEFORM("playlist.cpp", PlaylistDlg); ...@@ -5,11 +5,11 @@ USEFORM("playlist.cpp", PlaylistDlg);
USEFORM("preferences.cpp", PreferencesDlg); USEFORM("preferences.cpp", PreferencesDlg);
USEFORM("about.cpp", AboutDlg); USEFORM("about.cpp", AboutDlg);
USEFORM("disc.cpp", DiscDlg); USEFORM("disc.cpp", DiscDlg);
USEUNIT("control.cpp");
USE("win32_common.h", File); USE("win32_common.h", File);
USEUNIT("menu.cpp"); USEUNIT("menu.cpp");
USEFORM("messages.cpp", MessagesDlg); USEFORM("messages.cpp", MessagesDlg);
USEUNIT("misc.cpp"); USEUNIT("misc.cpp");
USEUNIT("dragdrop.cpp");
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
This file is used by the project manager only and should be treated like the project file This file is used by the project manager only and should be treated like the project file
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
<VERSION value="BCB.05.03"/> <VERSION value="BCB.05.03"/>
<PROJECT value="libwin32_plugin.dll"/> <PROJECT value="libwin32_plugin.dll"/>
<OBJFILES value="win32.obj mainframe.obj network.obj playlist.obj preferences.obj about.obj <OBJFILES value="win32.obj mainframe.obj network.obj playlist.obj preferences.obj about.obj
disc.obj control.obj menu.obj messages.obj misc.obj"/> disc.obj menu.obj messages.obj misc.obj dragdrop.obj"/>
<RESFILES value=""/> <RESFILES value=""/>
<DEFFILE value=""/> <DEFFILE value=""/>
<RESDEPEN value="$(RESFILES) mainframe.dfm network.dfm playlist.dfm preferences.dfm <RESDEPEN value="$(RESFILES) mainframe.dfm network.dfm playlist.dfm preferences.dfm
...@@ -26,8 +26,8 @@ ...@@ -26,8 +26,8 @@
<USERDEFINES value="_DEBUG;WIN32;__VLC__;__PLUGIN__;MODULE_NAME_IS_win32"/> <USERDEFINES value="_DEBUG;WIN32;__VLC__;__PLUGIN__;MODULE_NAME_IS_win32"/>
<SYSDEFINES value="NO_STRICT"/> <SYSDEFINES value="NO_STRICT"/>
<MAINSOURCE value="win32.bpf"/> <MAINSOURCE value="win32.bpf"/>
<INCLUDEPATH value="..\..\win32;$(BCB)\include;$(BCB)\include\vcl;..\..\..\include;..\..\.."/> <INCLUDEPATH value="F:\ProgInst\Borland\CBuilder5\Bin;..\..\win32;$(BCB)\include;$(BCB)\include\vcl;..\..\..\include;..\..\.."/>
<LIBPATH value="..\..\win32;$(BCB)\lib\obj;$(BCB)\lib"/> <LIBPATH value="F:\ProgInst\Borland\CBuilder5\Bin;..\..\win32;$(BCB)\lib\obj;$(BCB)\lib"/>
<WARNINGS value="-w-par"/> <WARNINGS value="-w-par"/>
</MACROS> </MACROS>
<OPTIONS> <OPTIONS>
...@@ -112,4 +112,4 @@ ActiveLang= ...@@ -112,4 +112,4 @@ ActiveLang=
ProjectLang= ProjectLang=
RootDir= RootDir=
</IDEOPTIONS> </IDEOPTIONS>
</PROJECT> </PROJECT>
\ No newline at end of file
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment