|
@@ -1,5 +1,4 @@
|
|
|
#include <util/dstr.h>
|
|
|
-#include <util/platform.h>
|
|
|
#include "dc-capture.h"
|
|
|
|
|
|
/* clang-format off */
|
|
@@ -177,7 +176,7 @@ static BOOL CALLBACK enum_monitor_props(HMONITOR handle, HDC hdc, LPRECT rect,
|
|
|
UNUSED_PARAMETER(rect);
|
|
|
|
|
|
obs_property_t *monitor_list = (obs_property_t *)param;
|
|
|
- MONITORINFOEX mi;
|
|
|
+ MONITORINFO mi;
|
|
|
size_t monitor_id = 0;
|
|
|
struct dstr monitor_desc = {0};
|
|
|
struct dstr resolution = {0};
|
|
@@ -188,40 +187,18 @@ static BOOL CALLBACK enum_monitor_props(HMONITOR handle, HDC hdc, LPRECT rect,
|
|
|
mi.cbSize = sizeof(mi);
|
|
|
GetMonitorInfo(handle, &mi);
|
|
|
|
|
|
- DISPLAY_DEVICE ddev;
|
|
|
- ddev.cb = sizeof(ddev);
|
|
|
- EnumDisplayDevices(mi.szDevice, 0, &ddev, 1);
|
|
|
-
|
|
|
- char *devname = NULL;
|
|
|
-#ifdef UNICODE
|
|
|
- os_wcs_to_utf8_ptr(ddev.DeviceString, 128, &devname);
|
|
|
-#else
|
|
|
- devname = (char *)bstrdup(ddev.DeviceString);
|
|
|
-#endif
|
|
|
-
|
|
|
dstr_catf(&resolution, "%dx%d @ %d,%d",
|
|
|
mi.rcMonitor.right - mi.rcMonitor.left,
|
|
|
mi.rcMonitor.bottom - mi.rcMonitor.top, mi.rcMonitor.left,
|
|
|
mi.rcMonitor.top);
|
|
|
|
|
|
- dstr_copy(&format_string, "%s: %s");
|
|
|
+ dstr_copy(&format_string, "%s %d: %s");
|
|
|
if (mi.dwFlags == MONITORINFOF_PRIMARY) {
|
|
|
dstr_catf(&format_string, " (%s)", TEXT_PRIMARY_MONITOR);
|
|
|
}
|
|
|
|
|
|
- struct dstr m = {0};
|
|
|
- dstr_copy(&m, devname);
|
|
|
- dstr_replace(&m, "(", " (");
|
|
|
- if (dstr_is_empty(&m)) {
|
|
|
- struct dstr d = {0};
|
|
|
- dstr_catf(&d, "%s %d", TEXT_MONITOR, monitor_id + 1);
|
|
|
- dstr_free(&m);
|
|
|
- dstr_copy_dstr(&m, &d);
|
|
|
- dstr_free(&d);
|
|
|
- }
|
|
|
-
|
|
|
- dstr_catf(&monitor_desc, format_string.array, m.array,
|
|
|
- resolution.array);
|
|
|
+ dstr_catf(&monitor_desc, format_string.array, TEXT_MONITOR,
|
|
|
+ monitor_id + 1, resolution.array);
|
|
|
|
|
|
obs_property_list_add_int(monitor_list, monitor_desc.array,
|
|
|
(int)monitor_id);
|
|
@@ -229,8 +206,6 @@ static BOOL CALLBACK enum_monitor_props(HMONITOR handle, HDC hdc, LPRECT rect,
|
|
|
dstr_free(&monitor_desc);
|
|
|
dstr_free(&resolution);
|
|
|
dstr_free(&format_string);
|
|
|
- dstr_free(&m);
|
|
|
- bfree(devname);
|
|
|
|
|
|
return TRUE;
|
|
|
}
|