Commit b8329984 authored by Felix Paul Kühne's avatar Felix Paul Kühne Committed by Jean-Baptiste Kempf

macosx: fix DVD menu control and usage of hotkeys with modifiers

fixes both #5733 and #5806
(cherry picked from commit a3349c78)
Signed-off-by: default avatarJean-Baptiste Kempf <jb@videolan.org>
parent 0747e1cc
...@@ -355,14 +355,14 @@ ...@@ -355,14 +355,14 @@
<object class="NSOutlineView" id="23448837"> <object class="NSOutlineView" id="23448837">
<reference key="NSNextResponder" ref="343242432"/> <reference key="NSNextResponder" ref="343242432"/>
<int key="NSvFlags">4370</int> <int key="NSvFlags">4370</int>
<string key="NSFrameSize">{482, 236}</string> <string key="NSFrameSize">{480, 236}</string>
<reference key="NSSuperview" ref="343242432"/> <reference key="NSSuperview" ref="343242432"/>
<int key="NSViewLayerContentsRedrawPolicy">2</int> <int key="NSViewLayerContentsRedrawPolicy">2</int>
<bool key="NSEnabled">YES</bool> <bool key="NSEnabled">YES</bool>
<object class="NSTableHeaderView" key="NSHeaderView" id="823165105"> <object class="NSTableHeaderView" key="NSHeaderView" id="823165105">
<reference key="NSNextResponder" ref="576307303"/> <reference key="NSNextResponder" ref="576307303"/>
<int key="NSvFlags">256</int> <int key="NSvFlags">256</int>
<string key="NSFrameSize">{482, 17}</string> <string key="NSFrameSize">{480, 17}</string>
<reference key="NSSuperview" ref="576307303"/> <reference key="NSSuperview" ref="576307303"/>
<int key="NSViewLayerContentsRedrawPolicy">2</int> <int key="NSViewLayerContentsRedrawPolicy">2</int>
<reference key="NSTableView" ref="23448837"/> <reference key="NSTableView" ref="23448837"/>
...@@ -409,7 +409,7 @@ ...@@ -409,7 +409,7 @@
</object> </object>
<object class="NSTableColumn" id="965199398"> <object class="NSTableColumn" id="965199398">
<string key="NSIdentifier">name</string> <string key="NSIdentifier">name</string>
<double key="NSWidth">222</double> <double key="NSWidth">220</double>
<double key="NSMinWidth">16</double> <double key="NSMinWidth">16</double>
<double key="NSMaxWidth">1000</double> <double key="NSMaxWidth">1000</double>
<object class="NSTableHeaderCell" key="NSHeaderCell"> <object class="NSTableHeaderCell" key="NSHeaderCell">
...@@ -524,10 +524,9 @@ ...@@ -524,10 +524,9 @@
</object> </object>
<object class="NSScroller" id="297523533"> <object class="NSScroller" id="297523533">
<reference key="NSNextResponder" ref="915491793"/> <reference key="NSNextResponder" ref="915491793"/>
<int key="NSvFlags">256</int> <int key="NSvFlags">-2147483392</int>
<string key="NSFrame">{{1, 238}, {480, 15}}</string> <string key="NSFrame">{{1, 238}, {480, 15}}</string>
<reference key="NSSuperview" ref="915491793"/> <reference key="NSSuperview" ref="915491793"/>
<bool key="NSEnabled">YES</bool>
<int key="NSsFlags">1</int> <int key="NSsFlags">1</int>
<reference key="NSTarget" ref="915491793"/> <reference key="NSTarget" ref="915491793"/>
<string key="NSAction">_doScroller:</string> <string key="NSAction">_doScroller:</string>
...@@ -553,7 +552,7 @@ ...@@ -553,7 +552,7 @@
<reference key="NSSuperview" ref="440594360"/> <reference key="NSSuperview" ref="440594360"/>
<reference key="NSNextKeyView" ref="343242432"/> <reference key="NSNextKeyView" ref="343242432"/>
<int key="NSViewLayerContentsRedrawPolicy">2</int> <int key="NSViewLayerContentsRedrawPolicy">2</int>
<int key="NSsFlags">133810</int> <int key="NSsFlags">133682</int>
<reference key="NSVScroller" ref="573737110"/> <reference key="NSVScroller" ref="573737110"/>
<reference key="NSHScroller" ref="297523533"/> <reference key="NSHScroller" ref="297523533"/>
<reference key="NSContentView" ref="343242432"/> <reference key="NSContentView" ref="343242432"/>
......
...@@ -1172,6 +1172,8 @@ static VLCMainWindow *_o_sharedInstance = nil; ...@@ -1172,6 +1172,8 @@ static VLCMainWindow *_o_sharedInstance = nil;
if (!b_videoPlayback) if (!b_videoPlayback)
[o_fspanel setNonActive: nil]; [o_fspanel setNonActive: nil];
} }
if (b_videoPlayback)
[self makeFirstResponder: o_video_view];
} }
- (void)resizeWindow - (void)resizeWindow
...@@ -1211,9 +1213,9 @@ static VLCMainWindow *_o_sharedInstance = nil; ...@@ -1211,9 +1213,9 @@ static VLCMainWindow *_o_sharedInstance = nil;
// Called automatically if window's acceptsMouseMovedEvents property is true // Called automatically if window's acceptsMouseMovedEvents property is true
- (void)mouseMoved:(NSEvent *)theEvent - (void)mouseMoved:(NSEvent *)theEvent
{ {
if (b_fullscreen) { if (b_fullscreen)
[self recreateHideMouseTimer]; [self recreateHideMouseTimer];
}
[super mouseMoved: theEvent]; [super mouseMoved: theEvent];
} }
......
/***************************************************************************** /*****************************************************************************
* VideoView.h: MacOS X video output module * VideoView.h: MacOS X video output module
***************************************************************************** *****************************************************************************
* Copyright (C) 2002-2011 VLC authors and VideoLAN * Copyright (C) 2002-2012 VLC authors and VideoLAN
* $Id$ * $Id$
* *
* Authors: Derk-Jan Hartman <hartman at videolan dot org> * Authors: Derk-Jan Hartman <hartman at videolan dot org>
...@@ -30,8 +30,5 @@ ...@@ -30,8 +30,5 @@
*****************************************************************************/ *****************************************************************************/
@interface VLCVoutView : NSView @interface VLCVoutView : NSView
{ {
NSView * o_view;
id o_window;
} }
@end @end
/***************************************************************************** /*****************************************************************************
* VideoView.m: MacOS X video output module * VideoView.m: MacOS X video output module
***************************************************************************** *****************************************************************************
* Copyright (C) 2002-2011 VLC authors and VideoLAN * Copyright (C) 2002-2012 VLC authors and VideoLAN
* $Id$ * $Id$
* *
* Authors: Derk-Jan Hartman <hartman at videolan dot org> * Authors: Derk-Jan Hartman <hartman at videolan dot org>
...@@ -41,6 +41,7 @@ ...@@ -41,6 +41,7 @@
#import <vlc_vout_window.h> #import <vlc_vout_window.h>
#import <vlc_vout_display.h> #import <vlc_vout_display.h>
#import <vlc_keys.h> #import <vlc_keys.h>
#import <vlc_mouse.h>
/***************************************************************************** /*****************************************************************************
* DeviceCallback: Callback triggered when the video-device variable is changed * DeviceCallback: Callback triggered when the video-device variable is changed
*****************************************************************************/ *****************************************************************************/
...@@ -60,97 +61,19 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -60,97 +61,19 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
} }
/***************************************************************************** /*****************************************************************************
* VLCVoutView implementation * VLCOpenGLVideoView interface excerpt
* full implementation in modules/video_output/macosx.m:95
*****************************************************************************/ *****************************************************************************/
@implementation VLCVoutView @interface VLCOpenGLVideoView : NSOpenGLView
- (void)setVoutView:(id)theView
{ {
vout_thread_t * p_vout = getVout();
if( !p_vout )
return;
int i_device;
NSArray *o_screens = [NSScreen screens];
if( [o_screens count] <= 0 )
{
msg_Err( VLCIntf, "no OSX screens available" );
return;
}
/* 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_vout->p_libvlc, "video-device" ) == 0 )
{
i_device = var_GetInteger( p_vout, "macosx-vdev" );
}
else
{
i_device = var_GetInteger( p_vout->p_libvlc, "video-device" );
}
/* Setup the menuitem for the multiple displays. */
if( var_Type( p_vout, "video-device" ) == 0 )
{
int i = 1;
vlc_value_t val2, text;
NSScreen * o_screen;
var_Create( p_vout, "video-device", VLC_VAR_INTEGER |
VLC_VAR_HASCHOICE );
text.psz_string = _("Fullscreen Video Device");
var_Change( p_vout, "video-device", VLC_VAR_SETTEXT, &text, NULL );
NSEnumerator * o_enumerator = [o_screens objectEnumerator];
val2.i_int = 0;
text.psz_string = _("Default");
var_Change( p_vout, "video-device", VLC_VAR_ADDCHOICE, &val2, &text );
var_Set( p_vout, "video-device", val2 );
while( (o_screen = [o_enumerator nextObject]) != NULL )
{
char psz_temp[255];
NSRect s_rect = [o_screen frame];
snprintf( psz_temp, sizeof(psz_temp)/sizeof(psz_temp[0])-1, "%s %d (%dx%d)", _("Screen"), i, (int)s_rect.size.width, (int)s_rect.size.height );
text.psz_string = psz_temp;
val2.i_int = (int)[o_screen displayID];
var_Change( p_vout, "video-device", VLC_VAR_ADDCHOICE, &val2, &text );
if( (int)[o_screen displayID] == i_device )
{
var_Set( p_vout, "video-device", val2 );
}
i++;
}
var_AddCallback( p_vout, "video-device", DeviceCallback,
NULL );
val2.b_bool = true;
var_Set( p_vout, "intf-change", val2 );
}
/* Add the view. It's automatically resized to fit the window */
if (o_view) {
[o_view removeFromSuperview];
[o_view release];
}
o_view = theView;
[o_view retain];
[self addSubview: o_view];
[self setAutoresizesSubviews: YES];
/* make sure that we look alright */
[[self window] setAlphaValue: var_CreateGetFloat( p_vout, "macosx-opaqueness" )];
vlc_object_release( p_vout );
}
- (void)resizeSubviewsWithOldSize:(NSSize)oldBoundsSize
{
[super resizeSubviewsWithOldSize: oldBoundsSize];
[o_view setFrameSize: [self frame].size];
} }
- (vout_display_t *)voutDisplay;
@end
/*****************************************************************************
* VLCVoutView implementation
*****************************************************************************/
@implementation VLCVoutView
- (void)closeVout - (void)closeVout
{ {
vout_thread_t * p_vout = getVout(); vout_thread_t * p_vout = getVout();
...@@ -159,11 +82,6 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -159,11 +82,6 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
var_DelCallback( p_vout, "video-device", DeviceCallback, NULL ); var_DelCallback( p_vout, "video-device", DeviceCallback, NULL );
vlc_object_release( p_vout ); vlc_object_release( p_vout );
} }
/* Make sure we don't see a white flash */
[o_view removeFromSuperview];
[o_view release];
o_view = nil;
} }
- (void)scrollWheel:(NSEvent *)theEvent - (void)scrollWheel:(NSEvent *)theEvent
...@@ -234,9 +152,7 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -234,9 +152,7 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
if( [o_event clickCount] <= 1 ) if( [o_event clickCount] <= 1 )
{ {
/* single clicking */ /* single clicking */
var_Get( p_vout, "mouse-button-down", &val ); vout_display_SendEventMousePressed( [[[self subviews] objectAtIndex:0] voutDisplay], MOUSE_BUTTON_LEFT );
val.i_int |= 1;
var_Set( p_vout, "mouse-button-down", val );
} }
else else
{ {
...@@ -266,9 +182,7 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -266,9 +182,7 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
if (p_vout) if (p_vout)
{ {
var_Get( p_vout, "mouse-button-down", &val ); vout_display_SendEventMousePressed( [[[self subviews] objectAtIndex:0] voutDisplay], MOUSE_BUTTON_CENTER );
val.i_int |= 2;
var_Set( p_vout, "mouse-button-down", val );
} }
vlc_object_release( p_vout ); vlc_object_release( p_vout );
} }
...@@ -296,15 +210,7 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -296,15 +210,7 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
vout_thread_t * p_vout = getVout(); vout_thread_t * p_vout = getVout();
if (p_vout) if (p_vout)
{ {
vlc_value_t val; vout_display_SendEventMouseReleased( [[[self subviews] objectAtIndex:0] voutDisplay], MOUSE_BUTTON_LEFT );
int x, y;
var_GetCoords( p_vout, "mouse-moved", &x, &y );
var_SetCoords( p_vout, "mouse-clicked", x, y );
var_Get( p_vout, "mouse-button-down", &val );
val.i_int &= ~1;
var_Set( p_vout, "mouse-button-down", val );
vlc_object_release( p_vout ); vlc_object_release( p_vout );
} }
} }
...@@ -319,10 +225,7 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -319,10 +225,7 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
vout_thread_t * p_vout = getVout(); vout_thread_t * p_vout = getVout();
if (p_vout) if (p_vout)
{ {
vlc_value_t val; vout_display_SendEventMouseReleased( [[[self subviews] objectAtIndex:0] voutDisplay], MOUSE_BUTTON_CENTER );
var_Get( p_vout, "mouse-button-down", &val );
val.i_int &= ~2;
var_Set( p_vout, "mouse-button-down", val );
vlc_object_release( p_vout ); vlc_object_release( p_vout );
} }
} }
...@@ -363,22 +266,22 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -363,22 +266,22 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
- (void)mouseMoved:(NSEvent *)o_event - (void)mouseMoved:(NSEvent *)o_event
{ {
vout_thread_t * p_vout = getVout(); vout_thread_t * p_vout = getVout();
if( p_vout ) if (p_vout)
{ {
NSPoint ml; NSPoint ml;
NSRect s_rect; NSRect s_rect;
BOOL b_inside; BOOL b_inside;
s_rect = [o_view bounds]; s_rect = [self bounds];
ml = [o_view convertPoint: [o_event locationInWindow] fromView: nil]; ml = [self convertPoint: [o_event locationInWindow] fromView: nil];
b_inside = [o_view mouse: ml inRect: s_rect]; b_inside = [self mouse: ml inRect: s_rect];
if( b_inside ) if( b_inside )
{ {
var_SetCoords( p_vout, "mouse-moved", ((int)ml.x), ((int)ml.y) ); vout_display_SendEventMouseMoved( [[[self subviews] objectAtIndex:0] voutDisplay], ((int)ml.x), ((int)s_rect.size.height - ((int)ml.y)) );
} }
vlc_object_release( p_vout );
[[VLCMain sharedInstance] showFullscreenController]; [[VLCMain sharedInstance] showFullscreenController];
vlc_object_release( p_vout );
} }
[super mouseMoved: o_event]; [super mouseMoved: o_event];
...@@ -405,11 +308,4 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable, ...@@ -405,11 +308,4 @@ int DeviceCallback( vlc_object_t *p_this, const char *psz_variable,
events */ events */
return NO; return NO;
} }
- (void)renewGState
{
[[self window] disableScreenUpdatesUntilFlush];
[super renewGState];
}
@end @end
/***************************************************************************** /*****************************************************************************
* voutgl.m: MacOS X OpenGL provider * voutgl.m: MacOS X OpenGL provider
***************************************************************************** *****************************************************************************
* Copyright (C) 2001-2011 the VideoLAN team * Copyright (C) 2001-2012 the VideoLAN team
* $Id$ * $Id$
* *
* Authors: Colin Delacroix <colin@zoy.org> * Authors: Colin Delacroix <colin@zoy.org>
...@@ -98,6 +98,7 @@ vlc_module_end () ...@@ -98,6 +98,7 @@ vlc_module_end ()
BOOL _hasPendingReshape; BOOL _hasPendingReshape;
} }
- (void)setVoutDisplay:(vout_display_t *)vd; - (void)setVoutDisplay:(vout_display_t *)vd;
- (vout_display_t *)voutDisplay;
- (void)setVoutFlushing:(BOOL)flushing; - (void)setVoutFlushing:(BOOL)flushing;
@end @end
...@@ -512,6 +513,10 @@ static void OpenglSwap(vlc_gl_t *gl) ...@@ -512,6 +513,10 @@ static void OpenglSwap(vlc_gl_t *gl)
} }
} }
- (vout_display_t *)voutDisplay
{
return vd;
}
/** /**
* Gets called when the vout will aquire the lock and flush. * Gets called when the vout will aquire the lock and flush.
......
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