From 1bb2665e3d099a792cf9c4e5b119a6b4352d9b2f Mon Sep 17 00:00:00 2001 From: "Avi Halachmi (:avih)" Date: Wed, 25 Nov 2020 19:33:35 +0200 Subject: vo_sixel: support --vo-sixel-exit-clear[=yes] By default we still clear the screen, but now it's possible to leave the last sixel image on screen. Allows mpv to be used as img2sixel of sorts, but with our auto-fit and various mpv scaling/filters etc. --- video/out/vo_sixel.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) (limited to 'video/out') diff --git a/video/out/vo_sixel.c b/video/out/vo_sixel.c index 8318c5190c..a1fb04bd59 100644 --- a/video/out/vo_sixel.c +++ b/video/out/vo_sixel.c @@ -63,6 +63,7 @@ struct priv { int opt_pad_x; int opt_rows; int opt_cols; + int opt_clear; // Internal data sixel_output_t *output; @@ -442,8 +443,10 @@ static void uninit(struct vo *vo) printf(ESC_RESTORE_CURSOR); - printf(ESC_CLEAR_SCREEN); - printf(ESC_GOTOXY, 1, 1); + if (priv->opt_clear) { + printf(ESC_CLEAR_SCREEN); + printf(ESC_GOTOXY, 1, 1); + } fflush(stdout); if (priv->output) { @@ -480,6 +483,7 @@ const struct vo_driver video_out_sixel = { .opt_pad_x = -1, .opt_rows = 0, .opt_cols = 0, + .opt_clear = 1, }, .options = (const m_option_t[]) { {"dither", OPT_CHOICE(opt_diffuse, @@ -503,6 +507,7 @@ const struct vo_driver video_out_sixel = { {"pad-x", OPT_INT(opt_pad_x)}, {"rows", OPT_INT(opt_rows)}, {"cols", OPT_INT(opt_cols)}, + {"exit-clear", OPT_FLAG(opt_clear), }, {0} }, .options_prefix = "vo-sixel", -- cgit v1.2.3