]> git.sesse.net Git - vlc/commitdiff
New simple playlist.
authorTony Castley <tcastley@videolan.org>
Fri, 15 Jun 2001 09:07:10 +0000 (09:07 +0000)
committerTony Castley <tcastley@videolan.org>
Fri, 15 Jun 2001 09:07:10 +0000 (09:07 +0000)
Enable/disable controls depending on what is in the playlist.

plugins/beos/InterfaceWindow.cpp
plugins/beos/InterfaceWindow.h
plugins/beos/Makefile
plugins/beos/MediaControlView.cpp [new file with mode: 0644]
plugins/beos/MediaControlView.h [new file with mode: 0644]
plugins/beos/MsgVals.h
plugins/beos/PlayListWindow.cpp [new file with mode: 0644]
plugins/beos/PlayListWindow.h [new file with mode: 0644]

index fcd439d6b84b9c99b05397a7bfdd32be65b61852..1d110ff24bc0885ac316ee89e7e8736ecf25bd45 100644 (file)
@@ -2,7 +2,7 @@
  * InterfaceWindow.cpp: beos interface
  *****************************************************************************
  * Copyright (C) 1999, 2000, 2001 VideoLAN
- * $Id: InterfaceWindow.cpp,v 1.1 2001/06/02 09:42:26 tcastley Exp $
+ * $Id: InterfaceWindow.cpp,v 1.2 2001/06/15 09:07:10 tcastley Exp $
  *
  * Authors: Jean-Marc Dressler <polux@via.ecp.fr>
  *          Samuel Hocevar <sam@zoy.org>
@@ -25,7 +25,6 @@
  *****************************************************************************/
 #include "defs.h"
 
 /* System headers */
 #include <kernel/OS.h>
 #include <InterfaceKit.h>
@@ -54,9 +53,9 @@ extern "C"
 
 /* BeOS interface headers */
 #include "MsgVals.h"
+#include "MediaControlView.h"
 #include "InterfaceWindow.h"
-#include "Bitmaps.h"
-#include "TransportButton.h"
+#include "PlayListWindow.h"
 
 /*****************************************************************************
  * InterfaceWindow
@@ -70,30 +69,36 @@ InterfaceWindow::InterfaceWindow( BRect frame, const char *name,
 {
     file_panel = NULL;
     p_intf = p_interface;
-    BRect ButtonRect;
-    float xStart = 5.0;
-    float yStart = 20.0;
+    BRect controlRect(0,0,0,0);
+    b_empty_playlist = (p_main->p_playlist->i_size < 0);
 
+    /* set the title bar */
     SetName( "interface" );
-    SetTitle(VOUT_TITLE " (BeOS interface)");
-    BRect rect(0, 0, 0, 0);
+    SetTitle(VOUT_TITLE);
 
+    /* set up the main menu */
     BMenuBar *menu_bar;
-    menu_bar = new BMenuBar(rect, "main menu");
+    menu_bar = new BMenuBar(controlRect, "main menu");
     AddChild( menu_bar );
 
     BMenu *mFile;
     BMenu *mAudio;
     CDMenu *cd_menu;
-
+    
+    /* Add the file Menu */
     BMenuItem *mItem;
-
     menu_bar->AddItem( mFile = new BMenu( "File" ) );
     menu_bar->ResizeToPreferred();
     mFile->AddItem( mItem = new BMenuItem( "Open File" B_UTF8_ELLIPSIS,
                                            new BMessage(OPEN_FILE), 'O') );
+    
     cd_menu = new CDMenu( "Open Disc" );
     mFile->AddItem( cd_menu );
+    
+    mFile->AddSeparatorItem();
+    mFile->AddItem( mItem = new BMenuItem( "Play List" B_UTF8_ELLIPSIS,
+                                           new BMessage(OPEN_PLAYLIST), 'P') );
+    
     mFile->AddSeparatorItem();
     mFile->AddItem( mItem = new BMenuItem( "About" B_UTF8_ELLIPSIS,
                                        new BMessage(B_ABOUT_REQUESTED), 'A') );
