[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH 3/3] vnc: h264: send additional frames after the display is clean
From: |
Dietmar Maurer |
Subject: |
[PATCH 3/3] vnc: h264: send additional frames after the display is clean |
Date: |
Mon, 7 Apr 2025 12:59:39 +0200 |
So that encoder can improve the picture quality.
Signed-off-by: Dietmar Maurer <dietmar@proxmox.com>
---
ui/vnc.c | 25 ++++++++++++++++++++++++-
ui/vnc.h | 3 +++
2 files changed, 27 insertions(+), 1 deletion(-)
diff --git a/ui/vnc.c b/ui/vnc.c
index 2e60b55e47..4ba0b715fd 100644
--- a/ui/vnc.c
+++ b/ui/vnc.c
@@ -3239,7 +3239,30 @@ static void vnc_refresh(DisplayChangeListener *dcl)
vnc_unlock_display(vd);
QTAILQ_FOREACH_SAFE(vs, &vd->clients, next, vn) {
- rects += vnc_update_client(vs, has_dirty);
+ int client_dirty = has_dirty;
+ if (vs->h264) {
+ if (client_dirty) {
+ vs->h264->keep_dirty = VNC_H264_KEEP_DIRTY;
+ } else {
+ if (vs->h264->keep_dirty > 0) {
+ client_dirty = 1;
+ vs->h264->keep_dirty--;
+ }
+ }
+ }
+
+ int count = vnc_update_client(vs, client_dirty);
+ rects += count;
+
+ if (vs->h264 && !count && vs->h264->keep_dirty) {
+ VncJob *job = vnc_job_new(vs);
+ int height = pixman_image_get_height(vd->server);
+ int width = pixman_image_get_width(vd->server);
+ vs->job_update = vs->update;
+ vs->update = VNC_STATE_UPDATE_NONE;
+ vnc_job_add_rect(job, 0, 0, width, height);
+ vnc_job_push(job);
+ }
/* vs might be free()ed here */
}
diff --git a/ui/vnc.h b/ui/vnc.h
index 7e232f7dac..e1b81d6bcc 100644
--- a/ui/vnc.h
+++ b/ui/vnc.h
@@ -236,10 +236,13 @@ typedef struct VncZywrle {
} VncZywrle;
#ifdef CONFIG_GSTREAMER
+/* Number of frames we send after the display is clean. */
+#define VNC_H264_KEEP_DIRTY 10
typedef struct VncH264 {
GstElement *pipeline, *source, *gst_encoder, *sink, *convert;
size_t width;
size_t height;
+ guint keep_dirty;
} VncH264;
#endif
--
2.39.5