瀏覽代碼

linux-capture: Add X border option to xcomposite

XComposite, which is currently our only capture method for windows,
doesn't handle X border width. This works in a lot of cases but anytime
there's a border, a bug occurs where the lower right is clipped.  This
patch has two goals:

1) To position and size the capture texture correctly in accordance to
the border.

2) Adds a configuration option to allow people to toggle it (which in
most cases will simply do nothing) with a default of not including it.
Zachary Lund 11 年之前
父節點
當前提交
ab7fa5bdb4
共有 2 個文件被更改,包括 32 次插入4 次删除
  1. 1 0
      plugins/linux-capture/data/locale/en-US.ini
  2. 31 4
      plugins/linux-capture/xcompcap-main.cpp

+ 1 - 0
plugins/linux-capture/data/locale/en-US.ini

@@ -9,3 +9,4 @@ CropRight="Crop Right (pixels)"
 CropBottom="Crop Bottom (pixels)"
 CropBottom="Crop Bottom (pixels)"
 SwapRedBlue="Swap red and blue"
 SwapRedBlue="Swap red and blue"
 LockX="Lock X server when capturing"
 LockX="Lock X server when capturing"
+IncludeXBorder="Include X Border"

+ 31 - 4
plugins/linux-capture/xcompcap-main.cpp

@@ -83,6 +83,9 @@ obs_properties_t *XCompcapMain::properties()
 	obs_properties_add_bool(props, "show_cursor",
 	obs_properties_add_bool(props, "show_cursor",
 			obs_module_text("CaptureCursor"));
 			obs_module_text("CaptureCursor"));
 
 
+	obs_properties_add_bool(props, "include_border",
+			obs_module_text("IncludeXBorder"));
+
 	return props;
 	return props;
 }
 }
 
 
@@ -96,6 +99,7 @@ void XCompcapMain::defaults(obs_data_t *settings)
 	obs_data_set_default_bool(settings, "swap_redblue", false);
 	obs_data_set_default_bool(settings, "swap_redblue", false);
 	obs_data_set_default_bool(settings, "lock_x", false);
 	obs_data_set_default_bool(settings, "lock_x", false);
 	obs_data_set_default_bool(settings, "show_cursor", true);
 	obs_data_set_default_bool(settings, "show_cursor", true);
+	obs_data_set_default_bool(settings, "include_border", false);
 }
 }
 
 
 
 
@@ -136,9 +140,11 @@ struct XCompcapMain_private
 	bool inverted;
 	bool inverted;
 	bool swapRedBlue;
 	bool swapRedBlue;
 	bool lockX;
 	bool lockX;
+	bool include_border;
 
 
 	uint32_t width;
 	uint32_t width;
 	uint32_t height;
 	uint32_t height;
+	uint32_t border;
 
 
 	Pixmap pixmap;
 	Pixmap pixmap;
 	GLXPixmap glxpixmap;
 	GLXPixmap glxpixmap;
@@ -275,6 +281,7 @@ void XCompcapMain::updateSettings(obs_data_t *settings)
 		p->lockX = obs_data_get_bool(settings, "lock_x");
 		p->lockX = obs_data_get_bool(settings, "lock_x");
 		p->swapRedBlue = obs_data_get_bool(settings, "swap_redblue");
 		p->swapRedBlue = obs_data_get_bool(settings, "swap_redblue");
 		p->show_cursor = obs_data_get_bool(settings, "show_cursor");
 		p->show_cursor = obs_data_get_bool(settings, "show_cursor");
+		p->include_border = obs_data_get_bool(settings, "include_border");
 	} else {
 	} else {
 		p->win = prevWin;
 		p->win = prevWin;
 	}
 	}
@@ -311,8 +318,15 @@ void XCompcapMain::updateSettings(obs_data_t *settings)
 
 
 	gs_color_format cf = GS_RGBA;
 	gs_color_format cf = GS_RGBA;
 
 
-	p->width = attr.width;
-	p->height = attr.height;
+	p->border = attr.border_width;
+
+	if (p->include_border) {
+		p->width = attr.width + p->border * 2;
+		p->height = attr.height + p->border * 2;
+	} else {
+		p->width = attr.width;
+		p->height = attr.height;
+	}
 
 
 	if (p->cut_top + p->cut_bot < (int)p->height) {
 	if (p->cut_top + p->cut_bot < (int)p->height) {
 		p->cur_cut_top = p->cut_top;
 		p->cur_cut_top = p->cut_top;
@@ -449,8 +463,21 @@ void XCompcapMain::tick(float seconds)
 		XSync(xdisp, 0);
 		XSync(xdisp, 0);
 	}
 	}
 
 
-	gs_copy_texture_region(p->tex, 0, 0, p->gltex, p->cur_cut_left,
-			p->cur_cut_top, width(), height());
+	if (p->include_border) {
+		gs_copy_texture_region(
+				p->tex, 0, 0,
+				p->gltex,
+				p->cur_cut_left,
+				p->cur_cut_top,
+				width(), height());
+	} else {
+		gs_copy_texture_region(
+				p->tex, 0, 0,
+				p->gltex,
+				p->cur_cut_left + p->border,
+				p->cur_cut_top + p->border,
+				width(), height());
+	}
 
 
 	if (p->cursor && p->show_cursor) {
 	if (p->cursor && p->show_cursor) {
 		xcursor_tick(p->cursor);
 		xcursor_tick(p->cursor);