@@ -101,101 +106,23 @@ InterfaceWindow::InterfaceWindow( BRect frame, const char *name,
     mFile->AddItem(mItem = new BMenuItem( "Quit",
                                         new BMessage(B_QUIT_REQUESTED), 'Q') );
 
+    /* Add the Audio menu */
     menu_bar->AddItem ( mAudio = new BMenu( "Audio" ) );
     menu_bar->ResizeToPreferred();
     mAudio->AddItem( new LanguageMenu( "Language", AUDIO_ES, p_intf ) );
     mAudio->AddItem( new LanguageMenu( "Subtitles", SPU_ES, p_intf ) );
 
-
-    rect = Bounds();
-    rect.top += menu_bar->Bounds().IntegerHeight() + 1;
-
-    BBox* p_view;
-    p_view = new BBox( rect, NULL, B_FOLLOW_ALL, B_WILL_DRAW, B_PLAIN_BORDER );
-    p_view->SetViewColor( ui_color(B_PANEL_BACKGROUND_COLOR) );
-
-    /* Buttons */
-    /* Slow play */
-    ButtonRect.SetLeftTop(BPoint(xStart, yStart));
-    ButtonRect.SetRightBottom(ButtonRect.LeftTop() + kSkipButtonSize);
-    xStart += kRewindBitmapWidth;
-    TransportButton* p_slow = new TransportButton(ButtonRect, B_EMPTY_STRING,
-                                            kSkipBackBitmapBits,
-                                            kPressedSkipBackBitmapBits,
-                                            kDisabledSkipBackBitmapBits,
-                                            new BMessage(SLOWER_PLAY));
-    p_view->AddChild( p_slow );
-
-    /* Play Pause */
-    ButtonRect.SetLeftTop(BPoint(xStart, yStart));
-    ButtonRect.SetRightBottom(ButtonRect.LeftTop() + kPlayButtonSize);
-    xStart += kPlayPauseBitmapWidth + 1.0;
-    PlayPauseButton* p_play = new PlayPauseButton(ButtonRect, B_EMPTY_STRING,
-                                            kPlayButtonBitmapBits,
-                                            kPressedPlayButtonBitmapBits,
-                                            kDisabledPlayButtonBitmapBits,
-                                            kPlayingPlayButtonBitmapBits,
-                                            kPressedPlayingPlayButtonBitmapBits,
-                                            kPausedPlayButtonBitmapBits,
-                                            kPressedPausedPlayButtonBitmapBits,
-                                            new BMessage(START_PLAYBACK));
-
-    p_view->AddChild( p_play );
-    /* p_play->SetPlaying(); */
-
-    /* Fast Foward */
-    ButtonRect.SetLeftTop(BPoint(xStart, yStart));
-    ButtonRect.SetRightBottom(ButtonRect.LeftTop() + kSkipButtonSize);
-    xStart += kRewindBitmapWidth;
-    TransportButton* p_fast = new TransportButton(ButtonRect, B_EMPTY_STRING,
-                                            kSkipForwardBitmapBits,
-                                            kPressedSkipForwardBitmapBits,
-                                            kDisabledSkipForwardBitmapBits,
-                                            new BMessage(FASTER_PLAY));
-    p_view->AddChild( p_fast );
-
-    /* Stop */
-    ButtonRect.SetLeftTop(BPoint(xStart, yStart));
-    ButtonRect.SetRightBottom(ButtonRect.LeftTop() + kStopButtonSize);
-    xStart += kStopBitmapWidth;
-    TransportButton* p_stop = new TransportButton(ButtonRect, B_EMPTY_STRING,
-                                            kStopButtonBitmapBits,
-                                            kPressedStopButtonBitmapBits,
-                                            kDisabledStopButtonBitmapBits,
-                                            new BMessage(STOP_PLAYBACK));
-    p_view->AddChild( p_stop );
-
-    ButtonRect.SetLeftTop(BPoint(xStart + 5, yStart + 6));
-    ButtonRect.SetRightBottom(ButtonRect.LeftTop() + kSpeakerButtonSize);
-    xStart += kSpeakerIconBitmapWidth;
-
-    TransportButton* p_mute = new TransportButton(ButtonRect, B_EMPTY_STRING,
-                                            kSpeakerIconBits,
-                                            kPressedSpeakerIconBits,
-                                            kSpeakerIconBits,
-                                            new BMessage(VOLUME_MUTE));
-
-    p_view->AddChild( p_mute );
-
-    /* Seek Status */
-    rgb_color fill_color = {0,255,0};
-    p_seek = new SeekSlider(BRect(5,2,255,15), this, 0, 100,
-                        B_TRIANGLE_THUMB);
-    p_seek->SetValue(0);
-    p_seek->UseFillColor(true, &fill_color);
-    p_view->AddChild( p_seek );
-
-    /* Volume Slider */
-    p_vol = new MediaSlider(BRect(xStart,20,255,30), new BMessage(VOLUME_CHG),
-                            0, VOLUME_MAX);
-    p_vol->SetValue(VOLUME_DEFAULT);
-    p_vol->UseFillColor(true, &fill_color);
-    p_view->AddChild( p_vol );
-
-    /* Set size and Show */
-    AddChild( p_view );
     ResizeTo(260,50 + menu_bar->Bounds().IntegerHeight()+1);
+    controlRect = Bounds();
+    controlRect.top += menu_bar->Bounds().IntegerHeight() + 1;
+
+    p_mediaControl = new MediaControlView( controlRect );
+    p_mediaControl->SetViewColor( ui_color(B_PANEL_BACKGROUND_COLOR) );
+
+    /* Show */
+    AddChild( p_mediaControl );
     Show();
+    
 }
 
 InterfaceWindow::~InterfaceWindow()
@@ -207,12 +134,20 @@ InterfaceWindow::~InterfaceWindow()
  *****************************************************************************/
 void InterfaceWindow::MessageReceived( BMessage * p_message )
 {
-    int vol_val = p_vol->Value();    // remember the current volume
-    static int playback_status;      // remember playback state
+    int vol_val = p_mediaControl->GetVolume();    // remember the current volume
+    int playback_status;      // remember playback state
     int     i_index;
     BAlert *alert;
 
     Activate();
+    if (p_intf->p_input)
+    {
+           playback_status = p_intf->p_input->stream.control.i_status;
+       }
+       else
+       {
+           playback_status = UNDEF_S;
+       }
 
     switch( p_message->what )
     {
@@ -232,6 +167,14 @@ void InterfaceWindow::MessageReceived( BMessage * p_message )
         file_panel->Show();
         break;
 
+       case OPEN_PLAYLIST:
+               {
+                   BRect rect(20,20,320,420);
+            PlayListWindow* playlist_window = new PlayListWindow(rect,
+                         "Playlist", (playlist_t *)p_main->p_playlist);
+            playlist_window->Show();
+        }
+               break;
     case OPEN_DVD:
         const char *psz_device;
         char psz_source[ B_FILE_NAME_LENGTH + 4 ];
@@ -241,6 +184,12 @@ void InterfaceWindow::MessageReceived( BMessage * p_message )
                       "dvd:%s", psz_device );
             psz_source[ strlen(psz_source) ] = '\0';
             intf_PlaylistAdd( p_main->p_playlist, PLAYLIST_END, (char*)psz_source );
+            if( p_intf->p_input != NULL )
+            {
+                p_intf->p_input->b_eof = 1;
+            }
+            intf_PlaylistJumpto( p_main->p_playlist, 
+                                 p_main->p_playlist->i_size - 1 );
         }
         break;
 
