Commit 5c15eb12 authored by Jon Lech Johansen's avatar Jon Lech Johansen

MacOS X port:

  * main window controls are back. based on suggestion by Dan Macpherson.
parent 6d969890
...@@ -30,11 +30,24 @@ ...@@ -30,11 +30,24 @@
SUPERCLASS = NSObject; SUPERCLASS = NSObject;
}, },
{ {
ACTIONS = {clearRecentItems = id; openRecentItem = id; viewPreferences = id; }; ACTIONS = {
clearRecentItems = id;
openRecentItem = id;
timesliderUpdate = id;
viewPreferences = id;
};
CLASS = VLCMain; CLASS = VLCMain;
LANGUAGE = ObjC; LANGUAGE = ObjC;
OUTLETS = { OUTLETS = {
asystm = id; "o_btn_faster" = id;
"o_btn_next" = id;
"o_btn_pause" = id;
"o_btn_play" = id;
"o_btn_playlist" = id;
"o_btn_prefs" = id;
"o_btn_prev" = id;
"o_btn_slower" = id;
"o_btn_stop" = id;
"o_controls" = id; "o_controls" = id;
"o_dmi_pause" = id; "o_dmi_pause" = id;
"o_dmi_play" = id; "o_dmi_play" = id;
...@@ -90,7 +103,8 @@ ...@@ -90,7 +103,8 @@
"o_mu_view" = id; "o_mu_view" = id;
"o_mu_window" = id; "o_mu_window" = id;
"o_playlist" = id; "o_playlist" = id;
"o_prefs" = id; "o_timefield" = id;
"o_timeslider" = id;
"o_window" = id; "o_window" = id;
}; };
SUPERCLASS = NSObject; SUPERCLASS = NSObject;
......
...@@ -7,12 +7,16 @@ ...@@ -7,12 +7,16 @@
<key>IBEditorPositions</key> <key>IBEditorPositions</key>
<dict> <dict>
<key>29</key> <key>29</key>
<string>266 466 308 44 0 0 1152 746 </string> <string>407 753 308 44 0 0 1600 1178 </string>
<key>303</key> <key>303</key>
<string>93 566 72 114 0 0 1600 1178 </string> <string>93 566 72 114 0 0 1600 1178 </string>
</dict> </dict>
<key>IBFramework Version</key> <key>IBFramework Version</key>
<string>291.0</string> <string>291.0</string>
<key>IBOpenObjects</key>
<array>
<integer>21</integer>
</array>
<key>IBSystem Version</key> <key>IBSystem Version</key>
<string>6G30</string> <string>6G30</string>
</dict> </dict>
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* controls.m: MacOS X interface plugin * controls.m: MacOS X interface plugin
***************************************************************************** *****************************************************************************
* Copyright (C) 2002 VideoLAN * Copyright (C) 2002 VideoLAN
* $Id: controls.m,v 1.4 2002/12/29 01:16:28 massiot Exp $ * $Id: controls.m,v 1.5 2003/01/04 04:11:08 jlj Exp $
* *
* Authors: Jon Lech Johansen <jon-vl@nanocrew.net> * Authors: Jon Lech Johansen <jon-vl@nanocrew.net>
* Christophe Massiot <massiot@via.ecp.fr> * Christophe Massiot <massiot@via.ecp.fr>
...@@ -236,7 +236,6 @@ ...@@ -236,7 +236,6 @@
- (IBAction)mute:(id)sender - (IBAction)mute:(id)sender
{ {
#if 0
intf_thread_t * p_intf = [NSApp getIntf]; intf_thread_t * p_intf = [NSApp getIntf];
aout_instance_t * p_aout = vlc_object_find( p_intf, VLC_OBJECT_AOUT, aout_instance_t * p_aout = vlc_object_find( p_intf, VLC_OBJECT_AOUT,
FIND_ANYWHERE ); FIND_ANYWHERE );
...@@ -250,37 +249,6 @@ ...@@ -250,37 +249,6 @@
NSMenuItem * o_mi = (NSMenuItem *)sender; NSMenuItem * o_mi = (NSMenuItem *)sender;
p_intf->p_sys->b_mute = !p_intf->p_sys->b_mute; p_intf->p_sys->b_mute = !p_intf->p_sys->b_mute;
[o_mi setState: p_intf->p_sys->b_mute ? NSOnState : NSOffState]; [o_mi setState: p_intf->p_sys->b_mute ? NSOnState : NSOffState];
#else
int err;
AudioDeviceID device;
UInt32 ui_param_size;
NSMenuItem * o_mi = (NSMenuItem *)sender;
intf_thread_t * p_intf = [NSApp getIntf];
UInt32 b_mute = !p_intf->p_sys->b_mute;
[o_mi setState: b_mute ? NSOnState : NSOffState];
p_intf->p_sys->b_mute = !p_intf->p_sys->b_mute;
ui_param_size = sizeof( device );
err = AudioHardwareGetProperty( kAudioHardwarePropertyDefaultOutputDevice,
&ui_param_size, (void *)&device );
if( err != noErr )
{
msg_Err( p_intf, "AudioHardwareGetProperty failed (%d)", err );
return;
}
ui_param_size = sizeof( b_mute );
err = AudioDeviceSetProperty( device, 0, 0, false,
kAudioDevicePropertyMute,
ui_param_size, (void *)&b_mute );
if( err != noErr )
{
msg_Err( p_intf, "AudioDeviceSetProperty failed (%d)", err );
return;
}
#endif
} }
- (IBAction)fullscreen:(id)sender - (IBAction)fullscreen:(id)sender
...@@ -458,7 +426,7 @@ ...@@ -458,7 +426,7 @@
{ {
bEnabled = p_intf->p_sys->p_input != NULL; bEnabled = p_intf->p_sys->p_input != NULL;
} }
else if( [[o_mi title] isEqualToString: _NS("Prev")] || else if( [[o_mi title] isEqualToString: _NS("Previous")] ||
[[o_mi title] isEqualToString: _NS("Next")] ) [[o_mi title] isEqualToString: _NS("Next")] )
{ {
playlist_t * p_playlist = vlc_object_find( p_intf, playlist_t * p_playlist = vlc_object_find( p_intf,
...@@ -477,40 +445,19 @@ ...@@ -477,40 +445,19 @@
} }
} }
else if( [[o_mi title] isEqualToString: _NS("Volume Up")] || else if( [[o_mi title] isEqualToString: _NS("Volume Up")] ||
[[o_mi title] isEqualToString: _NS("Volume Down")] ) [[o_mi title] isEqualToString: _NS("Volume Down")] ||
[[o_mi title] isEqualToString: _NS("Mute")] )
{ {
bEnabled = FALSE; /* not implemented yet */ aout_instance_t * p_aout = vlc_object_find( p_intf, VLC_OBJECT_AOUT,
} FIND_ANYWHERE );
else if( [[o_mi title] isEqualToString: _NS("Mute")] )
{
int err;
UInt32 b_mute;
AudioDeviceID device;
UInt32 ui_param_size;
ui_param_size = sizeof( device ); if ( p_aout != NULL )
err = AudioHardwareGetProperty(
kAudioHardwarePropertyDefaultOutputDevice,
&ui_param_size, (void *)&device );
if( err != noErr )
{
msg_Err( p_intf, "AudioHardwareGetProperty failed (%d)", err );
}
else
{
ui_param_size = sizeof( b_mute );
err = AudioDeviceGetProperty( device, 0, 0,
kAudioDevicePropertyMute,
&ui_param_size, (void *)&b_mute );
if( err != noErr )
{ {
msg_Err( p_intf, "AudioDeviceGetProperty failed (%d)", err ); vlc_object_release( (vlc_object_t *)p_aout );
} }
else else
{ {
[o_mi setState: b_mute ? NSOnState : NSOffState]; bEnabled = FALSE;
p_intf->p_sys->b_mute = (vlc_bool_t)b_mute ? 1 : 0;
}
} }
} }
else if( [[o_mi title] isEqualToString: _NS("Fullscreen")] ) else if( [[o_mi title] isEqualToString: _NS("Fullscreen")] )
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* intf.h: MacOS X interface plugin * intf.h: MacOS X interface plugin
***************************************************************************** *****************************************************************************
* Copyright (C) 2002 VideoLAN * Copyright (C) 2002 VideoLAN
* $Id: intf.h,v 1.8 2003/01/02 23:09:30 massiot Exp $ * $Id: intf.h,v 1.9 2003/01/04 04:11:08 jlj Exp $
* *
* Authors: Jon Lech Johansen <jon-vl@nanocrew.net> * Authors: Jon Lech Johansen <jon-vl@nanocrew.net>
* Christophe Massiot <massiot@via.ecp.fr> * Christophe Massiot <massiot@via.ecp.fr>
...@@ -87,6 +87,21 @@ struct intf_sys_t ...@@ -87,6 +87,21 @@ struct intf_sys_t
id o_prefs; /* VLCPrefs */ id o_prefs; /* VLCPrefs */
IBOutlet id o_window; /* main window */ IBOutlet id o_window; /* main window */
IBOutlet id o_timefield; /* time field */
IBOutlet id o_timeslider; /* time slider */
NSLock * o_slider_lock; /* slider lock */
float f_slider; /* slider value */
float f_slider_old; /* old slider val */
IBOutlet id o_btn_playlist; /* btn playlist */
IBOutlet id o_btn_prev; /* btn previous */
IBOutlet id o_btn_slower; /* btn slower */
IBOutlet id o_btn_play; /* btn play */
IBOutlet id o_btn_pause; /* btn pause */
IBOutlet id o_btn_stop; /* btn stop */
IBOutlet id o_btn_faster; /* btn faster */
IBOutlet id o_btn_next; /* btn next */
IBOutlet id o_btn_prefs; /* btn prefs */
IBOutlet id o_controls; /* VLCControls */ IBOutlet id o_controls; /* VLCControls */
IBOutlet id o_playlist; /* VLCPlaylist */ IBOutlet id o_playlist; /* VLCPlaylist */
...@@ -174,10 +189,11 @@ struct intf_sys_t ...@@ -174,10 +189,11 @@ struct intf_sys_t
- (IBAction)clearRecentItems:(id)sender; - (IBAction)clearRecentItems:(id)sender;
- (void)openRecentItem:(id)sender; - (void)openRecentItem:(id)sender;
//- (void)selectAction:(id)sender;
- (IBAction)viewPreferences:(id)sender; - (IBAction)viewPreferences:(id)sender;
- (IBAction)timesliderUpdate:(id)sender;
- (void)displayTime;
@end @end
@interface VLCMain (Internal) @interface VLCMain (Internal)
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* intf.m: MacOS X interface plugin * intf.m: MacOS X interface plugin
***************************************************************************** *****************************************************************************
* Copyright (C) 2002 VideoLAN * Copyright (C) 2002 VideoLAN
* $Id: intf.m,v 1.16 2003/01/02 23:50:55 massiot Exp $ * $Id: intf.m,v 1.17 2003/01/04 04:11:08 jlj Exp $
* *
* Authors: Jon Lech Johansen <jon-vl@nanocrew.net> * Authors: Jon Lech Johansen <jon-vl@nanocrew.net>
* Christophe Massiot <massiot@via.ecp.fr> * Christophe Massiot <massiot@via.ecp.fr>
...@@ -183,9 +183,22 @@ static void Run( intf_thread_t *p_intf ) ...@@ -183,9 +183,22 @@ static void Run( intf_thread_t *p_intf )
[o_window setTitle: pTitle]; [o_window setTitle: pTitle];
/* button controls */
[o_btn_playlist setToolTip: _NS("Playlist")];
[o_btn_prev setToolTip: _NS("Previous")];
[o_btn_slower setToolTip: _NS("Slower")];
[o_btn_play setToolTip: _NS("Play")];
[o_btn_pause setToolTip: _NS("Pause")];
[o_btn_stop setToolTip: _NS("Stop")];
[o_btn_faster setToolTip: _NS("Faster")];
[o_btn_next setToolTip: _NS("Next")];
[o_btn_prefs setToolTip: _NS("Preferences")];
/* messages panel */
[o_msgs_panel setTitle: _NS("Messages")]; [o_msgs_panel setTitle: _NS("Messages")];
[o_msgs_btn_ok setTitle: _NS("Close")]; [o_msgs_btn_ok setTitle: _NS("Close")];
/* main menu */
[o_mi_about setTitle: _NS("About vlc")]; [o_mi_about setTitle: _NS("About vlc")];
[o_mi_prefs setTitle: _NS("Preferences")]; [o_mi_prefs setTitle: _NS("Preferences")];
[o_mi_hide setTitle: _NS("Hide vlc")]; [o_mi_hide setTitle: _NS("Hide vlc")];
...@@ -194,8 +207,8 @@ static void Run( intf_thread_t *p_intf ) ...@@ -194,8 +207,8 @@ static void Run( intf_thread_t *p_intf )
[o_mi_quit setTitle: _NS("Quit vlc")]; [o_mi_quit setTitle: _NS("Quit vlc")];
[o_mu_file setTitle: _NS("File")]; [o_mu_file setTitle: _NS("File")];
[o_mi_open_file setTitle: _NS("Open File...")];
[o_mi_open_generic setTitle: _NS("Open...")]; [o_mi_open_generic setTitle: _NS("Open...")];
[o_mi_open_file setTitle: _NS("Open File...")];
[o_mi_open_disc setTitle: _NS("Open Disc...")]; [o_mi_open_disc setTitle: _NS("Open Disc...")];
[o_mi_open_net setTitle: _NS("Open Network...")]; [o_mi_open_net setTitle: _NS("Open Network...")];
[o_mi_open_recent setTitle: _NS("Open Recent")]; [o_mi_open_recent setTitle: _NS("Open Recent")];
...@@ -221,8 +234,8 @@ static void Run( intf_thread_t *p_intf ) ...@@ -221,8 +234,8 @@ static void Run( intf_thread_t *p_intf )
[o_mi_previous setTitle: _NS("Previous")]; [o_mi_previous setTitle: _NS("Previous")];
[o_mi_next setTitle: _NS("Next")]; [o_mi_next setTitle: _NS("Next")];
[o_mi_loop setTitle: _NS("Loop")]; [o_mi_loop setTitle: _NS("Loop")];
[o_mi_vol_up setTitle: _NS("Louder")]; [o_mi_vol_up setTitle: _NS("Volume Up")];
[o_mi_vol_down setTitle: _NS("Softer")]; [o_mi_vol_down setTitle: _NS("Volume Down")];
[o_mi_mute setTitle: _NS("Mute")]; [o_mi_mute setTitle: _NS("Mute")];
[o_mi_channels setTitle: _NS("Channels")]; [o_mi_channels setTitle: _NS("Channels")];
[o_mi_device setTitle: _NS("Device")]; [o_mi_device setTitle: _NS("Device")];
...@@ -251,6 +264,9 @@ static void Run( intf_thread_t *p_intf ) ...@@ -251,6 +264,9 @@ static void Run( intf_thread_t *p_intf )
{ {
intf_thread_t * p_intf = [NSApp getIntf]; intf_thread_t * p_intf = [NSApp getIntf];
f_slider_old = f_slider = 0.0;
o_slider_lock = [[NSLock alloc] init];
[NSThread detachNewThreadSelector: @selector(manage) [NSThread detachNewThreadSelector: @selector(manage)
toTarget: self withObject: nil]; toTarget: self withObject: nil];
...@@ -260,10 +276,6 @@ static void Run( intf_thread_t *p_intf ) ...@@ -260,10 +276,6 @@ static void Run( intf_thread_t *p_intf )
forMode: NSDefaultRunLoopMode]; forMode: NSDefaultRunLoopMode];
} }
- (void)noopAction:(id)sender {
// nothing
}
- (BOOL)application:(NSApplication *)o_app openFile:(NSString *)o_filename - (BOOL)application:(NSApplication *)o_app openFile:(NSString *)o_filename
{ {
[o_playlist appendArray: [o_playlist appendArray:
...@@ -312,6 +324,8 @@ static void Run( intf_thread_t *p_intf ) ...@@ -312,6 +324,8 @@ static void Run( intf_thread_t *p_intf )
if( !p_input->b_die ) if( !p_input->b_die )
{ {
[self displayTime];
/* New input or stream map change */ /* New input or stream map change */
if( p_input->stream.b_changed ) if( p_input->stream.b_changed )
{ {
...@@ -359,6 +373,7 @@ static void Run( intf_thread_t *p_intf ) ...@@ -359,6 +373,7 @@ static void Run( intf_thread_t *p_intf )
} }
else if( p_intf->p_sys->b_playing && !p_intf->b_die ) else if( p_intf->p_sys->b_playing && !p_intf->b_die )
{ {
[self displayTime];
[self manageMode]; [self manageMode];
p_intf->p_sys->b_playing = 0; p_intf->p_sys->b_playing = 0;
} }
...@@ -470,6 +485,8 @@ static void Run( intf_thread_t *p_intf ) ...@@ -470,6 +485,8 @@ static void Run( intf_thread_t *p_intf )
vout_Destroy( p_vout ); vout_Destroy( p_vout );
} }
[o_slider_lock release];
if( o_prefs != nil ) if( o_prefs != nil )
{ {
[o_prefs release]; [o_prefs release];
...@@ -492,10 +509,13 @@ static void Run( intf_thread_t *p_intf ) ...@@ -492,10 +509,13 @@ static void Run( intf_thread_t *p_intf )
- (void)manageMode - (void)manageMode
{ {
vlc_bool_t b_input;
vlc_bool_t b_plmul = 0;
vlc_bool_t b_control = 0; vlc_bool_t b_control = 0;
playlist_t * p_playlist = NULL;
intf_thread_t * p_intf = [NSApp getIntf]; intf_thread_t * p_intf = [NSApp getIntf];
if( p_intf->p_sys->p_input != NULL ) if( ( b_input = ( p_intf->p_sys->p_input != NULL ) ) )
{ {
/* control buttons for free pace streams */ /* control buttons for free pace streams */
b_control = p_intf->p_sys->p_input->stream.b_pace_control; b_control = p_intf->p_sys->p_input->stream.b_pace_control;
...@@ -524,6 +544,24 @@ static void Run( intf_thread_t *p_intf ) ...@@ -524,6 +544,24 @@ static void Run( intf_thread_t *p_intf )
[o_mi_screen setEnabled: FALSE]; [o_mi_screen setEnabled: FALSE];
} }
p_playlist = vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST,
FIND_ANYWHERE );
if( p_playlist != NULL )
{
vlc_mutex_lock( &p_playlist->object_lock );
b_plmul = p_playlist->i_size > 1;
vlc_mutex_unlock( &p_playlist->object_lock );
vlc_object_release( p_playlist );
}
/* set control items */
[o_btn_stop setEnabled: b_input];
[o_btn_pause setEnabled: b_control];
[o_btn_faster setEnabled: b_control];
[o_btn_slower setEnabled: b_control];
[o_btn_prev setEnabled: b_plmul];
[o_btn_next setEnabled: b_plmul];
if ( (p_intf->p_sys->b_loop = config_GetInt( p_intf, "loop" )) ) if ( (p_intf->p_sys->b_loop = config_GetInt( p_intf, "loop" )) )
{ {
[o_mi_loop setState: NSOnState]; [o_mi_loop setState: NSOnState];
...@@ -918,6 +956,84 @@ static void Run( intf_thread_t *p_intf ) ...@@ -918,6 +956,84 @@ static void Run( intf_thread_t *p_intf )
[o_prefs createPrefPanel: @"main"]; [o_prefs createPrefPanel: @"main"];
} }
- (IBAction)timesliderUpdate:(id)sender
{
switch( [[NSApp currentEvent] type] )
{
case NSLeftMouseDown:
[o_slider_lock lock];
break;
case NSLeftMouseUp:
f_slider = [sender floatValue];
[o_slider_lock unlock];
break;
default:
break;
}
}
- (void)displayTime
{
intf_thread_t * p_intf = [NSApp getIntf];
input_thread_t * p_input = p_intf->p_sys->p_input;
if( p_input == NULL )
{
[o_timeslider setEnabled: FALSE];
[o_timeslider setFloatValue: 0.0];
[o_timefield setStringValue: @"0:00:00"];
return;
}
#define p_area p_input->stream.p_selected_area
if( p_input->stream.b_changed )
{
[o_timeslider setEnabled: p_input->stream.b_seekable];
}
else if( p_intf->p_sys->b_playing )
{
NSString * o_time;
char psz_time[ OFFSETTOTIME_MAX_SIZE ];
input_OffsetToTime( p_input, psz_time, p_area->i_tell );
o_time = [NSString stringWithCString: psz_time];
[o_timefield setStringValue: o_time];
if( p_input->stream.b_seekable )
{
if( f_slider == f_slider_old )
{
float f_updated = ( 100. * p_area->i_tell ) /
p_area->i_size;
if( f_slider != f_updated && [o_slider_lock tryLock] )
{
[o_timeslider setFloatValue: f_updated];
[o_slider_lock unlock];
}
}
else
{
off_t i_seek = ( f_slider * p_area->i_size ) / 100;
/* release the lock to be able to seek */
vlc_mutex_unlock( &p_input->stream.stream_lock );
input_Seek( p_input, i_seek, INPUT_SEEK_SET );
vlc_mutex_lock( &p_input->stream.stream_lock );
/* Update the old value */
f_slider_old = f_slider;
}
}
}
#undef p_area
}
@end @end
@implementation VLCMain (NSMenuValidation) @implementation VLCMain (NSMenuValidation)
......
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