Update rendering

This commit is contained in:
Moritz Lipp 2011-03-20 02:09:04 +01:00
parent e5d0b6bac0
commit c5491675aa
4 changed files with 45 additions and 17 deletions

View file

@ -68,7 +68,7 @@ cb_view_vadjustment_value_changed(GtkAdjustment *adjustment, gpointer data)
/*|| ( (begin <= lower) && (end >= lower) && (end <= upper) ) [> end of the page is in viewport <]*/ /*|| ( (begin <= lower) && (end >= lower) && (end <= upper) ) [> end of the page is in viewport <]*/
/*|| ( (begin >= lower) && (end >= upper) && (begin <= upper) ) [> begin of the page is in viewport <]*/ /*|| ( (begin >= lower) && (end >= upper) && (begin <= upper) ) [> begin of the page is in viewport <]*/
/*) {*/ /*) {*/
if (page_id < 5) { if (page_id < 1) {
render_page(Zathura.Sync.render_thread, Zathura.document->pages[page_id]); render_page(Zathura.Sync.render_thread, Zathura.document->pages[page_id]);
} }
/*}*/ /*}*/

View file

@ -539,6 +539,7 @@ zathura_image_buffer_create(unsigned int width, unsigned int height)
image_buffer->width = width; image_buffer->width = width;
image_buffer->height = height; image_buffer->height = height;
image_buffer->rowstride = width * 3;
return image_buffer; return image_buffer;
} }

View file

@ -51,6 +51,7 @@ typedef struct zathura_image_buffer_s
unsigned char* data; /**> Image buffer data */ unsigned char* data; /**> Image buffer data */
unsigned int height; /**> Height of the image */ unsigned int height; /**> Height of the image */
unsigned int width; /**> Width of the image */ unsigned int width; /**> Width of the image */
unsigned int rowstride; /**> Rowstride of the image */
} zathura_image_buffer_t; } zathura_image_buffer_t;
/** /**

View file

@ -20,7 +20,10 @@ render_job(void* data)
girara_list_remove(render_thread->list, page); girara_list_remove(render_thread->list, page);
g_mutex_unlock(render_thread->lock); g_mutex_unlock(render_thread->lock);
render(page); if (render(page) != true) {
fprintf(stderr, "rendering failed\n");
}
printf("Rendered %d\n", page->number); printf("Rendered %d\n", page->number);
} }
@ -131,28 +134,51 @@ render(zathura_page_t* page)
{ {
gdk_threads_enter(); gdk_threads_enter();
g_static_mutex_lock(&(page->lock)); g_static_mutex_lock(&(page->lock));
zathura_image_buffer_t* buffer = zathura_page_render(page); zathura_image_buffer_t* image_buffer = zathura_page_render(page);
if (!buffer) { if (image_buffer == NULL) {
g_static_mutex_unlock(&(page->lock)); g_static_mutex_unlock(&(page->lock));
printf("error: rendering failed\n");
gdk_threads_leave(); gdk_threads_leave();
return false; return false;
} }
/* create drawing area */ /* remove old image */
/*GtkWidget* drawing_area = gtk_drawing_area_new();*/ GtkWidget* widget = gtk_bin_get_child(GTK_BIN(page->event_box));
if (widget != NULL) {
gtk_container_remove(GTK_CONTAINER(page->event_box), widget);
}
/*[> remove old image <]*/ /* create cairo surface */
/*GtkWidget* widget = gtk_bin_get_child(GTK_BIN(page->event_box));*/ unsigned int page_width = page->width * Zathura.document->scale;
/*if (widget != NULL) {*/ unsigned int page_height = page->height * Zathura.document->scale;
/*g_object_unref(widget);*/
/*}*/
/*[> set new image <]*/ cairo_surface_t* surface = cairo_image_surface_create(CAIRO_FORMAT_RGB24, page_width, page_height);
/*gtk_box_pack_start(GTK_BOX(page->event_box), drawing_area, TRUE, TRUE, 0);*/
zathura_image_buffer_free(buffer); int rowstride = cairo_image_surface_get_stride(surface);
unsigned char* image = cairo_image_surface_get_data(surface);
for (unsigned int y = 0; y < page_height; y++) {
unsigned char* dst = image + y * rowstride;
unsigned char* src = image_buffer->data + y * image_buffer->rowstride;
for (unsigned int x = 0; x < page_width; x++) {
dst[0] = src[0];
dst[1] = src[1];
dst[2] = src[2];
dst += 3;
}
}
/* draw to gtk widget */
GtkWidget* drawing_area = gtk_drawing_area_new();
gtk_container_add(GTK_CONTAINER(page->event_box), drawing_area);
cairo_t* cairo = gdk_cairo_create(drawing_area->window);
cairo_set_source_surface(cairo, surface, 0, 0);
cairo_paint(cairo);
cairo_destroy(cairo);
zathura_image_buffer_free(image_buffer);
g_static_mutex_unlock(&(page->lock)); g_static_mutex_unlock(&(page->lock));
gdk_threads_leave(); gdk_threads_leave();