changeset 10497:9e6becbd5c8a

draw rectangle with color key, avoid blue bars. avoid PutSurface before 1'st image
author iive
date Mon, 28 Jul 2003 20:04:09 +0000
parents 5fd0864becc3
children 17391ba6c53b
files libvo/vo_xvmc.c
diffstat 1 files changed, 5 insertions(+), 7 deletions(-) [+]
line wrap: on
line diff
--- a/libvo/vo_xvmc.c	Mon Jul 28 15:24:38 2003 +0000
+++ b/libvo/vo_xvmc.c	Mon Jul 28 20:04:09 2003 +0000
@@ -255,7 +255,7 @@
    }
    xv_port = 0;
    number_of_surfaces = 0;
-   keycolor_handling = 1;//!!fixme
+   keycolor_handling = 3;//!!fixme
    surface_render=NULL;
    
    return 0;
@@ -458,7 +458,7 @@
          vo_x11_classhint( mDisplay,vo_window,"xvmc" );
          vo_hidecursor(mDisplay,vo_window);
 
-         vo_x11_selectinput_witherr(mDisplay, vo_window, StructureNotifyMask | KeyPressMask | PropertyChangeMask |
+         vo_x11_selectinput_witherr(mDisplay, vo_window, StructureNotifyMask | KeyPressMask | PropertyChangeMask | ExposureMask |
 	      ((WinID==0) ? 0 : (PointerMotionMask
 		| ButtonPressMask | ButtonReleaseMask)) );
          XSetStandardProperties(mDisplay, vo_window, hello, hello, None, NULL, 0, &hint);
@@ -594,11 +594,8 @@
 int e=vo_x11_check_events(mDisplay);
    if(e&VO_EVENT_RESIZE)
    {
-      if (vo_fs) {
-        e |= VO_EVENT_EXPOSE;
-        XClearWindow(mDisplay, vo_window);
-        XFlush(mDisplay);
-      }
+      e |= VO_EVENT_EXPOSE;
+      
       XGetGeometry( mDisplay,vo_window,&mRoot,&drwX,&drwY,&vo_dwidth,&vo_dheight,
                    &drwBorderWidth,&drwDepth );
       drwX = drwY = 0;
@@ -619,6 +616,7 @@
    if ( e & VO_EVENT_EXPOSE )
    {
       mDrawColorKey(drwX,drwY,vo_dwidth,vo_dheight);     
+     if(p_render_surface_visible != NULL)
       XvMCPutSurface(mDisplay, p_render_surface_visible->p_surface,vo_window,
                      0, 0, image_width, image_height,
                      drwX,drwY,vo_dwidth,vo_dheight,