@@ -271,25 +220,13 @@ void InterfaceWindow::MessageReceived( BMessage * p_message )
 
     case START_PLAYBACK:
         /*  starts playing in normal mode */
-/*        if (p_intf->p_input != NULL )
-
-            if (p_main->p_aout != NULL)
-            {
-                p_main->p_aout->i_vol = vol_val;
-            }
-            snooze(400000);
-            input_SetStatus(p_intf->p_input, INPUT_STATUS_PLAY);
-            playback_status = PLAYING;
-        }
-        break;
-*/
 
     case PAUSE_PLAYBACK:
         /* toggle between pause and play */
         if( p_intf->p_input != NULL )
         {
             /* pause if currently playing */
-            if( playback_status == PLAYING )
+            if( playback_status == PLAYING_S )
             {
                 /* mute the sound */
                 vlc_mutex_lock( &p_aout_bank->lock );
@@ -300,13 +237,13 @@ void InterfaceWindow::MessageReceived( BMessage * p_message )
                     p_aout_bank->pp_aout[i_index]->i_volume = 0;
                 }
                 vlc_mutex_unlock( &p_aout_bank->lock );
+                snooze( 400000 );
                 
                 /* pause the movie */
                 input_SetStatus( p_intf->p_input, INPUT_STATUS_PAUSE );
                 vlc_mutex_lock( &p_main->p_playlist->change_lock );
                 p_main->p_playlist->b_stopped = 0;
                 vlc_mutex_unlock( &p_main->p_playlist->change_lock );
-                playback_status = PAUSED;
             }
             else
             {
@@ -325,7 +262,6 @@ void InterfaceWindow::MessageReceived( BMessage * p_message )
                 /* Start playing */
                 input_SetStatus( p_intf->p_input, INPUT_STATUS_PLAY );
                 p_main->p_playlist->b_stopped = 0;
-                playback_status = PLAYING;
             }
         }
         else
@@ -339,7 +275,7 @@ void InterfaceWindow::MessageReceived( BMessage * p_message )
                     vlc_mutex_unlock( &p_main->p_playlist->change_lock );
                     intf_PlaylistJumpto( p_main->p_playlist, 
                                          p_main->p_playlist->i_index );
-                    playback_status = PLAYING;
+                    p_main->p_playlist->b_stopped = 0;
                 }
                 else
                 {
@@ -476,6 +412,13 @@ void InterfaceWindow::MessageReceived( BMessage * p_message )
                 BPath path( &ref );
                 intf_PlaylistAdd( p_main->p_playlist,
                                   PLAYLIST_END, (char*)path.Path() );
+                if( p_intf->p_input != NULL )
+                {
+                    p_intf->p_input->b_eof = 1;
+                }
+                intf_PlaylistJumpto( p_main->p_playlist, 
+                                     p_main->p_playlist->i_size - 1 );
+                                  
              }
         }
         break;
@@ -484,6 +427,7 @@ void InterfaceWindow::MessageReceived( BMessage * p_message )
         BWindow::MessageReceived( p_message );
         break;
     }
+
 }
 
 /*****************************************************************************
@@ -492,25 +436,33 @@ void InterfaceWindow::MessageReceived( BMessage * p_message )
 void InterfaceWindow::updateInterface()
 {
     float progress;
-    bool seekNeeded = false;
-
-    if( acquire_sem(fScrubSem) == B_OK )
-    {
-        seekNeeded = true;
-    }
-    if( seekNeeded )
-    {
-        uint32 seekTo = (p_seek->Value() *
-                    p_intf->p_input->stream.p_selected_area->i_size) / 100;
-        input_Seek( p_intf->p_input, seekTo );
-        seekNeeded = false;
+    
+       if ( p_intf->p_input )
+       {
+        if ( acquire_sem(p_mediaControl->fScrubSem) == B_OK )
+        {
+            uint32 seekTo = (p_mediaControl->GetSeekTo() *
+                        p_intf->p_input->stream.p_selected_area->i_size) / 100;
+            input_Seek( p_intf->p_input, seekTo );
+        }
+        else if( Lock() )
+        {
+            progress = (100. * p_intf->p_input->stream.p_selected_area->i_tell) /
+                        p_intf->p_input->stream.p_selected_area->i_size;
+            p_mediaControl->SetStatus(p_intf->p_input->stream.control.i_status, 
+                                      p_intf->p_input->stream.control.i_rate);
+            p_mediaControl->SetProgress(progress);
+            Unlock();
+        }
     }
-    else if( Lock() )
+    if ( b_empty_playlist != (p_main->p_playlist->i_size < 1) )
     {
-        progress = (100. * p_intf->p_input->stream.p_selected_area->i_tell) /
-                    p_intf->p_input->stream.p_selected_area->i_size;
-        p_seek->SetValue(progress);
-        Unlock();
+        if (Lock())
+        {
+            b_empty_playlist = !b_empty_playlist;
+            p_mediaControl->SetEnabled( !b_empty_playlist );
+            Unlock();
+        }
     }
 }
 
@@ -643,7 +595,8 @@ int CDMenu::GetCD( const char *directory )
 /*****************************************************************************
  * LanguageMenu::LanguageMenu
  *****************************************************************************/
