From 448a7cb57d2138083bc34843690cd2a738608975 Mon Sep 17 00:00:00 2001 From: Sebastian Ramacher Date: Mon, 10 Sep 2018 23:06:57 +0200 Subject: [PATCH] Add option to request "plain" rendering of a page "Plain" in this context means without any recoloring or rescaling. --- zathura/render.c | 51 +++++++++++++++++++++++++++++++++++++----------- zathura/render.h | 18 +++++++++++++++-- 2 files changed, 56 insertions(+), 13 deletions(-) diff --git a/zathura/render.c b/zathura/render.c index ad03ef1..f33a564 100644 --- a/zathura/render.c +++ b/zathura/render.c @@ -51,6 +51,7 @@ typedef struct request_private_s { gint64 last_view_time; girara_list_t* active_jobs; GMutex jobs_mutex; + bool render_plain; } ZathuraRenderRequestPrivate; /* define the two types */ @@ -252,6 +253,7 @@ zathura_render_request_new(ZathuraRenderer* renderer, zathura_page_t* page) priv->page = page; priv->active_jobs = girara_list_new(); g_mutex_init(&priv->jobs_mutex); + priv->render_plain = false; /* register the request with the renderer */ renderer_register_request(renderer, request); @@ -759,16 +761,22 @@ render(render_job_t* job, ZathuraRenderRequest* request, ZathuraRenderer* render const double height = zathura_page_get_height(page); const double width = zathura_page_get_width(page); - /* page size in user pixels based on document zoom: if PPI information is - * correct, 100% zoom will result in 72 documents points per inch of screen - * (i.e. document size on screen matching the physical paper size). */ - const double real_scale = page_calc_height_width(document, height, width, - &page_height, &page_width, - false); + zathura_device_factors_t device_factors = { 0 }; + double real_scale = 1; + if (request_priv->render_plain == false) { + /* page size in user pixels based on document zoom: if PPI information is + * correct, 100% zoom will result in 72 documents points per inch of screen + * (i.e. document size on screen matching the physical paper size). */ + real_scale = page_calc_height_width(document, height, width, + &page_height, &page_width, false); - const zathura_device_factors_t device_factors = zathura_document_get_device_factors(document); - page_width *= device_factors.x; - page_height *= device_factors.y; + device_factors = zathura_document_get_device_factors(document); + page_width *= device_factors.x; + page_height *= device_factors.y; + } else { + page_width = width; + page_height = height; + } cairo_surface_t* surface = cairo_image_surface_create(CAIRO_FORMAT_RGB24, page_width, page_height); @@ -776,7 +784,9 @@ render(render_job_t* job, ZathuraRenderRequest* request, ZathuraRenderer* render return false; } - cairo_surface_set_device_scale(surface, device_factors.x, device_factors.y); + if (request_priv->render_plain == false) { + cairo_surface_set_device_scale(surface, device_factors.x, device_factors.y); + } if (cairo_surface_status(surface) != CAIRO_STATUS_SUCCESS) { cairo_surface_destroy(surface); @@ -799,7 +809,7 @@ render(render_job_t* job, ZathuraRenderRequest* request, ZathuraRenderer* render } /* recolor */ - if (priv->recolor.enabled == true) { + if (request_priv->render_plain == false && priv->recolor.enabled == true) { recolor(priv, page, page_width, page_height, surface); } @@ -1013,3 +1023,22 @@ zathura_renderer_page_cache_add(ZathuraRenderer* renderer, g_return_if_fail(request != NULL); g_signal_emit(request, request_signals[REQUEST_CACHE_ADDED], 0); } + +void zathura_render_request_set_render_plain(ZathuraRenderRequest* request, + bool render_plain) +{ + g_return_if_fail(ZATHURA_IS_RENDER_REQUEST(request)); + + ZathuraRenderRequestPrivate* priv = zathura_render_request_get_instance_private(request); + priv->render_plain =render_plain; +} + +bool +zathura_render_request_get_render_plain(ZathuraRenderRequest* request) +{ + g_return_val_if_fail(ZATHURA_IS_RENDER_REQUEST(request), false); + + ZathuraRenderRequestPrivate* priv = zathura_render_request_get_instance_private(request); + return priv->render_plain; +} + diff --git a/zathura/render.h b/zathura/render.h index 930b1ed..7b878c1 100644 --- a/zathura/render.h +++ b/zathura/render.h @@ -182,8 +182,7 @@ ZathuraRenderRequest* zathura_render_request_new(ZathuraRenderer* renderer, zathura_page_t* page); /** - * This function is used to add a page to the render thread list - * that should be rendered. + * Add a page to the render thread list that should be rendered. * * @param request request object of the page that should be renderer * @param last_view_time last view time of the page @@ -206,6 +205,21 @@ void zathura_render_request_abort(ZathuraRenderRequest* request); */ void zathura_render_request_update_view_time(ZathuraRenderRequest* request); +/** + * Set "plain" rendering mode, i.e. disabling scaling, recoloring, etc. + * @param request request that should be updated + * @param render_plain "plain" rendering setting + */ +void zathura_render_request_set_render_plain(ZathuraRenderRequest* request, + bool render_plain); + +/** + * Get "plain" rendering mode, i.e. disabling scaling, recoloring, etc. + * @param request request that should be updated + * @returns "plain" rendering setting + */ +bool zathura_render_request_get_render_plain(ZathuraRenderRequest* request); + /** * This function is used to unmark all pages as not rendered. This should * be used if all pages should be rendered again (e.g.: the zoom level or the