|  | @@ -357,7 +357,9 @@ void XCompcapMain::updateSettings(obs_data_t *settings)
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	if (cf == GS_BGRX) {
 |  |  	if (cf == GS_BGRX) {
 | 
											
												
													
														|  | -		p->swapRedBlue = !p->swapRedBlue;
 |  | 
 | 
											
												
													
														|  | 
 |  | +		if (settings) {
 | 
											
												
													
														|  | 
 |  | +			p->swapRedBlue = !p->swapRedBlue;
 | 
											
												
													
														|  | 
 |  | +		}
 | 
											
												
													
														|  |  		p->draw_opaque = true;
 |  |  		p->draw_opaque = true;
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -444,13 +446,14 @@ void XCompcapMain::updateSettings(obs_data_t *settings)
 | 
											
												
													
														|  |  	GLXFBConfig config;
 |  |  	GLXFBConfig config;
 | 
											
												
													
														|  |  	bool found = false;
 |  |  	bool found = false;
 | 
											
												
													
														|  |  	for (int i = 0; i < nelem; i++) {
 |  |  	for (int i = 0; i < nelem; i++) {
 | 
											
												
													
														|  | -		int visual;
 |  | 
 | 
											
												
													
														|  |  		config = configs[i];
 |  |  		config = configs[i];
 | 
											
												
													
														|  | -		glXGetFBConfigAttrib(xdisp, config, GLX_VISUAL_ID, &visual);
 |  | 
 | 
											
												
													
														|  | -		if ((int)attr.visual->visualid == visual) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +		XVisualInfo *visual = glXGetVisualFromFBConfig(xdisp, config);
 | 
											
												
													
														|  | 
 |  | +		if (attr.visual->visualid == visual->visualid) {
 | 
											
												
													
														|  |  			found = true;
 |  |  			found = true;
 | 
											
												
													
														|  | 
 |  | +			XFree(visual);
 | 
											
												
													
														|  |  			break;
 |  |  			break;
 | 
											
												
													
														|  |  		}
 |  |  		}
 | 
											
												
													
														|  | 
 |  | +		XFree(visual);
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	if (!found) {
 |  |  	if (!found) {
 | 
											
										
											
												
													
														|  | @@ -488,7 +491,7 @@ void XCompcapMain::updateSettings(obs_data_t *settings)
 | 
											
												
													
														|  |  		None
 |  |  		None
 | 
											
												
													
														|  |  	};
 |  |  	};
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -	const int *attribs = has_alpha ? attribs_alpha : attribs_no_alpha;
 |  | 
 | 
											
												
													
														|  | 
 |  | +	const int *attribs = cf == GS_RGBA ? attribs_alpha : attribs_no_alpha;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	p->glxpixmap = glXCreatePixmap(xdisp, config, p->pixmap, attribs);
 |  |  	p->glxpixmap = glXCreatePixmap(xdisp, config, p->pixmap, attribs);
 | 
											
												
													
														|  |  
 |  |  
 |