-LanguageMenu::LanguageMenu(const char *name, int menu_kind, intf_thread_t  *p_interface)
+LanguageMenu::LanguageMenu(const char *name, int menu_kind, 
+                            intf_thread_t  *p_interface)
     :BMenu(name)
 {
     kind = menu_kind;
@@ -740,100 +693,5 @@ int LanguageMenu::GetChannels()
 
 }
 
-/*****************************************************************************
- * MediaSlider
- *****************************************************************************/
-MediaSlider::MediaSlider( BRect frame, BMessage *p_message,
-                          int32 i_min, int32 i_max )
-            :BSlider(frame, NULL, NULL, p_message, i_min, i_max )
-{
-
-}
-
-MediaSlider::~MediaSlider()
-{
-
-}
-
-void MediaSlider::DrawThumb(void)
-{
-    BRect r;
-    BView *v;
-
-    rgb_color black = {0,0,0};
-    r = ThumbFrame();
-    v = OffscreenView();
-
-    if(IsEnabled())
-    {
-        v->SetHighColor(black);
-    }
-    else
-    {
-        v->SetHighColor(tint_color(black, B_LIGHTEN_2_TINT));
-    }
-
-    r.InsetBy(r.IntegerWidth()/4, r.IntegerHeight()/(4 * r.IntegerWidth() / r.IntegerHeight()));
-    v->StrokeEllipse(r);
-
-    if(IsEnabled())
-    {
-        v->SetHighColor(ui_color(B_PANEL_BACKGROUND_COLOR));
-    }
-    else
-    {
-        v->SetHighColor(tint_color(ui_color(B_PANEL_BACKGROUND_COLOR), B_LIGHTEN_2_TINT));
-    }
-
-    r.InsetBy(1,1);
-    v->FillEllipse(r);
-}
-
-/*****************************************************************************
- * SeekSlider
- *****************************************************************************/
-SeekSlider::SeekSlider( BRect frame, InterfaceWindow *p_owner, int32 i_min,
-                        int32 i_max, thumb_style thumbType = B_TRIANGLE_THUMB )
-           :MediaSlider( frame, NULL, i_min, i_max )
-{
-    fOwner = p_owner;
-    fMouseDown = false;
-}
-
-SeekSlider::~SeekSlider()
-{
-}
-
-/*****************************************************************************
- * SeekSlider::MouseDown
- *****************************************************************************/
-void SeekSlider::MouseDown(BPoint where)
-{
-    BSlider::MouseDown(where);
-    fOwner->fScrubSem = create_sem(1, "Vlc::fScrubSem");
-    fMouseDown = true;
-}
-
-/*****************************************************************************
- * SeekSlider::MouseUp
- *****************************************************************************/
-void SeekSlider::MouseMoved(BPoint where, uint32 code, const BMessage *message)
-{
-    BSlider::MouseMoved(where, code, message);
-    if (!fMouseDown)
-        return;
-    release_sem(fOwner->fScrubSem);
-}
-
-/*****************************************************************************
- * SeekSlider::MouseUp
- *****************************************************************************/
-void SeekSlider::MouseUp(BPoint where)
-{
-    BSlider::MouseUp(where);
-    delete_sem(fOwner->fScrubSem);
-    fOwner->fScrubSem = B_ERROR;
-    fMouseDown = false;
-}
 
 
index 260951e8979b7ad9ea5ed7bfd491ccfe70431a6e..9dcba51d68fbabe6f9700be78fbf12558d66a036 100644 (file)
@@ -2,7 +2,7 @@
  * InterfaceWindow.h: BeOS interface window class prototype
  *****************************************************************************
  * Copyright (C) 1999, 2000, 2001 VideoLAN
- * $Id: InterfaceWindow.h,v 1.10 2001/06/03 12:47:21 sam Exp $
+ * $Id: InterfaceWindow.h,v 1.11 2001/06/15 09:07:10 tcastley Exp $
  *
  * Authors: Jean-Marc Dressler <polux@via.ecp.fr>
  *          Tony Castley <tcastley@mail.powerup.com.au>
@@ -22,9 +22,7 @@
  * along with this program; if not, write to the Free Software
  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111, USA.
  *****************************************************************************/
