/*****************************************************************************\r
* fspanel.m: MacOS X full screen panel\r
*****************************************************************************\r
- * Copyright (C) 2006 the VideoLAN team\r
+ * Copyright (C) 2006-2007 the VideoLAN team\r
* $Id$\r
*\r
* Authors: J\8er\99me Decoodt <djc at videolan dot org>\r
#import "intf.h"\r
#import "controls.h"\r
#import "vout.h"\r
+#import "misc.h"\r
#import "fspanel.h"\r
\r
-#define KEEP_VISIBLE_AFTER_ACTION 4 /* time in half-sec until this panel will hide again after an user's action */\r
+#define KEEP_VISIBLE_AFTER_ACTION 4 /* time in half-sec until this panel will hide again after a user's action */\r
\r
/*****************************************************************************\r
* VLCFSPanel\r
backing:(NSBackingStoreType)bufferingType \r
defer:(BOOL)flag\r
{\r
- id win=[super initWithContentRect:contentRect styleMask:NSBorderlessWindowMask backing:bufferingType defer:flag];\r
+ id win = [super initWithContentRect:contentRect styleMask:NSTexturedBackgroundWindowMask backing:bufferingType defer:flag];\r
[win setOpaque:NO];\r
[win setHasShadow: NO];\r
[win setBackgroundColor:[NSColor clearColor]];\r
+ \r
/* let the window sit on top of everything else and start out completely transparent */\r
- [win setLevel:NSFloatingWindowLevel];\r
- [win setAlphaValue:0.0];\r
+ [win setLevel:NSModalPanelWindowLevel];\r
+ i_device = 0;\r
+ [win center];\r
+ [self setNonActive:nil];\r
+\r
return win;\r
}\r
\r
- (void)awakeFromNib\r
{\r
[self setContentView:[[VLCFSPanelView alloc] initWithFrame: [self frame]]];\r
- BOOL isInside=(NSPointInRect([NSEvent mouseLocation],[self frame]));\r
+ BOOL isInside = (NSPointInRect([NSEvent mouseLocation],[self frame]));\r
[[self contentView] addTrackingRect:[[self contentView] bounds] owner:self userData:nil assumeInside:isInside];\r
if (isInside)\r
- [self mouseEntered:NULL];\r
+ [self mouseEntered:NULL];\r
if (!isInside)\r
- [self mouseExited:NULL];\r
+ [self mouseExited:NULL];\r
+ \r
+ /* get a notification if VLC isn't the active app anymore */\r
+ [[NSNotificationCenter defaultCenter]\r
+ addObserver: self\r
+ selector: @selector(setNonActive:)\r
+ name: NSApplicationDidResignActiveNotification\r
+ object: NSApp];\r
+ \r
+ /* get a notification if VLC is the active app again */\r
+ [[NSNotificationCenter defaultCenter]\r
+ addObserver: self\r
+ selector: @selector(setActive:)\r
+ name: NSApplicationDidBecomeActiveNotification\r
+ object: NSApp];\r
}\r
\r
/* Windows created with NSBorderlessWindowMask normally can't be key, but we want ours to be */\r
return YES;\r
}\r
\r
+#if GC_ENABLED\r
+- (void)finalize\r
+{\r
+ /* dealloc isn't called on 10.5 in case that GC is enabled, so we need to provide the functionality here */\r
+ [[NSNotificationCenter defaultCenter] removeObserver: self];\r
+ [self setFadeTimer:nil];\r
+ \r
+ [super finalize];\r
+}\r
+#endif\r
+\r
-(void)dealloc\r
{\r
+ [[NSNotificationCenter defaultCenter] removeObserver: self];\r
+ \r
if( hideAgainTimer )\r
[hideAgainTimer release];\r
[self setFadeTimer:nil];\r
[super dealloc];\r
}\r
\r
+-(void)center\r
+{\r
+ /* centre the panel in the lower third of the screen */\r
+ NSPoint theCoordinate;\r
+ NSRect theScreensFrame;\r
+ NSRect theWindowsFrame;\r
+ NSScreen *screen;\r
+ \r
+ /* user-defined screen */\r
+ screen = [NSScreen screenWithDisplayID: (CGDirectDisplayID)i_device];\r
+ \r
+ if (!screen)\r
+ {\r
+ /* invalid preferences or none specified, using main screen */\r
+ screen = [NSScreen mainScreen];\r
+ }\r
+\r
+ theScreensFrame = [screen frame];\r
+\r
+ theWindowsFrame = [self frame];\r
+ \r
+ theCoordinate.x = (theScreensFrame.size.width - theWindowsFrame.size.width) / 2 + theScreensFrame.origin.x;\r
+ theCoordinate.y = (theScreensFrame.size.height / 3) - theWindowsFrame.size.height + theScreensFrame.origin.y;\r
+ [self setFrameTopLeftPoint: theCoordinate];\r
+}\r
+\r
- (void)setPlay\r
{\r
[[self contentView] setPlay];\r
[[self contentView] setVolumeLevel: f_volumeLevel];\r
}\r
\r
+- (void)setNonActive:(id)noData\r
+{\r
+ b_nonActive = YES;\r
+ [self orderOut: self];\r
+ \r
+ /* here's fadeOut, just without visibly fading */\r
+ b_displayed = NO;\r
+ [self setAlphaValue:0.0];\r
+ [self setFadeTimer:nil];\r
+ b_fadeQueued = NO;\r
+}\r
+\r
+- (void)setActive:(id)noData\r
+{\r
+ if( [[[[VLCMain sharedInstance] getControls] getVoutView] isFullscreen] )\r
+ {\r
+ b_nonActive = NO;\r
+ [self fadeIn];\r
+ }\r
+}\r
+\r
/* This routine is called repeatedly to fade in the window */\r
- (void)focus:(NSTimer *)timer\r
{\r
{\r
b_keptVisible = NO;\r
b_fadeQueued = NO;\r
- [[self fadeTimer] release];\r
[self setFadeTimer: NULL];\r
[self fadeIn];\r
return;\r
}\r
if( [self alphaValue] > 0.0 )\r
- [self setAlphaValue:[self alphaValue]-0.1];\r
- if( [self alphaValue] <= 0.1 )\r
+ [self setAlphaValue:[self alphaValue]-0.05];\r
+ if( [self alphaValue] <= 0.05 )\r
{\r
b_displayed = NO;\r
[self setAlphaValue:0.0];\r
\r
- (void)fadeIn\r
{\r
- if( [self alphaValue] < 1.0 )\r
+ /* in case that the user don't want us to appear, just return here */\r
+ if(! config_GetInt( VLCIntf, "macosx-fspanel" ) || b_nonActive )\r
+ return;\r
+ \r
+ [self orderFront: nil];\r
+ \r
+ if( [self alphaValue] < 1.0 || b_displayed != YES )\r
{\r
if (![self fadeTimer])\r
[self setFadeTimer:[NSTimer scheduledTimerWithTimeInterval:0.05 target:self selector:@selector(focus:) userInfo:[NSNumber numberWithShort:1] repeats:YES]];\r
\r
- (void)fadeOut\r
{\r
+ if( NSPointInRect([NSEvent mouseLocation],[self frame]))\r
+ return;\r
+\r
if( ( [self alphaValue] > 0.0 ) )\r
{\r
if (![self fadeTimer])\r
- [self setFadeTimer:[NSTimer scheduledTimerWithTimeInterval:0.1 target:self selector:@selector(unfocus:) userInfo:[NSNumber numberWithShort:0] repeats:YES]];\r
+ [self setFadeTimer:[NSTimer scheduledTimerWithTimeInterval:0.05 target:self selector:@selector(unfocus:) userInfo:[NSNumber numberWithShort:0] repeats:YES]];\r
else if ([[[self fadeTimer] userInfo] shortValue]==1)\r
b_fadeQueued=YES;\r
}\r
i_timeToKeepVisibleInSec -= 1;\r
if( i_timeToKeepVisibleInSec < 1 )\r
{\r
+ [NSCursor setHiddenUntilMouseMoves: YES];\r
[self fadeOut];\r
[timer invalidate];\r
[timer release];\r
return b_displayed;\r
}\r
\r
-- (void)setVoutWasUpdated\r
+- (void)setVoutWasUpdated: (int)i_newdevice;\r
{\r
b_voutWasUpdated = YES;\r
+ if( i_newdevice != i_device )\r
+ {\r
+ i_device = i_newdevice;\r
+ [self center];\r
+ }\r
}\r
@end\r
\r
fillColor = [[NSColor clearColor] retain];\r
NSRect s_rc = [self frame];\r
addButton( o_prev, @"fs_skip_previous" , @"fs_skip_previous_highlight", 174, 15, prev );\r
- addButton( o_slow, @"fs_rewind" , @"fs_rewind_highlight" , 211, 14, slower );\r
+ addButton( o_bwd, @"fs_rewind" , @"fs_rewind_highlight" , 211, 14, backward );\r
addButton( o_play, @"fs_play" , @"fs_play_highlight" , 267, 10, play );\r
- addButton( o_fast, @"fs_forward" , @"fs_forward_highlight" , 313, 14, faster );\r
+ addButton( o_fwd, @"fs_forward" , @"fs_forward_highlight" , 313, 14, forward );\r
addButton( o_next, @"fs_skip_next" , @"fs_skip_next_highlight" , 365, 15, next );\r
addButton( o_fullscreen, @"fs_exit_fullscreen", @"fs_exit_fullscreen_hightlight", 507, 13, windowAction );\r
/*\r
[o_fs_volumeSlider release];\r
[o_prev release];\r
[o_next release];\r
- [o_slow release];\r
+ [o_bwd release];\r
[o_play release];\r
- [o_fast release];\r
+ [o_fwd release];\r
[o_fullscreen release];\r
[o_streamTitle_txt release];\r
[o_streamPosition_txt release];\r
\r
- (void)setPlay\r
{\r
- NSImage *image;\r
- image = [NSImage imageNamed:@"fs_play"];\r
- [o_play setImage:image];\r
- image = [NSImage imageNamed:@"fs_play_highlight"];\r
- [o_play setAlternateImage:image];\r
+ [o_play setImage:[NSImage imageNamed:@"fs_play"]];\r
+ [o_play setAlternateImage: [NSImage imageNamed:@"fs_play_highlight"]];\r
}\r
\r
- (void)setPause\r
{\r
- NSImage *image;\r
- image = [NSImage imageNamed:@"fs_pause"];\r
- [o_play setImage:image];\r
- image = [NSImage imageNamed:@"fs_pause_highlight"];\r
- [o_play setAlternateImage:image];\r
+ [o_play setImage: [NSImage imageNamed:@"fs_pause"]];\r
+ [o_play setAlternateImage: [NSImage imageNamed:@"fs_pause_highlight"]];\r
}\r
\r
- (void)setStreamTitle:(NSString *)o_title\r
\r
- (void)setSeekable:(BOOL)b_seekable\r
{\r
- [o_slow setEnabled: b_seekable];\r
- [o_fast setEnabled: b_seekable];\r
+ [o_bwd setEnabled: b_seekable];\r
+ [o_fwd setEnabled: b_seekable];\r
[o_fs_timeSlider setEnabled: b_seekable];\r
}\r
\r
[[[VLCMain sharedInstance] getControls] play: sender];\r
}\r
\r
-- (IBAction)faster:(id)sender\r
+- (IBAction)forward:(id)sender\r
{\r
- [[[VLCMain sharedInstance] getControls] faster: sender];\r
+ [[[VLCMain sharedInstance] getControls] forward: sender];\r
}\r
\r
-- (IBAction)slower:(id)sender\r
+- (IBAction)backward:(id)sender\r
{\r
- [[[VLCMain sharedInstance] getControls] slower: sender];\r
+ [[[VLCMain sharedInstance] getControls] backward: sender];\r
}\r
\r
- (IBAction)prev:(id)sender\r
\r
- (void)drawRect:(NSRect)rect\r
{\r
- NSRect frame = [self frame];\r
+ NSRect frame = [self frame];\r
NSRect image_rect;\r
NSImage *img;\r
addImage( @"fs_background", 0, 0, NSCompositeCopy, 0 );\r
[self drawKnobInRect: knobRect];\r
}\r
\r
-@end
\ No newline at end of file
+@end\r
+\r