diff options
author | Marco Pesenti Gritti <mpg@redhat.com> | 2005-06-07 09:20:35 (GMT) |
---|---|---|
committer | Marco Pesenti Gritti <marco@src.gnome.org> | 2005-06-07 09:20:35 (GMT) |
commit | 421d3d8b0f2f2432ec02f57677da2964d339f2d8 (patch) | |
tree | ac1ccd139b4b99b15b8f355e3b8aeca79e439621 /backend/ev-jobs.c | |
parent | 2380ada377881c8e6bf00368f713ebd72e355dda (diff) |
Add an async renderer interface (method + callback) which is useful for
2005-06-07 Marco Pesenti Gritti <mpg@redhat.com>
* backend/Makefile.am:
* backend/ev-async-renderer.c: (ev_async_renderer_get_type),
(ev_async_renderer_class_init), (ev_async_renderer_render_pixbuf):
* backend/ev-async-renderer.h:
Add an async renderer interface (method + callback) which
is useful for backends like ps.
* backend/ev-job-queue.c: (remove_job_from_async_queue),
(add_job_to_async_queue), (job_finished_cb), (handle_job),
(ev_job_queue_run_next), (ev_job_queue_init), (find_queue),
(ev_job_queue_add_job), (move_job_async), (move_job),
(ev_job_queue_update_job), (ev_job_queue_remove_job):
Add queues for async renderer, these are executed on the
main thread.
* backend/ev-jobs.c: (ev_job_render_new), (render_finished_cb),
(ev_job_render_run):
* backend/ev-jobs.h:
If the backend support async renderer interface use it.
* ps/ps-document.c: (ps_document_init), (push_pixbuf),
(setup_pixmap), (ps_document_get_type),
(ps_async_renderer_render_pixbuf),
(ps_document_document_iface_init), (ps_async_renderer_iface_init):
Implement async renderer interface.
Diffstat (limited to 'backend/ev-jobs.c')
-rw-r--r-- | backend/ev-jobs.c | 37 |
1 files changed, 31 insertions, 6 deletions
diff --git a/backend/ev-jobs.c b/backend/ev-jobs.c index c4556c9..73b0614 100644 --- a/backend/ev-jobs.c +++ b/backend/ev-jobs.c @@ -2,6 +2,7 @@ #include "ev-job-queue.h" #include "ev-document-thumbnails.h" #include "ev-document-links.h" +#include "ev-async-renderer.h" static void ev_job_init (EvJob *job); static void ev_job_class_init (EvJobClass *class); @@ -196,9 +197,24 @@ ev_job_render_new (EvDocument *document, job->target_height = height; job->include_links = include_links; + if (EV_IS_ASYNC_RENDERER (document)) { + EV_JOB (job)->async = TRUE; + } + return EV_JOB (job); } +static void +render_finished_cb (EvDocument *document, GdkPixbuf *pixbuf, EvJobRender *job) +{ + g_signal_handlers_disconnect_by_func (EV_JOB (job)->document, + render_finished_cb, job); + + EV_JOB (job)->finished = TRUE; + job->pixbuf = g_object_ref (pixbuf); + ev_job_finished (EV_JOB (job)); +} + void ev_job_render_run (EvJobRender *job) { @@ -206,12 +222,21 @@ ev_job_render_run (EvJobRender *job) ev_document_doc_mutex_lock (); - job->pixbuf = ev_document_render_pixbuf (EV_JOB (job)->document, - job->page, - job->scale); - if (job->include_links) - job->link_mapping = ev_document_get_links (EV_JOB (job)->document, job->page); - EV_JOB (job)->finished = TRUE; + if (EV_JOB (job)->async) { + EvAsyncRenderer *renderer = EV_ASYNC_RENDERER (EV_JOB (job)->document); + ev_async_renderer_render_pixbuf (renderer, job->page, job->scale); + g_signal_connect (EV_JOB (job)->document, "render_finished", + G_CALLBACK (render_finished_cb), job); + } else { + job->pixbuf = ev_document_render_pixbuf (EV_JOB (job)->document, + job->page, + job->scale); + if (job->include_links) + job->link_mapping = ev_document_get_links (EV_JOB (job)->document, job->page); + + EV_JOB (job)->finished = TRUE; + } + ev_document_doc_mutex_unlock (); } |