# HG changeset patch # User iive # Date 1107352946 0 # Node ID 1c277cafd3b1b1295cf419c7265efe36d22d3665 # Parent d92dab9e76b6ff9fb74bec820ce077461ed154f4 Query XV_COLORKEY only when listed in attribute list, fixes displaying with non overlay ports diff -r d92dab9e76b6 -r 1c277cafd3b1 libvo/vo_xvmc.c --- a/libvo/vo_xvmc.c Wed Feb 02 11:32:34 2005 +0000 +++ b/libvo/vo_xvmc.c Wed Feb 02 14:02:26 2005 +0000 @@ -209,31 +209,23 @@ attributes = XvQueryPortAttributes(mDisplay, xv_port, &attrib_count); if(attributes!=NULL){ for (i = 0; i < attrib_count; i++){ - if (!strcmp(attributes[i].name, "XV_AUTOPAINT_COLORKEY")) + if (!strcmp(attributes[i].name, "XV_COLORKEY")) { - xv_atom = XInternAtom(mDisplay, "XV_AUTOPAINT_COLORKEY", False); + xv_atom = XInternAtom(mDisplay, "XV_COLORKEY", False); if(xv_atom!=None) { - rez=XvSetPortAttribute(mDisplay, xv_port, xv_atom, 1); - if(rez == Success) - keycolor_handling = AUTOPAINT_COLORKEY; + rez=XvGetPortAttribute(mDisplay,xv_port, xv_atom, &colorkey); + if(rez == Success){ + keycolor = colorkey; + keycolor_handling = MANUALFILL_COLORKEY; + } } break; } - } + } XFree(attributes); } } - - xv_atom = XInternAtom(mDisplay, "XV_COLORKEY",False); - if(xv_atom == None) return; - rez=XvGetPortAttribute(mDisplay,xv_port, xv_atom, &colorkey); - if(rez == Success){ - keycolor = colorkey; - if(keycolor_handling == AUTO_COLORKEY){ - keycolor_handling = MANUALFILL_COLORKEY; - } - } } //from vo_xmga @@ -439,7 +431,7 @@ surface_render = NULL; xv_port = 0; number_of_surfaces = 0; - keycolor_handling = MANUALFILL_COLORKEY;//fixme + keycolor_handling = AUTO_COLORKEY; subpicture_alloc = 0; benchmark = 0; //disable PutImageto allow faster display than screen refresh