aboutsummaryrefslogtreecommitdiffhomepage
path: root/libvo
diff options
context:
space:
mode:
authorGravatar nplourde <nplourde@b3059339-0415-0410-9bf9-f77b7e298cf2>2005-05-02 18:05:59 +0000
committerGravatar nplourde <nplourde@b3059339-0415-0410-9bf9-f77b7e298cf2>2005-05-02 18:05:59 +0000
commitb7aed4714e298cd4c39248055eda54db2ce562ae (patch)
tree1b4c3d6e0c6a47d858660265ba1317e834b5cc83 /libvo
parent97378713fd110322919ab41d761770a7a440a44d (diff)
enable rootwin
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@15328 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'libvo')
-rw-r--r--libvo/vo_macosx.h2
-rw-r--r--libvo/vo_macosx.m40
2 files changed, 35 insertions, 7 deletions
diff --git a/libvo/vo_macosx.h b/libvo/vo_macosx.h
index bcb0b27d06..07983b6369 100644
--- a/libvo/vo_macosx.h
+++ b/libvo/vo_macosx.h
@@ -10,6 +10,7 @@
#import <Cocoa/Cocoa.h>
#import <QuartzCore/QuartzCore.h>
+#import <QuickTime/QuickTime.h>
@interface CustomOpenGLView : NSOpenGLView
{
@@ -45,6 +46,7 @@
- (void) fullscreen: (BOOL) animate;
- (void) ontop;
- (void) panscan;
+- (void) rootwin;
//event
- (void) keyDown: (NSEvent *) theEvent;
diff --git a/libvo/vo_macosx.m b/libvo/vo_macosx.m
index 3a9e746ab8..c3d9db97f4 100644
--- a/libvo/vo_macosx.m
+++ b/libvo/vo_macosx.m
@@ -50,6 +50,7 @@ extern int vo_ontop;
extern int vo_fs;
static int isFullscreen;
static int isOntop;
+static int isRootwin;
extern float monitor_aspect;
extern int vo_keepaspect;
extern float movie_aspect;
@@ -141,6 +142,9 @@ static uint32_t config(uint32_t width, uint32_t height, uint32_t d_width, uint32
vo_fs = flags & VOFLAG_FULLSCREEN;
+ if(vo_rootwin)
+ [glView rootwin];
+
if(vo_fs)
[glView fullscreen: NO];
@@ -280,6 +284,7 @@ static uint32_t control(uint32_t request, void *data, ...)
case VOCTRL_RESUME: return (int_pause=0);
case VOCTRL_QUERY_FORMAT: return query_format(*((uint32_t*)data));
case VOCTRL_ONTOP: vo_ontop = (!(vo_ontop)); [glView ontop]; return VO_TRUE;
+ case VOCTRL_ROOTWIN: vo_rootwin = (!(vo_rootwin)); [glView rootwin]; return VO_TRUE;
case VOCTRL_FULLSCREEN: vo_fs = (!(vo_fs)); [glView fullscreen: YES]; return VO_TRUE;
case VOCTRL_GET_PANSCAN: return VO_TRUE;
case VOCTRL_SET_PANSCAN: [glView panscan]; return VO_TRUE;
@@ -312,7 +317,7 @@ static uint32_t control(uint32_t request, void *data, ...)
[window setAcceptsMouseMovedEvents:YES];
[window setTitle:@"MPlayer - The Movie Player"];
[window center];
- [window makeKeyAndOrderFront:nil];
+ [window makeKeyAndOrderFront:self];
[self setOpenGLContext:glContext];
[glContext setView:self];
@@ -424,7 +429,7 @@ static uint32_t control(uint32_t request, void *data, ...)
glFlush();
//auto hide mouse cursor and futur on-screen control?
- if(isFullscreen && !mouseHide)
+ if(isFullscreen && !mouseHide && !isRootwin)
{
DateTimeRec d;
unsigned long curTime;
@@ -477,10 +482,13 @@ static uint32_t control(uint32_t request, void *data, ...)
//go fullscreen
if(vo_fs)
{
- //hide menubar and mouse if fullscreen on main display
- HideMenuBar();
- HideCursor();
- mouseHide = YES;
+ if(!isRootwin)
+ {
+ //hide menubar and mouse if fullscreen on main display
+ HideMenuBar();
+ HideCursor();
+ mouseHide = YES;
+ }
panscan_calc();
old_frame = [window frame]; //save main window size & position
@@ -535,6 +543,24 @@ static uint32_t control(uint32_t request, void *data, ...)
}
/*
+ Toggle rootwin
+ */
+- (void) rootwin
+{
+ if(vo_rootwin)
+ {
+ [window setLevel:CGWindowLevelForKey(kCGDesktopWindowLevelKey)];
+ [window orderBack:self];
+ isRootwin = YES;
+ }
+ else
+ {
+ [window setLevel:NSNormalWindowLevel];
+ isRootwin = NO;
+ }
+}
+
+/*
Check event for new event
*/
- (void) check_events
@@ -608,7 +634,7 @@ static uint32_t control(uint32_t request, void *data, ...)
*/
- (void) mouseMoved: (NSEvent *) theEvent
{
- if(isFullscreen)
+ if(isFullscreen && !isRootwin)
{
ShowMenuBar();
ShowCursor();