Commit f3ccaec1 authored by Benjamin Pracht's avatar Benjamin Pracht

* Apply changed made to the 0.8.5 branch to trunk.

* Embedded Vout should work now
* To create an embedded vout, just create a custom view of type VLCEmbeddedVoutView in interface builder
* Just make sure you define the view as resizeable
* Hotkeys and mose events should work
* Tests with the mozilla plugin are welcome

parent 3371c10f
...@@ -34,6 +34,7 @@ ...@@ -34,6 +34,7 @@
OUTLETS = {"o_btn_fullscreen" = id; "o_main" = id; "o_volumeslider" = id; }; OUTLETS = {"o_btn_fullscreen" = id; "o_main" = id; "o_volumeslider" = id; };
SUPERCLASS = NSObject; SUPERCLASS = NSObject;
}, },
{CLASS = VLCEmbeddedVoutView; LANGUAGE = ObjC; SUPERCLASS = VLCVoutView; },
{ {
ACTIONS = { ACTIONS = {
bandSliderUpdated = id; bandSliderUpdated = id;
...@@ -287,7 +288,8 @@ ...@@ -287,7 +288,8 @@
}; };
SUPERCLASS = NSObject; SUPERCLASS = NSObject;
}, },
{CLASS = VLCPlaylistView; LANGUAGE = ObjC; SUPERCLASS = NSOutlineView; } {CLASS = VLCPlaylistView; LANGUAGE = ObjC; SUPERCLASS = NSOutlineView; },
{CLASS = VLCVoutView; LANGUAGE = ObjC; SUPERCLASS = NSView; }
); );
IBVersion = 1; IBVersion = 1;
} }
...@@ -7,6 +7,7 @@ ...@@ -7,6 +7,7 @@
* 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>
* Derk-Jan Hartman <hartman at videolan dot org> * Derk-Jan Hartman <hartman at videolan dot org>
* Benjamin Pracht <bigben at videolan doit org>
* *
* This program is free software; you can redistribute it and/or modify * 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 * it under the terms of the GNU General Public License as published by
...@@ -268,18 +269,31 @@ ...@@ -268,18 +269,31 @@
if( p_vout != NULL ) if( p_vout != NULL )
{ {
id o_embedded_vout_list = [[VLCMain sharedInstance] getEmbeddedList];
while ((o_window = [o_enumerator nextObject])) while ((o_window = [o_enumerator nextObject]))
{ {
if( [[o_window className] isEqualToString: @"VLCWindow"] ) id o_vout_view = nil;
/* We have an embedded vout */
if( [o_embedded_vout_list windowContainsEmbedded: o_window] )
{
o_vout_view = [o_embedded_vout_list getViewForWindow: o_window];
}
/* We have a detached Vout */
else if( [[o_window className] isEqualToString: @"VLCWindow"] )
{
o_vout_view = [o_window getVoutView];
}
if( o_vout_view )
{ {
if( [o_title isEqualToString: _NS("Half Size") ] ) if( [o_title isEqualToString: _NS("Half Size") ] )
[o_window scaleWindowWithFactor: 0.5]; [o_vout_view scaleWindowWithFactor: 0.5];
else if( [o_title isEqualToString: _NS("Normal Size") ] ) else if( [o_title isEqualToString: _NS("Normal Size") ] )
[o_window scaleWindowWithFactor: 1.0]; [o_vout_view scaleWindowWithFactor: 1.0];
else if( [o_title isEqualToString: _NS("Double Size") ] ) else if( [o_title isEqualToString: _NS("Double Size") ] )
[o_window scaleWindowWithFactor: 2.0]; [o_vout_view scaleWindowWithFactor: 2.0];
else if( [o_title isEqualToString: _NS("Float on Top") ] ) else if( [o_title isEqualToString: _NS("Float on Top") ] )
[o_window toggleFloatOnTop]; [o_vout_view toggleFloatOnTop];
else if( [o_title isEqualToString: _NS("Fit to Screen") ] ) else if( [o_title isEqualToString: _NS("Fit to Screen") ] )
{ {
if( ![o_window isZoomed] ) if( ![o_window isZoomed] )
...@@ -287,11 +301,11 @@ ...@@ -287,11 +301,11 @@
} }
else if( [o_title isEqualToString: _NS("Snapshot") ] ) else if( [o_title isEqualToString: _NS("Snapshot") ] )
{ {
[o_window snapshot]; [o_vout_view snapshot];
} }
else else
{ {
[o_window toggleFullscreen]; [o_vout_view toggleFullscreen];
} }
break; break;
} }
...@@ -640,7 +654,9 @@ ...@@ -640,7 +654,9 @@
while( (o_window = [o_enumerator nextObject])) while( (o_window = [o_enumerator nextObject]))
{ {
if( [[o_window className] isEqualToString: @"VLCWindow"] ) if( [[o_window className] isEqualToString: @"VLCWindow"] ||
[[[VLCMain sharedInstance] getEmbeddedList]
windowContainsEmbedded: o_window])
{ {
bEnabled = TRUE; bEnabled = TRUE;
break; break;
......
...@@ -79,6 +79,7 @@ struct intf_sys_t ...@@ -79,6 +79,7 @@ struct intf_sys_t
/* The messages window */ /* The messages window */
msg_subscription_t * p_sub; msg_subscription_t * p_sub;
}; };
/***************************************************************************** /*****************************************************************************
...@@ -93,6 +94,7 @@ struct intf_sys_t ...@@ -93,6 +94,7 @@ struct intf_sys_t
id o_wizard; /* VLCWizard */ id o_wizard; /* VLCWizard */
id o_extended; /* VLCExtended */ id o_extended; /* VLCExtended */
id o_bookmarks; /* VLCBookmarks */ id o_bookmarks; /* VLCBookmarks */
id o_embedded_list; /* VLCEmbeddedList*/
id o_sfilters; /* VLCsFilters */ id o_sfilters; /* VLCsFilters */
/*id o_update; VLCUpdate */ /*id o_update; VLCUpdate */
BOOL nib_main_loaded; /* reference to the main-nib */ BOOL nib_main_loaded; /* reference to the main-nib */
...@@ -278,6 +280,7 @@ struct intf_sys_t ...@@ -278,6 +280,7 @@ struct intf_sys_t
- (id)getInfo; - (id)getInfo;
- (id)getWizard; - (id)getWizard;
- (id)getBookmarks; - (id)getBookmarks;
- (id)getEmbeddedList;
- (void)terminate; - (void)terminate;
- (NSString *)localizedString:(char *)psz; - (NSString *)localizedString:(char *)psz;
- (char *)delocalizeString:(NSString *)psz; - (char *)delocalizeString:(NSString *)psz;
......
...@@ -304,6 +304,7 @@ static VLCMain *_o_sharedMainInstance = nil; ...@@ -304,6 +304,7 @@ static VLCMain *_o_sharedMainInstance = nil;
o_wizard = [[VLCWizard alloc] init]; o_wizard = [[VLCWizard alloc] init];
o_extended = nil; o_extended = nil;
o_bookmarks = [[VLCBookmarks alloc] init]; o_bookmarks = [[VLCBookmarks alloc] init];
o_embedded_list = [[VLCEmbeddedList alloc] init];
o_sfilters = nil; o_sfilters = nil;
/*o_update = [[VLCUpdate alloc] init];*/ /*o_update = [[VLCUpdate alloc] init];*/
...@@ -804,6 +805,15 @@ static VLCMain *_o_sharedMainInstance = nil; ...@@ -804,6 +805,15 @@ static VLCMain *_o_sharedMainInstance = nil;
return nil; return nil;
} }
- (id)getEmbeddedList
{
if( o_embedded_list )
{
return o_embedded_list;
}
return nil;
}
- (void)manage - (void)manage
{ {
playlist_t * p_playlist; playlist_t * p_playlist;
......
...@@ -8,6 +8,7 @@ ...@@ -8,6 +8,7 @@
* Florian G. Pflug <fgp@phlo.org> * Florian G. Pflug <fgp@phlo.org>
* Jon Lech Johansen <jon-vl@nanocrew.net> * Jon Lech Johansen <jon-vl@nanocrew.net>
* Eric Petit <titer@m0k.org> * Eric Petit <titer@m0k.org>
* Benjamin Pracht <bigben at videolan dot org>
* *
* This program is free software; you can redistribute it and/or modify * 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 * it under the terms of the GNU General Public License as published by
...@@ -25,35 +26,99 @@ ...@@ -25,35 +26,99 @@
*****************************************************************************/ *****************************************************************************/
/***************************************************************************** /*****************************************************************************
* VLCWindow interface * VLCEmbeddedList interface
*****************************************************************************/ *****************************************************************************/
@interface VLCWindow : NSWindow @interface VLCEmbeddedList : NSObject
{
NSMutableArray * o_embedded_array;
}
- (id)getEmbeddedVout;
- (void)releaseEmbeddedVout: (id)o_vout_view;
- (void)addEmbeddedVout: (id)o_vout_view;
- (BOOL)windowContainsEmbedded: (id)o_window;
- (id)getViewForWindow: (id)o_window;
@end
/*****************************************************************************
* VLCVoutView interface
*****************************************************************************/
@interface VLCVoutView : NSView
{ {
vout_thread_t * p_vout; vout_thread_t * p_vout;
NSView * o_view; NSView * o_view;
NSRect * s_frame; NSRect * s_frame;
vout_thread_t * p_real_vout; vout_thread_t * p_real_vout;
Ptr p_fullscreen_state; id o_window;
mtime_t i_time_mouse_last_moved;
vlc_bool_t b_init_ok;
} }
- (BOOL)setVout: (vout_thread_t *) p_arg_vout subView: (NSView *) view
- (id) initWithVout: (vout_thread_t *) p_vout view: (NSView *) view frame: (NSRect *) s_arg_frame;
frame: (NSRect *) s_frame; - (void)closeVout;
- (id) initReal: (id) sender;
- (void) close;
- (id) closeReal: (id) sender;
- (void)setOnTop:(BOOL)b_on_top;
- (void)hideMouse:(BOOL)b_hide;
- (void)manage; - (void)manage;
- (void)scaleWindowWithFactor: (float)factor; - (void)scaleWindowWithFactor: (float)factor;
- (void)setOnTop:(BOOL)b_on_top;
- (void)toggleFloatOnTop; - (void)toggleFloatOnTop;
- (void)toggleFullscreen; - (void)toggleFullscreen;
- (BOOL)isFullscreen; - (BOOL)isFullscreen;
- (void)snapshot; - (void)snapshot;
- (id)getWindow;
+ (id)getVoutView: (vout_thread_t *)p_vout subView: (NSView *) view
frame: (NSRect *) s_frame;
+ (vout_thread_t *)getRealVout: (vout_thread_t *)p_vout;
@end
/*****************************************************************************
* VLCVoutDetachedView interface
*****************************************************************************/
@interface VLCDetachedVoutView : VLCVoutView
{
mtime_t i_time_mouse_last_moved;
}
- (void)hideMouse: (BOOL)b_hide;
@end
/*****************************************************************************
* VLCEmbeddedView interface
*****************************************************************************/
@interface VLCEmbeddedVoutView : VLCVoutView
{
BOOL b_used;
}
- (void)setUsed: (BOOL)b_new_used;
- (BOOL)isUsed;
@end
/*****************************************************************************
* VLCWindow interface
*****************************************************************************/
@interface VLCWindow : NSWindow
{
vout_thread_t * p_vout;
VLCVoutView * o_view;
NSRect * s_frame;
vout_thread_t * p_real_vout;
Ptr p_fullscreen_state;
vlc_bool_t b_init_ok;
}
- (id) initWithVout: (vout_thread_t *) p_vout view: (VLCVoutView *) view
frame: (NSRect *) s_frame;
- (id)initReal: (id) sender;
- (void)close;
- (void)closeWindow;
- (id)closeReal: (id) sender;
- (id)getVoutView;
- (void)updateTitle; - (void)updateTitle;
- (BOOL)windowShouldClose:(id)sender; - (BOOL)windowShouldClose:(id)sender;
......
...@@ -9,6 +9,7 @@ ...@@ -9,6 +9,7 @@
* Jon Lech Johansen <jon-vl@nanocrew.net> * Jon Lech Johansen <jon-vl@nanocrew.net>
* Derk-Jan Hartman <hartman at videolan dot org> * Derk-Jan Hartman <hartman at videolan dot org>
* Eric Petit <titer@m0k.org> * Eric Petit <titer@m0k.org>
* Benjamin Pracht <bigben at videolan dot org>
* *
* This program is free software; you can redistribute it and/or modify * 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 * it under the terms of the GNU General Public License as published by
...@@ -61,90 +62,110 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -61,90 +62,110 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
/***************************************************************************** /*****************************************************************************
* VLCWindow implementation * VLCEmbeddedList implementation
*****************************************************************************/ *****************************************************************************/
@implementation VLCWindow @implementation VLCEmbeddedList
- (id) initWithVout: (vout_thread_t *) vout view: (NSView *) view - (id)init
frame: (NSRect *) frame
{ {
p_vout = vout; [super init];
o_view = view; o_embedded_array = [NSMutableArray array];
s_frame = frame;
[self performSelectorOnMainThread: @selector(initReal:)
withObject: NULL waitUntilDone: YES];
if( !b_init_ok )
{
return NULL;
}
return self; return self;
} }
- (id) initReal: (id) sender - (id)getEmbeddedVout
{ {
NSAutoreleasePool *o_pool = [[NSAutoreleasePool alloc] init]; unsigned int i;
NSArray *o_screens = [NSScreen screens];
NSScreen *o_screen;
vlc_bool_t b_menubar_screen = VLC_FALSE;
int i_timeout, i_device;
vlc_value_t value_drawable;
b_init_ok = VLC_FALSE;
var_Get( p_vout->p_vlc, "drawable", &value_drawable );
/* We only wait for NSApp to initialise if we're not embedded (as in the for( i = 0; i < [o_embedded_array count]; i++ )
* case of the Mozilla plugin). We can tell whether we're embedded or not
* by examining the "drawable" value: if it's zero, we're running in the
* main Mac intf; if it's non-zero, we're embedded. */
if( value_drawable.i_int == 0 )
{
/* Wait for a MacOS X interface to appear. Timeout is 2 seconds. */
for( i_timeout = 20 ; i_timeout-- ; )
{ {
if( NSApp == NULL ) id o_vout_view = [o_embedded_array objectAtIndex: i];
if( ![o_vout_view isUsed] )
{ {
msleep( INTF_IDLE_SLEEP ); [o_vout_view setUsed: YES];
return o_vout_view;
} }
} }
return nil;
}
if( NSApp == NULL ) - (void)releaseEmbeddedVout: (id)o_vout_view
{
if( [o_embedded_array containsObject: o_vout_view] )
{ {
/* No MacOS X intf, unable to communicate with MT */ [o_vout_view setUsed: NO];
msg_Err( p_vout, "no MacOS X interface present" );
return NULL;
} }
else
{
msg_Warn( VLCIntf, "Cannot find Video Output");
} }
}
if( [o_screens count] <= 0 ) - (void)addEmbeddedVout: (id)o_vout_view
{
if( ![o_embedded_array containsObject: o_vout_view] )
{ {
msg_Err( p_vout, "no OSX screens available" ); [o_embedded_array addObject: o_vout_view];
return NULL;
} }
}
/* p_real_vout: the vout we have to use to check for video-on-top - (BOOL)windowContainsEmbedded: (id)o_window
and a few other things. If we are the QuickTime output, it's us. {
It we are the OpenGL provider, it is our parent. */ return ([self getViewForWindow: o_window] == nil ? NO : YES);
if( p_vout->i_object_type == VLC_OBJECT_OPENGL ) }
- (id)getViewForWindow: (id)o_window
{
id o_enumerator = [o_embedded_array objectEnumerator];
id o_current_embedded;
while( (o_current_embedded = [o_enumerator nextObject]) )
{ {
p_real_vout = (vout_thread_t *) p_vout->p_parent; if( [o_current_embedded getWindow] == o_window )
}
else
{ {
p_real_vout = p_vout; return o_current_embedded;
} }
}
return nil;
}
p_fullscreen_state = NULL; @end
i_time_mouse_last_moved = mdate();
var_Create( p_vout, "macosx-vdev", VLC_VAR_INTEGER | VLC_VAR_DOINHERIT ); /*****************************************************************************
var_Create( p_vout, "macosx-fill", VLC_VAR_BOOL | VLC_VAR_DOINHERIT ); * VLCVoutView implementation
var_Create( p_vout, "macosx-stretch", VLC_VAR_BOOL | VLC_VAR_DOINHERIT ); *****************************************************************************/
var_Create( p_vout, "macosx-opaqueness", VLC_VAR_FLOAT | VLC_VAR_DOINHERIT ); @implementation VLCVoutView
var_Create( p_vout, "macosx-background", VLC_VAR_BOOL | VLC_VAR_DOINHERIT );
- (id)initWithFrame:(NSRect)frameRect
{
[super initWithFrame: frameRect];
p_vout = NULL;
o_view = nil;
s_frame = &frameRect;
p_real_vout = NULL;
o_window = nil;
return self;
}
- (BOOL)setVout: (vout_thread_t *) vout subView: (NSView *) view
frame: (NSRect *) frame
{
int i_device;
NSAutoreleasePool *o_pool = [[NSAutoreleasePool alloc] init];
NSArray *o_screens = [NSScreen screens];
p_vout = vout;
o_view = view;
s_frame = frame;
if( [o_screens count] <= 0 )
{
msg_Err( p_vout, "no OSX screens available" );
return NO;
}
p_real_vout = [VLCVoutView getRealVout: p_vout];
/* Get the pref value when this is the first time, otherwise retrieve the device from the top level video-device var */ /* Get the pref value when this is the first time, otherwise retrieve the device from the top level video-device var */
if( var_Type( p_real_vout->p_vlc, "video-device" ) == 0 ) if( var_Type( p_real_vout->p_vlc, "video-device" ) == 0 )
...@@ -203,172 +224,40 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -203,172 +224,40 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
var_Set( p_real_vout, "intf-change", val2 ); var_Set( p_real_vout, "intf-change", val2 );
} }
/* Find out on which screen to open the window */
if( i_device <= 0 || i_device > (int)[o_screens count] )
{
/* No preference specified. Use the main screen */
o_screen = [NSScreen mainScreen];
if( o_screen == [o_screens objectAtIndex: 0] )
b_menubar_screen = VLC_TRUE;
}
else
{
i_device--;
o_screen = [o_screens objectAtIndex: i_device];
b_menubar_screen = ( i_device == 0 );
}
if( p_vout->b_fullscreen )
{
NSRect screen_rect = [o_screen frame];
screen_rect.origin.x = screen_rect.origin.y = 0;
/* Creates a window with size: screen_rect on o_screen */
[self initWithContentRect: screen_rect
styleMask: NSBorderlessWindowMask
backing: NSBackingStoreBuffered
defer: YES screen: o_screen];
if( b_menubar_screen )
{
BeginFullScreen( &p_fullscreen_state, NULL, 0, 0,
NULL, NULL, fullScreenAllowEvents );
}
}
else if( var_GetBool( p_real_vout, "macosx-background" ) )
{
NSRect screen_rect = [o_screen frame];
screen_rect.origin.x = screen_rect.origin.y = 0;
/* Creates a window with size: screen_rect on o_screen */
[self initWithContentRect: screen_rect
styleMask: NSBorderlessWindowMask
backing: NSBackingStoreBuffered
defer: YES screen: o_screen];
[self setLevel: CGWindowLevelForKey(kCGDesktopWindowLevelKey)];
}
else
{
unsigned int i_stylemask = NSTitledWindowMask |
NSMiniaturizableWindowMask |
NSClosableWindowMask |
NSResizableWindowMask;
NSRect s_rect;
if( !s_frame )
{
s_rect.size.width = p_vout->i_window_width;
s_rect.size.height = p_vout->i_window_height;
}
else
{
s_rect = *s_frame;
}
[self initWithContentRect: s_rect
styleMask: i_stylemask
backing: NSBackingStoreBuffered
defer: YES screen: o_screen];
[self setAlphaValue: var_GetFloat( p_vout, "macosx-opaqueness" )];
if( var_GetBool( p_real_vout, "video-on-top" ) )
{
[self setLevel: NSStatusWindowLevel];
}
if( !s_frame )
{
[self center];
}
}
[self updateTitle];
[self makeKeyAndOrderFront: nil];
[self setReleasedWhenClosed: YES];
/* We'll catch mouse events */
[self setAcceptsMouseMovedEvents: YES];
[self makeFirstResponder: self];
/* Add the view. It's automatically resized to fit the window */ /* Add the view. It's automatically resized to fit the window */
[self setContentView: o_view]; [self addSubview: o_view];
[self setAutoresizesSubviews: YES];
[o_pool release]; [o_pool release];
b_init_ok = VLC_TRUE; return YES;
return self;
} }
- (void) close - (void)resizeSubviewsWithOldSize:(NSSize)oldBoundsSize
{ {
/* XXX waitUntilDone = NO to avoid a possible deadlock when hitting [super resizeSubviewsWithOldSize: oldBoundsSize];
Command-Q */ [o_view setFrameSize: [self frame].size];
[self setAcceptsMouseMovedEvents: NO];
[self setContentView: NULL];
[self performSelectorOnMainThread: @selector(closeReal:)
withObject: NULL waitUntilDone: NO];
} }
- (id) closeReal: (id) sender - (void)closeVout
{ {
[super close]; [o_view removeFromSuperview];
if( p_fullscreen_state ) o_view = nil;
{ p_vout = NULL;
EndFullScreen( p_fullscreen_state, 0 ); s_frame = nil;
} o_window = nil;
return NULL; p_real_vout = NULL;
} }
- (void)setOnTop:(BOOL)b_on_top - (void)setOnTop:(BOOL)b_on_top
{ {
if( b_on_top ) if( b_on_top )
{ {
[self setLevel: NSStatusWindowLevel]; [o_window setLevel: NSStatusWindowLevel];
}
else
{
[self setLevel: NSNormalWindowLevel];
}
}
- (void)hideMouse:(BOOL)b_hide
{
BOOL b_inside;
NSPoint ml;
NSView *o_contents = [self contentView];
ml = [self convertScreenToBase:[NSEvent mouseLocation]];
ml = [o_contents convertPoint:ml fromView:nil];
b_inside = [o_contents mouse: ml inRect: [o_contents bounds]];
if( b_hide && b_inside )
{
[NSCursor setHiddenUntilMouseMoves: YES];
}
else if( !b_hide )
{
[NSCursor setHiddenUntilMouseMoves: NO];
}
}
- (void)manage
{
if( p_fullscreen_state )
{
if( mdate() - i_time_mouse_last_moved > 3000000 )
{
[self hideMouse: YES];
}
} }
else else
{ {
[self hideMouse: NO]; [o_window setLevel: NSNormalWindowLevel];
} }
/* Disable screensaver */
UpdateSystemActivity( UsrActivity );
} }
- (void)scaleWindowWithFactor: (float)factor - (void)scaleWindowWithFactor: (float)factor
...@@ -380,9 +269,10 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -380,9 +269,10 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
if ( !p_vout->b_fullscreen ) if ( !p_vout->b_fullscreen )
{ {
NSRect new_frame;
topleftbase.x = 0; topleftbase.x = 0;
topleftbase.y = [self frame].size.height; topleftbase.y = [o_window frame].size.height;
topleftscreen = [self convertBaseToScreen: topleftbase]; topleftscreen = [o_window convertBaseToScreen: topleftbase];
if( p_vout->render.i_height * p_vout->render.i_aspect > if( p_vout->render.i_height * p_vout->render.i_aspect >
p_vout->render.i_width * VOUT_ASPECT_FACTOR ) p_vout->render.i_width * VOUT_ASPECT_FACTOR )
...@@ -400,9 +290,17 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -400,9 +290,17 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
newsize.height = (int) ( i_corrected_height * factor ); newsize.height = (int) ( i_corrected_height * factor );
} }
[self setContentSize: newsize]; /* Calculate the window's new size */
new_frame.size.width = [o_window frame].size.width -
[self frame].size.width + newsize.width;
new_frame.size.height = [o_window frame].size.height -
[self frame].size.height + newsize.height;
new_frame.origin.x = topleftscreen.x;
new_frame.origin.y = topleftscreen.y - new_frame.size.height;
[o_window setFrame: new_frame display: YES];
[self setFrameTopLeftPoint: topleftscreen];
p_vout->i_changes |= VOUT_SIZE_CHANGE; p_vout->i_changes |= VOUT_SIZE_CHANGE;
} }
} }
...@@ -442,16 +340,16 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -442,16 +340,16 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
vout_Control( p_real_vout, VOUT_SNAPSHOT ); vout_Control( p_real_vout, VOUT_SNAPSHOT );
} }
- (BOOL)canBecomeKeyWindow - (void)manage
{ {
return YES; /* Disable Screensaver */
UpdateSystemActivity( UsrActivity );
} }
/* Sometimes crashes VLC.... - (id)getWindow
- (BOOL)performKeyEquivalent:(NSEvent *)o_event
{ {
return [[VLCMain sharedInstance] hasDefinedShortcutKey:o_event]; return o_window;
}*/ }
- (void)keyDown:(NSEvent *)o_event - (void)keyDown:(NSEvent *)o_event
{ {
...@@ -501,89 +399,13 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -501,89 +399,13 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
} }
} }
- (void)updateTitle - (void)mouseDown:(NSEvent *)o_event
{ {
NSMutableString * o_title = NULL, * o_mrl = NULL; vlc_value_t val;
input_thread_t * p_input;
if( p_vout == NULL ) if( p_vout )
{ {
return; switch( [o_event type] )
}
p_input = vlc_object_find( p_vout, VLC_OBJECT_INPUT, FIND_PARENT );
if( p_input == NULL )
{
return;
}
if( p_input->input.p_item->psz_name != NULL )
o_title = [NSMutableString stringWithUTF8String:
p_input->input.p_item->psz_name];
if( p_input->input.p_item->psz_uri != NULL )
o_mrl = [NSMutableString stringWithUTF8String:
p_input->input.p_item->psz_uri];
if( o_title == nil )
o_title = o_mrl;
if( o_mrl != nil )
{
if( p_input->input.p_access && !strcmp( p_input->input.p_access->p_module->psz_shortname, "File" ) )
{
NSRange prefix_range = [o_mrl rangeOfString: @"file:"];
if( prefix_range.location != NSNotFound )
[o_mrl deleteCharactersInRange: prefix_range];
[self setRepresentedFilename: o_mrl];
}
[self setTitle: o_title];
}
else
{
[self setTitle: [NSString stringWithCString: VOUT_TITLE]];
}
vlc_object_release( p_input );
}
/* This is actually the same as VLCControls::stop. */
- (BOOL)windowShouldClose:(id)sender
{
playlist_t * p_playlist = vlc_object_find( p_vout, VLC_OBJECT_PLAYLIST,
FIND_ANYWHERE );
if( p_playlist == NULL )
{
return NO;
}
playlist_Stop( p_playlist );
vlc_object_release( p_playlist );
/* The window will be closed by the intf later. */
return NO;
}
- (BOOL)acceptsFirstResponder
{
return YES;
}
- (BOOL)becomeFirstResponder
{
return YES;
}
- (BOOL)resignFirstResponder
{
/* We need to stay the first responder or we'll miss some
events */
return NO;
}
- (void)mouseDown:(NSEvent *)o_event
{
vlc_value_t val;
switch( [o_event type] )
{ {
case NSLeftMouseDown: case NSLeftMouseDown:
{ {
...@@ -597,12 +419,15 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -597,12 +419,15 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
[super mouseDown: o_event]; [super mouseDown: o_event];
break; break;
} }
}
} }
- (void)otherMouseDown:(NSEvent *)o_event - (void)otherMouseDown:(NSEvent *)o_event
{ {
vlc_value_t val; vlc_value_t val;
if( p_vout )
{
switch( [o_event type] ) switch( [o_event type] )
{ {
case NSOtherMouseDown: case NSOtherMouseDown:
...@@ -617,12 +442,15 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -617,12 +442,15 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
[super mouseDown: o_event]; [super mouseDown: o_event];
break; break;
} }
}
} }
- (void)rightMouseDown:(NSEvent *)o_event - (void)rightMouseDown:(NSEvent *)o_event
{ {
vlc_value_t val; vlc_value_t val;
if( p_vout )
{
switch( [o_event type] ) switch( [o_event type] )
{ {
case NSRightMouseDown: case NSRightMouseDown:
...@@ -637,12 +465,15 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -637,12 +465,15 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
[super mouseDown: o_event]; [super mouseDown: o_event];
break; break;
} }
}
} }
- (void)mouseUp:(NSEvent *)o_event - (void)mouseUp:(NSEvent *)o_event
{ {
vlc_value_t val; vlc_value_t val;
if( p_vout )
{
switch( [o_event type] ) switch( [o_event type] )
{ {
case NSLeftMouseUp: case NSLeftMouseUp:
...@@ -661,12 +492,15 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -661,12 +492,15 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
[super mouseUp: o_event]; [super mouseUp: o_event];
break; break;
} }
}
} }
- (void)otherMouseUp:(NSEvent *)o_event - (void)otherMouseUp:(NSEvent *)o_event
{ {
vlc_value_t val; vlc_value_t val;
if( p_vout )
{
switch( [o_event type] ) switch( [o_event type] )
{ {
case NSOtherMouseUp: case NSOtherMouseUp:
...@@ -681,12 +515,15 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -681,12 +515,15 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
[super mouseUp: o_event]; [super mouseUp: o_event];
break; break;
} }
}
} }
- (void)rightMouseUp:(NSEvent *)o_event - (void)rightMouseUp:(NSEvent *)o_event
{ {
vlc_value_t val; vlc_value_t val;
if( p_vout )
{
switch( [o_event type] ) switch( [o_event type] )
{ {
case NSRightMouseUp: case NSRightMouseUp:
...@@ -701,6 +538,7 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -701,6 +538,7 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
[super mouseUp: o_event]; [super mouseUp: o_event];
break; break;
} }
}
} }
- (void)mouseDragged:(NSEvent *)o_event - (void)mouseDragged:(NSEvent *)o_event
...@@ -724,8 +562,8 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -724,8 +562,8 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
NSRect s_rect; NSRect s_rect;
BOOL b_inside; BOOL b_inside;
i_time_mouse_last_moved = mdate(); if( p_vout )
{
s_rect = [o_view bounds]; s_rect = [o_view bounds];
ml = [o_view convertPoint: [o_event locationInWindow] fromView: nil]; ml = [o_view convertPoint: [o_event locationInWindow] fromView: nil];
b_inside = [o_view mouse: ml inRect: s_rect]; b_inside = [o_view mouse: ml inRect: s_rect];
...@@ -758,8 +596,470 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -758,8 +596,470 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
val.b_bool = VLC_TRUE; val.b_bool = VLC_TRUE;
var_Set( p_vout, "mouse-moved", val ); var_Set( p_vout, "mouse-moved", val );
} }
}
[super mouseMoved: o_event];
}
- (BOOL)acceptsFirstResponder
{
return YES;
}
- (BOOL)becomeFirstResponder
{
return YES;
}
- (BOOL)resignFirstResponder
{
/* We need to stay the first responder or we'll miss some
events */
return NO;
}
/* Class methods used by the different vout modules */
+ (vout_thread_t *)getRealVout: (vout_thread_t *)p_vout
{
/* p_real_vout: the vout we have to use to check for video-on-top
and a few other things. If we are the QuickTime output, it's us.
It we are the OpenGL provider, it is our parent. */
if( p_vout->i_object_type == VLC_OBJECT_OPENGL )
{
return (vout_thread_t *) p_vout->p_parent;
}
else
{
return p_vout;
}
}
+ (id)getVoutView: (vout_thread_t *)p_vout subView: (NSView *)view
frame: (NSRect *)s_frame
{
vlc_value_t value_drawable;
int i_timeout;
id o_return = nil;
vout_thread_t * p_real_vout = [VLCVoutView getRealVout: p_vout];
var_Get( p_vout->p_vlc, "drawable", &value_drawable );
var_Create( p_vout, "macosx-vdev", VLC_VAR_INTEGER | VLC_VAR_DOINHERIT );
var_Create( p_vout, "macosx-fill", VLC_VAR_BOOL | VLC_VAR_DOINHERIT );
var_Create( p_vout, "macosx-stretch", VLC_VAR_BOOL | VLC_VAR_DOINHERIT );
var_Create( p_vout, "macosx-opaqueness", VLC_VAR_FLOAT | VLC_VAR_DOINHERIT );
var_Create( p_vout, "macosx-background", VLC_VAR_BOOL | VLC_VAR_DOINHERIT );
/* We only wait for NSApp to initialise if we're not embedded (as in the
* case of the Mozilla plugin). We can tell whether we're embedded or not
* by examining the "drawable" value: if it's zero, we're running in the
* main Mac intf; if it's non-zero, we're embedded. */
if( value_drawable.i_int == 0 )
{
/* Wait for a MacOS X interface to appear. Timeout is 2 seconds. */
for( i_timeout = 20 ; i_timeout-- ; )
{
if( NSApp == NULL )
{
msleep( INTF_IDLE_SLEEP );
}
}
if( NSApp == NULL )
{
/* No MacOS X intf, unable to communicate with MT */
msg_Err( p_vout, "no MacOS X interface present" );
return nil;
}
else
{
if ( VLCIntf && !(p_vout->b_fullscreen) &&
!(var_GetBool( p_real_vout, "macosx-background" )) )
{
o_return = [[[VLCMain sharedInstance] getEmbeddedList]
getEmbeddedVout];
}
}
}
/* No embedded vout is available */
if( o_return == nil )
{
NSRect null_rect;
bzero( &null_rect, sizeof( NSRect ) );
o_return = [[VLCDetachedVoutView alloc] initWithFrame: null_rect ];
}
[o_return setVout: p_vout subView: view frame: s_frame];
return o_return;
}
@end
/*****************************************************************************
* VLCDetachedVoutView implementation
*****************************************************************************/
@implementation VLCDetachedVoutView
- (id)initWithFrame: (NSRect)frameRect
{
[super initWithFrame: frameRect];
i_time_mouse_last_moved = 0;
return self;
}
- (bool)setVout: (vout_thread_t *) p_arg_vout subView: (NSView *) view
frame: (NSRect *) s_arg_frame
{
BOOL b_return = [super setVout: p_arg_vout subView: view frame:s_arg_frame];
i_time_mouse_last_moved = mdate();
o_window = [[VLCWindow alloc] initWithVout: p_arg_vout view: self
frame: s_arg_frame];
[view setFrame: [self frame]];
[o_window setAcceptsMouseMovedEvents: TRUE];
return b_return;
}
- (void)closeVout
{
[o_window closeWindow];
[o_window setAcceptsMouseMovedEvents: NO];
i_time_mouse_last_moved = 0;
[super closeVout];
}
- (void)mouseMoved:(NSEvent *)o_event
{
i_time_mouse_last_moved = mdate();
[super mouseMoved: o_event]; [super mouseMoved: o_event];
} }
- (void)hideMouse:(BOOL)b_hide
{
BOOL b_inside;
NSPoint ml;
NSView *o_contents = [o_window contentView];
ml = [o_window convertScreenToBase:[NSEvent mouseLocation]];
ml = [o_contents convertPoint:ml fromView:nil];
b_inside = [o_contents mouse: ml inRect: [o_contents bounds]];
if( b_hide && b_inside )
{
[NSCursor setHiddenUntilMouseMoves: YES];
}
else if( !b_hide )
{
[NSCursor setHiddenUntilMouseMoves: NO];
}
}
- (void)manage
{
[super manage];
if( p_vout->b_fullscreen )
{
if( mdate() - i_time_mouse_last_moved > 3000000 )
{
[self hideMouse: YES];
}
}
else
{
[self hideMouse: NO];
}
}
@end
/*****************************************************************************
* VLCEmbeddedVoutView implementation
*****************************************************************************/
@implementation VLCEmbeddedVoutView
- (id)initWithFrame: (NSRect)frameRect
{
[super initWithFrame: frameRect];
b_used = NO;
[[[VLCMain sharedInstance] getEmbeddedList] addEmbeddedVout: self];
return self;
}
- (BOOL)setVout: (vout_thread_t *) p_arg_vout subView: (NSView *) view
frame: (NSRect *) s_arg_frame
{
BOOL b_return;
b_return = [super setVout: p_arg_vout subView: view frame: s_arg_frame];
if( b_return )
{
o_window = [self window];
[o_window makeKeyAndOrderFront: self];
[o_window setAcceptsMouseMovedEvents: TRUE];
[view setFrameSize: [self frame].size];
}
return b_return;
}
- (void)setUsed: (BOOL)b_new_used
{
b_used = b_new_used;
}
- (BOOL)isUsed
{
return b_used;
}
- (void)closeVout
{
[super closeVout];
[o_window setAcceptsMouseMovedEvents: NO];
[[[VLCMain sharedInstance] getEmbeddedList] releaseEmbeddedVout: self];
}
@end
/*****************************************************************************
* VLCWindow implementation
*****************************************************************************/
@implementation VLCWindow
- (id) initWithVout: (vout_thread_t *) vout view: (VLCVoutView *) view
frame: (NSRect *) frame
{
p_vout = vout;
o_view = view;
s_frame = frame;
[self performSelectorOnMainThread: @selector(initReal:)
withObject: NULL waitUntilDone: YES];
if( !b_init_ok )
{
return NULL;
}
return self;
}
- (id) initReal: (id) sender
{
NSAutoreleasePool *o_pool = [[NSAutoreleasePool alloc] init];
NSArray *o_screens = [NSScreen screens];
NSScreen *o_screen;
vlc_bool_t b_menubar_screen = VLC_FALSE;
int i_device;
b_init_ok = VLC_FALSE;
p_fullscreen_state = NULL;
p_real_vout = [VLCVoutView getRealVout: p_vout];
i_device = var_GetInteger( p_real_vout->p_vlc, "video-device" );
/* Find out on which screen to open the window */
if( i_device <= 0 || i_device > (int)[o_screens count] )
{
/* No preference specified. Use the main screen */
o_screen = [NSScreen mainScreen];
if( o_screen == [o_screens objectAtIndex: 0] )
b_menubar_screen = VLC_TRUE;
}
else
{
i_device--;
o_screen = [o_screens objectAtIndex: i_device];
b_menubar_screen = ( i_device == 0 );
}
if( p_vout->b_fullscreen )
{
NSRect screen_rect = [o_screen frame];
screen_rect.origin.x = screen_rect.origin.y = 0;
/* Creates a window with size: screen_rect on o_screen */
[self initWithContentRect: screen_rect
styleMask: NSBorderlessWindowMask
backing: NSBackingStoreBuffered
defer: YES screen: o_screen];
if( b_menubar_screen )
{
BeginFullScreen( &p_fullscreen_state, NULL, 0, 0,
NULL, NULL, fullScreenAllowEvents );
}
}
else if( var_GetBool( p_real_vout, "macosx-background" ) )
{
NSRect screen_rect = [o_screen frame];
screen_rect.origin.x = screen_rect.origin.y = 0;
/* Creates a window with size: screen_rect on o_screen */
[self initWithContentRect: screen_rect
styleMask: NSBorderlessWindowMask
backing: NSBackingStoreBuffered
defer: YES screen: o_screen];
[self setLevel: CGWindowLevelForKey(kCGDesktopWindowLevelKey)];
}
else
{
unsigned int i_stylemask = NSTitledWindowMask |
NSMiniaturizableWindowMask |
NSClosableWindowMask |
NSResizableWindowMask;
NSRect s_rect;
if( !s_frame )
{
s_rect.size.width = p_vout->i_window_width;
s_rect.size.height = p_vout->i_window_height;
}
else
{
s_rect = *s_frame;
}
[self initWithContentRect: s_rect
styleMask: i_stylemask
backing: NSBackingStoreBuffered
defer: YES screen: o_screen];
[self setAlphaValue: var_GetFloat( p_vout, "macosx-opaqueness" )];
if( var_GetBool( p_real_vout, "video-on-top" ) )
{
[self setLevel: NSStatusWindowLevel];
}
if( !s_frame )
{
[self center];
}
}
[self updateTitle];
[self makeKeyAndOrderFront: nil];
[self setReleasedWhenClosed: YES];
/* We'll catch mouse events */
[self makeFirstResponder: o_view];
/* Add the view. It's automatically resized to fit the window */
[self setContentView: o_view];
[o_pool release];
b_init_ok = VLC_TRUE;
return self;
}
- (void)close
{
[o_view closeVout];
}
- (void) closeWindow
{
/* XXX waitUntilDone = NO to avoid a possible deadlock when hitting
Command-Q */
[self setContentView: NULL];
[self performSelectorOnMainThread: @selector(closeReal:)
withObject: NULL waitUntilDone: NO];
}
- (id) closeReal: (id) sender
{
[super close];
if( p_fullscreen_state )
{
EndFullScreen( p_fullscreen_state, 0 );
}
return NULL;
}
- (id)getVoutView
{
return o_view;
}
- (BOOL)canBecomeKeyWindow
{
return YES;
}
/* Sometimes crashes VLC....
- (BOOL)performKeyEquivalent:(NSEvent *)o_event
{
return [[VLCMain sharedInstance] hasDefinedShortcutKey:o_event];
}*/
/* This is actually the same as VLCControls::stop. */
- (void)updateTitle /*not modified yey ! */
{
NSMutableString * o_title = NULL, * o_mrl = NULL;
input_thread_t * p_input;
if( p_vout == NULL )
{
return;
}
p_input = vlc_object_find( p_vout, VLC_OBJECT_INPUT, FIND_PARENT );
if( p_input == NULL )
{
return;
}
if( p_input->input.p_item->psz_name != NULL )
o_title = [NSMutableString stringWithUTF8String:
p_input->input.p_item->psz_name];
if( p_input->input.p_item->psz_uri != NULL )
o_mrl = [NSMutableString stringWithUTF8String:
p_input->input.p_item->psz_uri];
if( o_title == nil )
o_title = o_mrl;
if( o_mrl != nil )
{
if( p_input->input.p_access && !strcmp( p_input->input.p_access->p_module->psz_shortname, "File" ) )
{
NSRange prefix_range = [o_mrl rangeOfString: @"file:"];
if( prefix_range.location != NSNotFound )
[o_mrl deleteCharactersInRange: prefix_range];
[self setRepresentedFilename: o_mrl];
}
[self setTitle: o_title];
}
else
{
[self setTitle: [NSString stringWithCString: VOUT_TITLE]];
}
vlc_object_release( p_input );
}
- (BOOL)windowShouldClose:(id)sender
{
playlist_t * p_playlist = vlc_object_find( p_vout, VLC_OBJECT_PLAYLIST,
FIND_ANYWHERE );
if( p_playlist == NULL )
{
return NO;
}
playlist_Stop( p_playlist );
vlc_object_release( p_playlist );
/* The window will be closed by the intf later. */
return NO;
}
@end @end
...@@ -9,6 +9,7 @@ ...@@ -9,6 +9,7 @@
* Jon Lech Johansen <jon-vl@nanocrew.net> * Jon Lech Johansen <jon-vl@nanocrew.net>
* Derk-Jan Hartman <hartman at videolan dot org> * Derk-Jan Hartman <hartman at videolan dot org>
* Eric Petit <titer@m0k.org> * Eric Petit <titer@m0k.org>
* Benjamin Pracht <bigben at videolan dot org>
* *
* This program is free software; you can redistribute it and/or modify * 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 * it under the terms of the GNU General Public License as published by
...@@ -54,8 +55,8 @@ ...@@ -54,8 +55,8 @@
struct vout_sys_t struct vout_sys_t
{ {
NSAutoreleasePool * o_pool; NSAutoreleasePool * o_pool;
VLCWindow * o_window;
VLCGLView * o_glview; VLCGLView * o_glview;
VLCVoutView * o_vout_view;
vlc_bool_t b_saved_frame; vlc_bool_t b_saved_frame;
NSRect s_frame; NSRect s_frame;
vlc_bool_t b_got_frame; vlc_bool_t b_got_frame;
...@@ -102,14 +103,15 @@ int E_(OpenVideoGL) ( vlc_object_t * p_this ) ...@@ -102,14 +103,15 @@ int E_(OpenVideoGL) ( vlc_object_t * p_this )
[p_vout->p_sys->o_glview autorelease]; [p_vout->p_sys->o_glview autorelease];
/* Spawn the window */ /* Spawn the window */
p_vout->p_sys->b_got_frame = VLC_FALSE;
p_vout->p_sys->o_window = [[VLCWindow alloc] initWithVout: p_vout if( !(p_vout->p_sys->o_vout_view = [VLCVoutView getVoutView: p_vout
view: p_vout->p_sys->o_glview frame: nil]; subView: p_vout->p_sys->o_glview frame: nil]) )
if( !p_vout->p_sys->o_window )
{ {
return VLC_EGENERIC; return VLC_EGENERIC;
} }
p_vout->p_sys->b_got_frame = VLC_FALSE;
p_vout->pf_init = Init; p_vout->pf_init = Init;
p_vout->pf_end = End; p_vout->pf_end = End;
p_vout->pf_manage = Manage; p_vout->pf_manage = Manage;
...@@ -127,7 +129,7 @@ void E_(CloseVideoGL) ( vlc_object_t * p_this ) ...@@ -127,7 +129,7 @@ void E_(CloseVideoGL) ( vlc_object_t * p_this )
NSAutoreleasePool *o_pool = [[NSAutoreleasePool alloc] init]; NSAutoreleasePool *o_pool = [[NSAutoreleasePool alloc] init];
/* Close the window */ /* Close the window */
[p_vout->p_sys->o_window close]; [p_vout->p_sys->o_vout_view closeVout];
/* Clean up */ /* Clean up */
vlc_mutex_destroy( &p_vout->p_sys->lock ); vlc_mutex_destroy( &p_vout->p_sys->lock );
...@@ -156,12 +158,12 @@ static int Manage( vout_thread_t * p_vout ) ...@@ -156,12 +158,12 @@ static int Manage( vout_thread_t * p_vout )
{ {
/* Save window size and position */ /* Save window size and position */
p_vout->p_sys->s_frame.size = p_vout->p_sys->s_frame.size =
[[p_vout->p_sys->o_window contentView] frame].size; [p_vout->p_sys->o_vout_view frame].size;
p_vout->p_sys->s_frame.origin = p_vout->p_sys->s_frame.origin =
[p_vout->p_sys->o_window frame].origin; [[p_vout->p_sys->o_vout_view getWindow ]frame].origin;
p_vout->p_sys->b_saved_frame = VLC_TRUE; p_vout->p_sys->b_saved_frame = VLC_TRUE;
} }
[p_vout->p_sys->o_window close]; [p_vout->p_sys->o_vout_view closeVout];
p_vout->b_fullscreen = !p_vout->b_fullscreen; p_vout->b_fullscreen = !p_vout->b_fullscreen;
...@@ -171,14 +173,15 @@ static int Manage( vout_thread_t * p_vout ) ...@@ -171,14 +173,15 @@ static int Manage( vout_thread_t * p_vout )
if( p_vout->p_sys->b_saved_frame ) if( p_vout->p_sys->b_saved_frame )
{ {
p_vout->p_sys->o_window = [[VLCWindow alloc] p_vout->p_sys->o_vout_view = [VLCVoutView getVoutView: p_vout
initWithVout: p_vout view: o_glview subView: o_glview
frame: &p_vout->p_sys->s_frame]; frame: &p_vout->p_sys->s_frame];
} }
else else
{ {
p_vout->p_sys->o_window = [[VLCWindow alloc] p_vout->p_sys->o_vout_view = [VLCVoutView getVoutView: p_vout
initWithVout: p_vout view: o_glview frame: nil]; subView: o_glview frame: nil];
} }
[[o_glview openGLContext] makeCurrentContext]; [[o_glview openGLContext] makeCurrentContext];
...@@ -188,7 +191,7 @@ static int Manage( vout_thread_t * p_vout ) ...@@ -188,7 +191,7 @@ static int Manage( vout_thread_t * p_vout )
p_vout->i_changes &= ~VOUT_FULLSCREEN_CHANGE; p_vout->i_changes &= ~VOUT_FULLSCREEN_CHANGE;
} }
[p_vout->p_sys->o_window manage]; [p_vout->p_sys->o_vout_view manage];
return VLC_SUCCESS; return VLC_SUCCESS;
} }
...@@ -203,7 +206,7 @@ static int Control( vout_thread_t *p_vout, int i_query, va_list args ) ...@@ -203,7 +206,7 @@ static int Control( vout_thread_t *p_vout, int i_query, va_list args )
{ {
case VOUT_SET_STAY_ON_TOP: case VOUT_SET_STAY_ON_TOP:
b_arg = va_arg( args, vlc_bool_t ); b_arg = va_arg( args, vlc_bool_t );
[p_vout->p_sys->o_window setOnTop: b_arg]; [p_vout->p_sys->o_vout_view setOnTop: b_arg];
return VLC_SUCCESS; return VLC_SUCCESS;
case VOUT_CLOSE: case VOUT_CLOSE:
......
...@@ -57,8 +57,8 @@ ...@@ -57,8 +57,8 @@
struct vout_sys_t struct vout_sys_t
{ {
NSAutoreleasePool *o_pool; NSAutoreleasePool *o_pool;
VLCWindow * o_window;
VLCQTView * o_qtview; VLCQTView * o_qtview;
VLCVoutView * o_vout_view;
vlc_bool_t b_saved_frame; vlc_bool_t b_saved_frame;
vlc_bool_t b_altivec; vlc_bool_t b_altivec;
...@@ -215,9 +215,9 @@ int E_(OpenVideoQT) ( vlc_object_t *p_this ) ...@@ -215,9 +215,9 @@ int E_(OpenVideoQT) ( vlc_object_t *p_this )
else else
{ {
/* Spawn window */ /* Spawn window */
p_vout->p_sys->o_window = [[VLCWindow alloc] p_vout->p_sys->o_vout_view = [VLCVoutView getVoutView: p_vout
initWithVout: p_vout view: o_qtview frame: nil]; subView: o_qtview frame: nil];
if( !p_vout->p_sys->o_window ) if( !p_vout->p_sys->o_vout_view )
{ {
return VLC_EGENERIC; return VLC_EGENERIC;
} }
...@@ -251,7 +251,7 @@ void E_(CloseVideoQT) ( vlc_object_t *p_this ) ...@@ -251,7 +251,7 @@ void E_(CloseVideoQT) ( vlc_object_t *p_this )
vout_thread_t * p_vout = (vout_thread_t *)p_this; vout_thread_t * p_vout = (vout_thread_t *)p_this;
if( !p_vout->p_sys->b_embedded ) if( !p_vout->p_sys->b_embedded )
[p_vout->p_sys->o_window close]; [p_vout->p_sys->o_vout_view closeVout];
/* Clean Up Quicktime environment */ /* Clean Up Quicktime environment */
ExitMovies(); ExitMovies();
...@@ -386,7 +386,7 @@ static int ManageVideo( vout_thread_t *p_vout ) ...@@ -386,7 +386,7 @@ static int ManageVideo( vout_thread_t *p_vout )
p_vout->i_changes &= ~VOUT_SIZE_CHANGE; p_vout->i_changes &= ~VOUT_SIZE_CHANGE;
} }
[p_vout->p_sys->o_window manage]; [p_vout->p_sys->o_vout_view manage];
return( 0 ); return( 0 );
} }
...@@ -463,7 +463,7 @@ static int ControlVideo( vout_thread_t *p_vout, int i_query, va_list args ) ...@@ -463,7 +463,7 @@ static int ControlVideo( vout_thread_t *p_vout, int i_query, va_list args )
{ {
case VOUT_SET_STAY_ON_TOP: case VOUT_SET_STAY_ON_TOP:
b_arg = va_arg( args, vlc_bool_t ); b_arg = va_arg( args, vlc_bool_t );
[p_vout->p_sys->o_window setOnTop: b_arg]; [p_vout->p_sys->o_vout_view setOnTop: b_arg];
return VLC_SUCCESS; return VLC_SUCCESS;
case VOUT_CLOSE: case VOUT_CLOSE:
...@@ -488,12 +488,12 @@ static int CoToggleFullscreen( vout_thread_t *p_vout ) ...@@ -488,12 +488,12 @@ static int CoToggleFullscreen( vout_thread_t *p_vout )
{ {
/* Save window size and position */ /* Save window size and position */
p_vout->p_sys->s_frame.size = p_vout->p_sys->s_frame.size =
[[p_vout->p_sys->o_window contentView] frame].size; [p_vout->p_sys->o_vout_view frame].size;
p_vout->p_sys->s_frame.origin = p_vout->p_sys->s_frame.origin =
[p_vout->p_sys->o_window frame].origin; [[p_vout->p_sys->o_vout_view getWindow] frame].origin;
p_vout->p_sys->b_saved_frame = VLC_TRUE; p_vout->p_sys->b_saved_frame = VLC_TRUE;
} }
[p_vout->p_sys->o_window close]; [p_vout->p_sys->o_vout_view closeVout];
p_vout->b_fullscreen = !p_vout->b_fullscreen; p_vout->b_fullscreen = !p_vout->b_fullscreen;
...@@ -503,14 +503,14 @@ static int CoToggleFullscreen( vout_thread_t *p_vout ) ...@@ -503,14 +503,14 @@ static int CoToggleFullscreen( vout_thread_t *p_vout )
if( p_vout->p_sys->b_saved_frame ) if( p_vout->p_sys->b_saved_frame )
{ {
p_vout->p_sys->o_window = [[VLCWindow alloc] p_vout->p_sys->o_vout_view = [VLCVoutView getVoutView: p_vout
initWithVout: p_vout view: o_qtview subView: o_qtview
frame: &p_vout->p_sys->s_frame]; frame: &p_vout->p_sys->s_frame];
} }
else else
{ {
p_vout->p_sys->o_window = [[VLCWindow alloc] p_vout->p_sys->o_vout_view = [VLCVoutView getVoutView: p_vout
initWithVout: p_vout view: o_qtview frame: nil]; subView: o_qtview frame: nil];
} }
/* Retrieve the QuickDraw port */ /* Retrieve the QuickDraw port */
......
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