# HG changeset patch # User iive # Date 1113148948 0 # Node ID 66956f84246177cad9734d55478a1121cf1821d7 # Parent bfb91d085f22f2098fc38e3c71e664c04ef9a8e8 fix vo_xv_draw_colorkey to a workable state (using panscan makes x,y negative, so it is very bad idea they to be unsigned) diff -r bfb91d085f22 -r 66956f842461 libvo/x11_common.c --- a/libvo/x11_common.c Sun Apr 10 15:37:43 2005 +0000 +++ b/libvo/x11_common.c Sun Apr 10 16:02:28 2005 +0000 @@ -2444,12 +2444,14 @@ * It also draws the black bars ( when the video doesn't fit to the * display in full screen ) seperately, so they don't overlap with the * video area. + * It doesn't call XFlush * */ -inline void vo_xv_draw_colorkey( uint32_t x, uint32_t y, - uint32_t w, uint32_t h ) +inline void vo_xv_draw_colorkey( int32_t x, int32_t y, + int32_t w, int32_t h ) { - if( xv_ck_info.method == CK_METHOD_MANUALFILL ) + if( xv_ck_info.method == CK_METHOD_MANUALFILL || + xv_ck_info.method == CK_METHOD_BACKGROUND )//less tearing than XClearWindow() { XSetForeground( mDisplay, vo_gc, xv_colorkey ); XFillRectangle( mDisplay, vo_window, vo_gc, @@ -2458,28 +2460,28 @@ } /* draw black bars if needed */ + /* TODO! move this to vo_x11_clearwindow_part() */ if ( vo_fs ) { XSetForeground( mDisplay, vo_gc, 0 ); + /* making non overlap fills, requiare 8 checks instead of 4*/ if ( y > 0 ) XFillRectangle( mDisplay, vo_window, vo_gc, 0, 0, vo_screenwidth, y); if (x > 0) XFillRectangle( mDisplay, vo_window, vo_gc, - 0, y, - x, h ); + 0, 0, + x, vo_screenheight); if (x + w < vo_screenwidth) XFillRectangle( mDisplay, vo_window, vo_gc, - x + w, y, - vo_screenwidth - (x + w), h ); + x + w, 0, + vo_screenwidth, vo_screenheight); if (y + h < vo_screenheight) XFillRectangle( mDisplay, vo_window, vo_gc, 0, y + h, - vo_screenwidth, vo_screenheight - (y + h) ); + vo_screenwidth, vo_screenheight); } - - XFlush( mDisplay ); } /** \brief tests if a valid arg for the ck suboption was given */ diff -r bfb91d085f22 -r 66956f842461 libvo/x11_common.h --- a/libvo/x11_common.h Sun Apr 10 15:37:43 2005 +0000 +++ b/libvo/x11_common.h Sun Apr 10 16:02:28 2005 +0000 @@ -104,8 +104,7 @@ extern unsigned long xv_colorkey; extern int vo_xv_init_colorkey(); -extern void vo_xv_colorkey(uint32_t x,uint32_t y, uint32_t w, uint32_t h); -extern void vo_xv_draw_colorkey(uint32_t x, uint32_t y, uint32_t w, uint32_t h); +extern void vo_xv_draw_colorkey(int32_t x, int32_t y, int32_t w, int32_t h); extern void xv_setup_colorkeyhandling(char const * ck_method_str, char const * ck_str); /*** test functions for common suboptions ***/