-
-class SeekSlider;
-class MediaSlider;
+class MediaControlView;
 
 class CDMenu : public BMenu
 {
@@ -39,7 +37,8 @@ private:
 class LanguageMenu : public BMenu
 {
 public:
-       LanguageMenu(const char *name, int menu_kind, intf_thread_t  *p_interface);
+       LanguageMenu(const char *name, int menu_kind, 
+                    intf_thread_t  *p_interface);
        ~LanguageMenu();
        void AttachedToWindow(void);
 private:
@@ -51,7 +50,8 @@ private:
 class InterfaceWindow : public BWindow
 {
 public:
-    InterfaceWindow( BRect frame, const char *name, intf_thread_t  *p_intf );
+    InterfaceWindow( BRect frame, const char *name, 
+                     intf_thread_t  *p_interface );
     ~InterfaceWindow();
 
     // standard window member
@@ -59,57 +59,14 @@ public:
     virtual void    MessageReceived(BMessage *message);
        void                    updateInterface();
            
-       SeekSlider * p_seek;
-       sem_id  fScrubSem;
-       bool    fSeeking;
+       MediaControlView *p_mediaControl;
 
 private:       
     intf_thread_t  *p_intf;
-       MediaSlider * p_vol;
-       BCheckBox * p_mute;
+    bool            b_empty_playlist;
        BFilePanel *file_panel;
        es_descriptor_t *  p_audio_es;
     es_descriptor_t *  p_spu_es;
 
 };
 
-class InterfaceView : public BView
-{
-public:
-    InterfaceView();
-    ~InterfaceView();
-
-    virtual void    MessageReceived(BMessage *message);
-};
-
-
-class MediaSlider : public BSlider
-{
-public:
-       MediaSlider(BRect frame,
-                               BMessage *message,
-                               int32 minValue,
-                               int32 maxValue);
-       ~MediaSlider();
-       virtual void DrawThumb(void);
-};
-                               
-
-class SeekSlider : public MediaSlider
-{
-public:
-       SeekSlider(BRect frame,
-                               InterfaceWindow *owner,
-                               int32 minValue,
-                               int32 maxValue,
-                               thumb_style thumbType = B_TRIANGLE_THUMB);
-
-       ~SeekSlider();
-       
-       virtual void MouseDown(BPoint);
-       virtual void MouseUp(BPoint pt);
-       virtual void MouseMoved(BPoint pt, uint32 c, const BMessage *m);
-private:
-       InterfaceWindow*        fOwner; 
-       bool fMouseDown;
-};
index dc83685ac590c9c12993512387d15fab91c5ded4..2daaf43bbf271541603e7c90c0d44846e2a325c2 100644 (file)
@@ -7,7 +7,7 @@
 # Objects
 #
 
-PLUGIN_CPP = beos.o aout_beos.o vout_beos.o intf_beos.o InterfaceWindow.o DrawingTidbits.o TransportButton.o
+PLUGIN_CPP = beos.o aout_beos.o vout_beos.o intf_beos.o InterfaceWindow.o DrawingTidbits.o TransportButton.o PlayListWindow.o MediaControlView.o
 BUILTIN_CPP = $(PLUGIN_CPP:%.o=BUILTIN_%.o)
 
 ALL_OBJ = $(PLUGIN_CPP) $(BUILTIN_CPP)
diff --git a/plugins/beos/MediaControlView.cpp b/plugins/beos/MediaControlView.cpp
new file mode 100644 (file)
index 0000000..243d925
--- /dev/null
@@ -0,0 +1,277 @@
+/*****************************************************************************
+ * MediaControlView.cpp: beos interface
+ *****************************************************************************
+ * Copyright (C) 1999, 2000, 2001 VideoLAN
+ * $Id: MediaControlView.cpp,v 1.1 2001/06/15 09:07:10 tcastley Exp $
+ *
+ * Authors: Tony Castley <tony@castley.net>
+ *
+ * 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 "defs.h"
+
+/* System headers */
+#include <InterfaceKit.h>
+#include <AppKit.h>
+
+/* VLC headers */
+extern "C"
+{
+#include "config.h"
+#include "common.h"
+#include "threads.h"
+#include "mtime.h"
+#include "main.h"
+#include "tests.h"
+#include "stream_control.h"
+#include "input_ext-intf.h"
+#include "interface.h"
+#include "intf_msg.h"
+#include "intf_playlist.h"
+}
+
+/* BeOS interface headers */
+#include "MsgVals.h"
+#include "Bitmaps.h"
+#include "TransportButton.h"
+#include "MediaControlView.h"
+
+
+MediaControlView::MediaControlView( BRect frame )
+    : BBox( frame, NULL, B_FOLLOW_ALL, B_WILL_DRAW, B_PLAIN_BORDER )
+{
+       float xStart = HORZ_SPACE;
+       float yStart = VERT_SPACE;
+       fScrubSem = B_ERROR;
+       
+       BRect controlRect = BRect(xStart,yStart, 
+                                 frame.Width() - (HORZ_SPACE * 2), 15);
+       
+    /* Seek Status */
+    rgb_color fill_color = {0,255,0};
+    p_seek = new SeekSlider(controlRect, this, 0, 100, B_TRIANGLE_THUMB);
+    p_seek->SetValue(0);
+    p_seek->UseFillColor(true, &fill_color);
+    AddChild( p_seek );
+    yStart += 15 + VERT_SPACE;
+
+
+    /* Buttons */
+    /* Slow play */
+    controlRect.SetLeftTop(BPoint(xStart, yStart));
+    controlRect.SetRightBottom(controlRect.LeftTop() + kSkipButtonSize);
+    xStart += kRewindBitmapWidth;
+    p_slow = new TransportButton(controlRect, B_EMPTY_STRING,
+                                            kSkipBackBitmapBits,
+                                            kPressedSkipBackBitmapBits,
+                                            kDisabledSkipBackBitmapBits,
+                                            new BMessage(SLOWER_PLAY));
+    AddChild( p_slow );
+
+    /* Play Pause */
+    controlRect.SetLeftTop(BPoint(xStart, yStart));
+    controlRect.SetRightBottom(controlRect.LeftTop() + kPlayButtonSize);
+    xStart += kPlayPauseBitmapWidth + 1.0;
+    p_play = new PlayPauseButton(controlRect, B_EMPTY_STRING,
+                                            kPlayButtonBitmapBits,
+                                            kPressedPlayButtonBitmapBits,
+                                            kDisabledPlayButtonBitmapBits,
+                                            kPlayingPlayButtonBitmapBits,
+                                            kPressedPlayingPlayButtonBitmapBits,
+                                            kPausedPlayButtonBitmapBits,
+                                            kPressedPausedPlayButtonBitmapBits,
+                                            new BMessage(START_PLAYBACK));
+
+    AddChild( p_play );
+
+    /* Fast Foward */
+    controlRect.SetLeftTop(BPoint(xStart, yStart));
+    controlRect.SetRightBottom(controlRect.LeftTop() + kSkipButtonSize);
+    xStart += kRewindBitmapWidth;
+    p_fast = new TransportButton(controlRect, B_EMPTY_STRING,
+                                            kSkipForwardBitmapBits,
+                                            kPressedSkipForwardBitmapBits,
+                                            kDisabledSkipForwardBitmapBits,
+                                            new BMessage(FASTER_PLAY));
+    AddChild( p_fast );
+
+    /* Stop */
+    controlRect.SetLeftTop(BPoint(xStart, yStart));
+    controlRect.SetRightBottom(controlRect.LeftTop() + kStopButtonSize);
+    xStart += kStopBitmapWidth;
+    p_stop = new TransportButton(controlRect, B_EMPTY_STRING,
+                                            kStopButtonBitmapBits,
+                                            kPressedStopButtonBitmapBits,
+                                            kDisabledStopButtonBitmapBits,
+                                            new BMessage(STOP_PLAYBACK));
+    AddChild( p_stop );
+
+    controlRect.SetLeftTop(BPoint(xStart + 5, yStart + 6));
+    controlRect.SetRightBottom(controlRect.LeftTop() + kSpeakerButtonSize);
+    xStart += kSpeakerIconBitmapWidth;
+
+    p_mute = new TransportButton(controlRect, B_EMPTY_STRING,
+                                            kSpeakerIconBits,
+                                            kPressedSpeakerIconBits,
+                                            kSpeakerIconBits,
+                                            new BMessage(VOLUME_MUTE));
+
+    AddChild( p_mute );
+
+    /* Volume Slider */
+    p_vol = new MediaSlider(BRect(xStart,20,255,30), new BMessage(VOLUME_CHG),
+                            0, VOLUME_MAX);
+    p_vol->SetValue(VOLUME_DEFAULT);
+    p_vol->UseFillColor(true, &fill_color);
+    AddChild( p_vol );
+
+}
+
+MediaControlView::~MediaControlView()
+{
+}
+
+void MediaControlView::MessageReceived(BMessage *message)
+{
+}
+
+void MediaControlView::SetProgress(float position)
+{
+       p_seek->SetValue(position);
+}
+
+void MediaControlView::SetStatus(int status, int rate)
+{
+}
+
+void MediaControlView::SetEnabled(bool enabled)
+{
+       p_slow->SetEnabled(enabled);
+       p_play->SetEnabled(enabled);
+       p_fast->SetEnabled(enabled);
+       p_stop->SetEnabled(enabled);
+       p_mute->SetEnabled(enabled);
+       p_vol->SetEnabled(enabled);
+       p_seek->SetEnabled(enabled);
+}
+
+int32 MediaControlView::GetSeekTo()
+{
+       return p_seek->seekTo;
+}
+
+int32 MediaControlView::GetVolume()
+{
+       return p_vol->Value();
+}
+
+
+/*****************************************************************************
+ * MediaSlider
+ *****************************************************************************/
+MediaSlider::MediaSlider( BRect frame, BMessage *p_message,
+                          int32 i_min, int32 i_max )
+            :BSlider(frame, NULL, NULL, p_message, i_min, i_max )
+{
+
+}
+
+MediaSlider::~MediaSlider()
+{
+
+}
+
+void MediaSlider::DrawThumb(void)
+{
+    BRect r;
+    BView *v;
+
+    rgb_color black = {0,0,0};
+    r = ThumbFrame();
+    v = OffscreenView();
+
+    if(IsEnabled())
+    {
+        v->SetHighColor(black);
+    }
+    else
+    {
+        v->SetHighColor(tint_color(black, B_LIGHTEN_2_TINT));
+    }
+
+    r.InsetBy(r.IntegerWidth()/4, r.IntegerHeight()/(4 * r.IntegerWidth() / r.IntegerHeight()));
+    v->StrokeEllipse(r);
+
+    if(IsEnabled())
+    {
+        v->SetHighColor(ui_color(B_PANEL_BACKGROUND_COLOR));
+    }
+    else
+    {
+        v->SetHighColor(tint_color(ui_color(B_PANEL_BACKGROUND_COLOR), B_LIGHTEN_2_TINT));
+    }
+
+    r.InsetBy(1,1);
+    v->FillEllipse(r);
+}
+
+/*****************************************************************************
+ * SeekSlider
+ *****************************************************************************/
+SeekSlider::SeekSlider( BRect frame, MediaControlView *p_owner, int32 i_min,
+                        int32 i_max, thumb_style thumbType = B_TRIANGLE_THUMB )
+           :MediaSlider( frame, NULL, i_min, i_max )
+{
+    fOwner = p_owner;
+    fMouseDown = false;
+}
+
+SeekSlider::~SeekSlider()
+{
+}
+
+/*****************************************************************************
+ * SeekSlider::MouseDown
+ *****************************************************************************/
+void SeekSlider::MouseDown(BPoint where)
+{
+    BSlider::MouseDown(where);
+    fOwner->fScrubSem = create_sem(0, "Vlc::fScrubSem");
+    fMouseDown = true;
+}
+
+/*****************************************************************************
+ * SeekSlider::MouseUp
+ *****************************************************************************/
+void SeekSlider::MouseMoved(BPoint where, uint32 code, const BMessage *message)
+{
+    BSlider::MouseMoved(where, code, message);
+    if (!fMouseDown)
+        return;
+    seekTo = ValueForPoint(where);
+    release_sem(fOwner->fScrubSem);
+}
+
+/*****************************************************************************
+ * SeekSlider::MouseUp
+ *****************************************************************************/
+void SeekSlider::MouseUp(BPoint where)
+{
+    BSlider::MouseUp(where);
+    seekTo = ValueForPoint(where);
+    delete_sem(fOwner->fScrubSem);
+    fOwner->fScrubSem = B_ERROR;
+    fMouseDown = false;
+}
diff --git a/plugins/beos/MediaControlView.h b/plugins/beos/MediaControlView.h
new file mode 100644 (file)
index 0000000..44f9ba4
--- /dev/null
@@ -0,0 +1,92 @@
+/*****************************************************************************
+ * MediaControlView.h: beos interface
+ *****************************************************************************
+ * Copyright (C) 1999, 2000, 2001 VideoLAN
+ * $Id: MediaControlView.h,v 1.1 2001/06/15 09:07:10 tcastley Exp $
+ *
+ * Authors: Tony Castley <tony@castley.net>
+ *
+ * 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.
+ *****************************************************************************/
+#define HORZ_SPACE 5.0
+#define VERT_SPACE 5.0
+
+
+class TransportButton;
+class PlayPauseButton;
+class MediaSlider;
+class SeekSlider;
+
+class MediaControlView : public BBox
+{
+public:
+    MediaControlView( BRect frame );
+    ~MediaControlView();
+
+    virtual void    MessageReceived(BMessage *message);
+    void            SetProgress(float position);
+
+    void            SetStatus(int status, int rate); 
+    void            SetEnabled(bool);
+    int32           GetSeekTo();
+    int32           GetVolume();
+       sem_id  fScrubSem;
+       bool    fSeeking;
+    
+private:
+       MediaSlider * p_vol;
+       SeekSlider * p_seek;
+       TransportButton* p_slow;
+       PlayPauseButton* p_play;
+       TransportButton* p_fast;
+       TransportButton* p_stop;
+       TransportButton* p_mute;
+       
+       int current_rate;
+       int current_status;
+};
+
+class MediaSlider : public BSlider
+{
+public:
+       MediaSlider(BRect frame,
+                               BMessage *message,
+                               int32 minValue,
+                               int32 maxValue);
+       ~MediaSlider();
+       virtual void DrawThumb(void);
+};
+                               
+
+class SeekSlider : public MediaSlider
+{
+public:
+       SeekSlider(BRect frame,
+                               MediaControlView *owner,
+                               int32 minValue,
+                               int32 maxValue,
+                               thumb_style thumbType = B_TRIANGLE_THUMB);
+
+       ~SeekSlider();
+       int32 seekTo;
+       virtual void MouseDown(BPoint);
+       virtual void MouseUp(BPoint pt);
+       virtual void MouseMoved(BPoint pt, uint32 c, const BMessage *m);
+private:
+       MediaControlView*       fOwner; 
+       bool fMouseDown;
+};
+
+
index 618a10102ba8c05a8cc05f96ab3fbca92e342154..a06f386844e16996d5f28d122892df1078708922 100644 (file)
@@ -2,7 +2,7 @@
  * MsgVals.h
  *****************************************************************************
  * Copyright (C) 2001 VideoLAN
- * $Id: MsgVals.h,v 1.5 2001/03/25 17:09:14 richards Exp $
+ * $Id: MsgVals.h,v 1.6 2001/06/15 09:07:10 tcastley Exp $
  *
  * Authors: Tony Castley <tcastley@mail.powerup.com.au>
  *
@@ -27,6 +27,7 @@
 
 const uint32 OPEN_FILE      = 'OPFL';
 const uint32 OPEN_DVD       = 'OPDV';
+const uint32 OPEN_PLAYLIST  = 'OPPL';
 const uint32 STOP_PLAYBACK  = 'STPL';
 const uint32 START_PLAYBACK = 'PLAY';
 const uint32 PAUSE_PLAYBACK = 'PAPL';
diff --git a/plugins/beos/PlayListWindow.cpp b/plugins/beos/PlayListWindow.cpp
new file mode 100644 (file)
index 0000000..152dea3
--- /dev/null
@@ -0,0 +1,150 @@
+/*****************************************************************************
+ * PlayListWindow.cpp: beos interface
+ *****************************************************************************
+ * Copyright (C) 1999, 2000, 2001 VideoLAN
+ * $Id: PlayListWindow.cpp,v 1.1 2001/06/15 09:07:10 tcastley Exp $
+ *
+ * Authors: Jean-Marc Dressler <polux@via.ecp.fr>
+ *          Samuel Hocevar <sam@zoy.org>
+ *          Tony Castley <tony@castley.net>
+ *          Richard Shepherd <richard@rshepherd.demon.co.uk>
+ *
+ * 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 "defs.h"
+
+/* System headers */
+#include <InterfaceKit.h>
+#include <StorageKit.h>
+
+/* VLC headers */
+extern "C"
+{
+#include "config.h"
+#include "common.h"
+#include "threads.h"
+#include "mtime.h"
+#include "main.h"
+#include "tests.h"
+#include "stream_control.h"
+#include "input_ext-intf.h"
+#include "interface.h"
+#include "intf_msg.h"
+#include "intf_playlist.h"
+}
+
+/* BeOS interface headers */
+#include "InterfaceWindow.h"
+#include "PlayListWindow.h"
+#include "MsgVals.h"
+
+/*****************************************************************************
+ * PlayListWindow
+ *****************************************************************************/
+
+PlayListWindow::PlayListWindow( BRect frame, const char *name,
+                                  playlist_t *p_pl)
+    : BWindow( frame, name, B_FLOATING_WINDOW_LOOK, B_NORMAL_WINDOW_FEEL,
+                B_WILL_ACCEPT_FIRST_CLICK | B_ASYNCHRONOUS_CONTROLS )
+{
+    SetName( "playlist" );
+    SetTitle(name);
+    p_playlist = p_pl;
+
+    /* set up the main menu */
+    BMenuBar *menu_bar;
+    menu_bar = new BMenuBar(BRect(0,0,0,0), "main menu");
+    AddChild( menu_bar );
+
+    BMenu *mFile;
+    /* Add the file Menu */
+    BMenuItem *mItem;
+    menu_bar->AddItem( mFile = new BMenu( "File" ) );
+    menu_bar->ResizeToPreferred();
+    mFile->AddItem( mItem = new BMenuItem( "Open File" B_UTF8_ELLIPSIS,
+                                           new BMessage(OPEN_FILE), 'O') );
+    
+    CDMenu *cd_menu = new CDMenu( "Open Disc" );
+    mFile->AddItem( cd_menu );
+    
+    BRect rect = Bounds();
+    rect.top += menu_bar->Bounds().IntegerHeight() + 1;
+    BView *p_view = new BView(rect, NULL, B_FOLLOW_ALL_SIDES, B_WILL_DRAW);
+    
+    p_listview = new BListView(rect, "PlayList", 
+                                    B_MULTIPLE_SELECTION_LIST);
+    for (int i=0; i < p_playlist->i_size; i++)
+    {
+        p_listview->AddItem(new BStringItem(p_playlist->p_item[i].psz_name)); 
+    }
+    p_view->AddChild(new BScrollView("scroll_playlist", p_listview,
+             B_FOLLOW_LEFT | B_FOLLOW_TOP, 0, false, true)); 
+             
+    AddChild(p_view);
+}
+
+PlayListWindow::~PlayListWindow()
+{
+}
+
+/*****************************************************************************
+ * PlayListWindow::MessageReceived
+ *****************************************************************************/
+void PlayListWindow::MessageReceived( BMessage * p_message )
+{
+    Activate();
+
+    switch( p_message->what )
+    {
+    case OPEN_FILE:
+        if( file_panel )
+        {
+            file_panel->Show();
+            break;
+        }
+        file_panel = new BFilePanel();
+        file_panel->SetTarget( this );
+        file_panel->Show();
+        break;
+
+    case OPEN_DVD:
+        const char *psz_device;
+        char psz_source[ B_FILE_NAME_LENGTH + 4 ];
+        if( p_message->FindString("device", &psz_device) != B_ERROR )
+        {
+            snprintf( psz_source, B_FILE_NAME_LENGTH + 4,
+                      "dvd:%s", psz_device );
+            psz_source[ strlen(psz_source) ] = '\0';
+            intf_PlaylistAdd( p_playlist, PLAYLIST_END, (char*)psz_source );
+            p_listview->AddItem(new BStringItem((char*)psz_source));
+        }
+    case B_REFS_RECEIVED:
+    case B_SIMPLE_DATA:
+        {
+            entry_ref ref;
+            if( p_message->FindRef( "refs", &ref ) == B_OK )
+            {
+                BPath path( &ref );
+                intf_PlaylistAdd( p_playlist,
+                                  PLAYLIST_END, (char*)path.Path() );
+                p_listview->AddItem(new BStringItem((char*)path.Path()));
+            }
+        }
+        break;
+    default:
+        BWindow::MessageReceived( p_message );
+        break;
+    }
+}
diff --git a/plugins/beos/PlayListWindow.h b/plugins/beos/PlayListWindow.h
new file mode 100644 (file)
index 0000000..f324932
--- /dev/null
@@ -0,0 +1,41 @@
+/*****************************************************************************
+ * PlayListWindow.h: BeOS interface window class prototype
+ *****************************************************************************
+ * Copyright (C) 1999, 2000, 2001 VideoLAN
+ * $Id: PlayListWindow.h,v 1.1 2001/06/15 09:07:10 tcastley Exp $
+ *
+ * Authors: Jean-Marc Dressler <polux@via.ecp.fr>
+ *          Tony Castley <tcastley@mail.powerup.com.au>
+ *          Richard Shepherd <richard@rshepherd.demon.co.uk>
+ *
+ * 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.
+ *****************************************************************************/
+class CDMenu;
+class PlayListWindow : public BWindow
+{
+public:
+    PlayListWindow( BRect frame, const char *name, playlist_t *p_pl);
+    ~PlayListWindow();
+
+    // standard window member
+    virtual void    MessageReceived(BMessage *message);
+    
+private:       
+    playlist_t  *p_playlist;
+    BListView  *p_listview;
+    BFilePanel *file_panel;
+};
+
+