mirror of
https://repo.dec05eba.com/gpu-screen-recorder
synced 2026-03-31 09:07:13 +09:00
Error if -fm content is used on wayland or not window capture
This commit is contained in:
11
src/main.cpp
11
src/main.cpp
@@ -1951,11 +1951,11 @@ int main(int argc, char **argv) {
|
|||||||
if(fps < 1)
|
if(fps < 1)
|
||||||
fps = 1;
|
fps = 1;
|
||||||
|
|
||||||
|
VideoQuality quality = VideoQuality::VERY_HIGH;
|
||||||
const char *quality_str = args["-q"].value();
|
const char *quality_str = args["-q"].value();
|
||||||
if(!quality_str)
|
if(!quality_str)
|
||||||
quality_str = "very_high";
|
quality_str = "very_high";
|
||||||
|
|
||||||
VideoQuality quality;
|
|
||||||
if(strcmp(quality_str, "medium") == 0) {
|
if(strcmp(quality_str, "medium") == 0) {
|
||||||
quality = VideoQuality::MEDIUM;
|
quality = VideoQuality::MEDIUM;
|
||||||
} else if(strcmp(quality_str, "high") == 0) {
|
} else if(strcmp(quality_str, "high") == 0) {
|
||||||
@@ -2034,7 +2034,7 @@ int main(int argc, char **argv) {
|
|||||||
// TODO: Fix constant framerate not working properly on amd/intel because capture framerate gets locked to the same framerate as
|
// TODO: Fix constant framerate not working properly on amd/intel because capture framerate gets locked to the same framerate as
|
||||||
// game framerate, which doesn't work well when you need to encode multiple duplicate frames (AMD/Intel is slow at encoding!).
|
// game framerate, which doesn't work well when you need to encode multiple duplicate frames (AMD/Intel is slow at encoding!).
|
||||||
// It also appears to skip audio frames on nvidia wayland? why? that should be fine, but it causes video stuttering because of audio/video sync.
|
// It also appears to skip audio frames on nvidia wayland? why? that should be fine, but it causes video stuttering because of audio/video sync.
|
||||||
FramerateMode framerate_mode;
|
FramerateMode framerate_mode = FramerateMode::VARIABLE;
|
||||||
const char *framerate_mode_str = args["-fm"].value();
|
const char *framerate_mode_str = args["-fm"].value();
|
||||||
if(!framerate_mode_str)
|
if(!framerate_mode_str)
|
||||||
framerate_mode_str = "vfr";
|
framerate_mode_str = "vfr";
|
||||||
@@ -2050,7 +2050,12 @@ int main(int argc, char **argv) {
|
|||||||
usage();
|
usage();
|
||||||
}
|
}
|
||||||
|
|
||||||
gsr_color_range color_range;
|
if(framerate_mode == FramerateMode::CONTENT && (wayland || is_monitor_capture)) {
|
||||||
|
fprintf(stderr, "Error: -fm 'content' is currently only supported on X11 and when capturing a single window.\n");
|
||||||
|
usage();
|
||||||
|
}
|
||||||
|
|
||||||
|
gsr_color_range color_range = GSR_COLOR_RANGE_LIMITED;
|
||||||
const char *color_range_str = args["-cr"].value();
|
const char *color_range_str = args["-cr"].value();
|
||||||
if(!color_range_str)
|
if(!color_range_str)
|
||||||
color_range_str = "limited";
|
color_range_str = "limited";
|
||||||
|
|||||||
Reference in New Issue
Block a user