Save links in page_view_widget

This commit is contained in:
Moritz Lipp 2012-02-07 16:39:02 +01:00
parent ab03d2dd0b
commit d3967d9bde
5 changed files with 80 additions and 71 deletions

View file

@ -144,3 +144,5 @@ cb_index_row_activated(GtkTreeView* tree_view, GtkTreePath* path,
g_object_unref(model); g_object_unref(model);
} }
bool

View file

@ -291,7 +291,7 @@ cmd_search(girara_session_t* session, const char* input, girara_argument_t* argu
continue; continue;
} }
zathura_page_view_clear_rectangles(ZATHURA_PAGE_VIEW(page->drawing_area)); g_object_set(page->drawing_area, "draw-links", FALSE, NULL);
girara_list_t* result = zathura_page_search_text(page, input); girara_list_t* result = zathura_page_search_text(page, input);
if (result == NULL || girara_list_size(result) == 0) { if (result == NULL || girara_list_size(result) == 0) {
@ -301,7 +301,7 @@ cmd_search(girara_session_t* session, const char* input, girara_argument_t* argu
GIRARA_LIST_FOREACH(result, zathura_rectangle_t*, iter, rect) GIRARA_LIST_FOREACH(result, zathura_rectangle_t*, iter, rect)
zathura_rectangle_t position = recalc_rectangle(page, *rect); zathura_rectangle_t position = recalc_rectangle(page, *rect);
zathura_page_view_draw_rectangle(ZATHURA_PAGE_VIEW(page->drawing_area), &position, -1); /*zathura_page_view_draw_rectangle(ZATHURA_PAGE_VIEW(page->drawing_area), &position, -1);*/
GIRARA_LIST_FOREACH_END(result, zathura_link_t*, iter, link); GIRARA_LIST_FOREACH_END(result, zathura_link_t*, iter, link);
girara_list_free(result); girara_list_free(result);
} }

View file

@ -2,24 +2,21 @@
#include "page_view_widget.h" #include "page_view_widget.h"
#include "render.h" #include "render.h"
#include "utils.h"
#include <girara/utils.h> #include <girara/utils.h>
#include <girara/settings.h> #include <girara/settings.h>
#include <girara/datastructures.h> #include <girara/datastructures.h>
G_DEFINE_TYPE(ZathuraPageView, zathura_page_view, GTK_TYPE_DRAWING_AREA) G_DEFINE_TYPE(ZathuraPageView, zathura_page_view, GTK_TYPE_DRAWING_AREA)
typedef struct pv_rect_s
{
zathura_rectangle_t rect;
int linkid;
} pv_rect_t;
typedef struct zathura_page_view_private_s { typedef struct zathura_page_view_private_s {
zathura_page_t* page; zathura_page_t* page;
zathura_t* zathura; zathura_t* zathura;
cairo_surface_t* surface; /** Cairo surface */ cairo_surface_t* surface; /** Cairo surface */
GStaticMutex lock; /**< Lock */ GStaticMutex lock; /**< Lock */
girara_list_t* rectangles; girara_list_t* links; /**< List of links on the page */
bool links_got; /**< True if we already tried to retrieve the list of links */
bool draw_links; /**< True if links should be drawn */
} zathura_page_view_private_t; } zathura_page_view_private_t;
#define ZATHURA_PAGE_VIEW_GET_PRIVATE(obj) \ #define ZATHURA_PAGE_VIEW_GET_PRIVATE(obj) \
@ -29,11 +26,13 @@ static gboolean zathura_page_view_expose(GtkWidget* widget, GdkEventExpose* even
static void zathura_page_view_finalize(GObject* object); static void zathura_page_view_finalize(GObject* object);
static void zathura_page_view_set_property(GObject* object, guint prop_id, const GValue* value, GParamSpec* pspec); static void zathura_page_view_set_property(GObject* object, guint prop_id, const GValue* value, GParamSpec* pspec);
static void zathura_page_view_size_allocate(GtkWidget* widget, GdkRectangle* allocation); static void zathura_page_view_size_allocate(GtkWidget* widget, GdkRectangle* allocation);
static void redraw_rect(ZathuraPageView* widget, zathura_rectangle_t* rectangle);
enum properties_e enum properties_e
{ {
PROP_0, PROP_0,
PROP_PAGE PROP_PAGE,
PROP_DRAW_LINKS,
}; };
static void static void
@ -54,15 +53,18 @@ zathura_page_view_class_init(ZathuraPageViewClass* class)
/* add properties */ /* add properties */
g_object_class_install_property(object_class, PROP_PAGE, g_object_class_install_property(object_class, PROP_PAGE,
g_param_spec_pointer("page", "page", "the page to draw", G_PARAM_WRITABLE | G_PARAM_CONSTRUCT_ONLY)); g_param_spec_pointer("page", "page", "the page to draw", G_PARAM_WRITABLE | G_PARAM_CONSTRUCT_ONLY));
g_object_class_install_property(object_class, PROP_DRAW_LINKS,
g_param_spec_boolean("draw-links", "draw-links", "Set to true if links should be drawn", FALSE, G_PARAM_WRITABLE));
} }
static void static void
zathura_page_view_init(ZathuraPageView* widget) zathura_page_view_init(ZathuraPageView* widget)
{ {
zathura_page_view_private_t* priv = ZATHURA_PAGE_VIEW_GET_PRIVATE(widget); zathura_page_view_private_t* priv = ZATHURA_PAGE_VIEW_GET_PRIVATE(widget);
priv->page = NULL; priv->page = NULL;
priv->surface = NULL; priv->surface = NULL;
priv->rectangles = girara_list_new2(g_free); priv->links = NULL;
priv->links_got = false;
g_static_mutex_init(&(priv->lock)); g_static_mutex_init(&(priv->lock));
/* we want mouse events */ /* we want mouse events */
@ -104,6 +106,21 @@ zathura_page_view_set_property(GObject* object, guint prop_id, const GValue* val
priv->page = g_value_get_pointer(value); priv->page = g_value_get_pointer(value);
priv->zathura = priv->page->document->zathura; priv->zathura = priv->page->document->zathura;
break; break;
case PROP_DRAW_LINKS:
priv->draw_links = g_value_get_boolean(value);
/* get links */
if (priv->draw_links == true && priv->links_got == false) {
priv->links = zathura_page_links_get(priv->page);
priv->links_got = true;
}
if (priv->links_got == true && priv->links != NULL) {
GIRARA_LIST_FOREACH(priv->links, zathura_link_t*, iter, link)
zathura_rectangle_t rectangle = recalc_rectangle(priv->page, link->position);
redraw_rect(pageview, &rectangle);
GIRARA_LIST_FOREACH_END(priv->links, zathura_link_t*, iter, link);
}
break;
default: default:
G_OBJECT_WARN_INVALID_PROPERTY_ID(object, prop_id, pspec); G_OBJECT_WARN_INVALID_PROPERTY_ID(object, prop_id, pspec);
} }
@ -165,22 +182,26 @@ zathura_page_view_expose(GtkWidget* widget, GdkEventExpose* event)
cairo_select_font_face(cairo, font, CAIRO_FONT_SLANT_NORMAL, CAIRO_FONT_WEIGHT_BOLD); cairo_select_font_face(cairo, font, CAIRO_FONT_SLANT_NORMAL, CAIRO_FONT_WEIGHT_BOLD);
} }
GIRARA_LIST_FOREACH(priv->rectangles, pv_rect_t*, iter, rect) /* draw links */
if (rect->linkid >= 0) { if (priv->draw_links == true) {
GIRARA_LIST_FOREACH(priv->links, zathura_link_t*, iter, link)
zathura_rectangle_t rectangle = recalc_rectangle(priv->page, link->position);
/* draw text */ /* draw text */
cairo_set_font_size(cairo, 10); cairo_set_font_size(cairo, 10);
cairo_move_to(cairo, rect->rect.x1 + 1, rect->rect.y1 - 1); cairo_move_to(cairo, rectangle.x1 + 1, rectangle.y1 - 1);
char* link_number = g_strdup_printf("%i", rect->linkid); char* link_number = g_strdup_printf("%i", 0);
cairo_show_text(cairo, link_number); cairo_show_text(cairo, link_number);
g_free(link_number); g_free(link_number);
}
/* draw rectangle */ /* draw position */
GdkColor color = priv->zathura->ui.colors.highlight_color; GdkColor color = priv->zathura->ui.colors.highlight_color;
cairo_set_source_rgba(cairo, color.red, color.green, color.blue, transparency); cairo_set_source_rgba(cairo, color.red, color.green, color.blue, transparency);
cairo_rectangle(cairo, rect->rect.x1, rect->rect.y1, (rect->rect.x2 - rect->rect.x1), (rect->rect.y2 - rect->rect.y1)); cairo_rectangle(cairo, rectangle.x1, rectangle.y1,
cairo_fill(cairo); (rectangle.x2 - rectangle.x1), (rectangle.y2 - rectangle.y1));
GIRARA_LIST_FOREACH_END(priv->rectangles, pv_rect_t*, iter, rect); cairo_fill(cairo);
GIRARA_LIST_FOREACH_END(priv->links, zathura_link_t*, iter, link);
}
} else { } else {
/* set background color */ /* set background color */
cairo_set_source_rgb(cairo, 255, 255, 255); cairo_set_source_rgb(cairo, 255, 255, 255);
@ -243,48 +264,27 @@ static void
zathura_page_view_size_allocate(GtkWidget* widget, GdkRectangle* allocation) zathura_page_view_size_allocate(GtkWidget* widget, GdkRectangle* allocation)
{ {
GTK_WIDGET_CLASS(zathura_page_view_parent_class)->size_allocate(widget, allocation); GTK_WIDGET_CLASS(zathura_page_view_parent_class)->size_allocate(widget, allocation);
zathura_page_view_clear_rectangles(ZATHURA_PAGE_VIEW(widget));
zathura_page_view_update_surface(ZATHURA_PAGE_VIEW(widget), NULL); zathura_page_view_update_surface(ZATHURA_PAGE_VIEW(widget), NULL);
} }
static void static void
redraw_rect(ZathuraPageView* widget, pv_rect_t* rectangle) redraw_rect(ZathuraPageView* widget, zathura_rectangle_t* rectangle)
{ {
/* cause the rect to be drawn */ /* cause the rect to be drawn */
GdkRectangle grect; GdkRectangle grect;
grect.x = rectangle->rect.x1; grect.x = rectangle->x1;
grect.y = rectangle->rect.y2; grect.y = rectangle->y2;
grect.width = rectangle->rect.x2 - rectangle->rect.x1; grect.width = rectangle->x2 - rectangle->x1;
grect.height = rectangle->rect.y1 - rectangle->rect.y2; grect.height = rectangle->y1 - rectangle->y2;
gdk_window_invalidate_rect(GTK_WIDGET(widget)->window, &grect, TRUE); gdk_window_invalidate_rect(GTK_WIDGET(widget)->window, &grect, TRUE);
} }
void zathura_link_t*
zathura_page_view_draw_rectangle(ZathuraPageView* widget, zathura_rectangle_t* rectangle, int linkid) zathura_page_view_link_get(ZathuraPageView* widget, unsigned int index)
{ {
g_return_if_fail(widget != NULL); g_return_val_if_fail(widget != NULL, NULL);
if (rectangle == NULL) {
return;
}
zathura_page_view_private_t* priv = ZATHURA_PAGE_VIEW_GET_PRIVATE(widget); zathura_page_view_private_t* priv = ZATHURA_PAGE_VIEW_GET_PRIVATE(widget);
g_return_val_if_fail(priv != NULL, NULL);
pv_rect_t* rect = g_malloc0(sizeof(pv_rect_t)); return girara_list_nth(priv->links, index);
rect->rect = *rectangle;
rect->linkid = linkid;
girara_list_append(priv->rectangles, rect);
redraw_rect(widget, rect);
}
void
zathura_page_view_clear_rectangles(ZathuraPageView* widget)
{
g_return_if_fail(widget != NULL);
zathura_page_view_private_t* priv = ZATHURA_PAGE_VIEW_GET_PRIVATE(widget);
GIRARA_LIST_FOREACH(priv->rectangles, pv_rect_t*, iter, rect)
redraw_rect(widget, rect);
GIRARA_LIST_FOREACH_END(priv->rectangles, pv_rect_t*, iter, rect);
girara_list_clear(priv->rectangles);
} }

View file

@ -66,4 +66,13 @@ void zathura_page_view_draw_rectangle(ZathuraPageView* widget, zathura_rectangle
*/ */
void zathura_page_view_clear_rectangles(ZathuraPageView* widget); void zathura_page_view_clear_rectangles(ZathuraPageView* widget);
/**
* Returns the zathura link object at the given index
*
* @param widget the widget
* @param index Index of the link
* @return Link object or NULL if an error occured
*/
zathura_link_t* zathura_page_view_link_get(ZathuraPageView* widget, unsigned int index);
#endif #endif

View file

@ -19,6 +19,8 @@ bool
sc_abort(girara_session_t* session, girara_argument_t* UNUSED(argument), sc_abort(girara_session_t* session, girara_argument_t* UNUSED(argument),
girara_event_t* UNUSED(event), unsigned int UNUSED(t)) girara_event_t* UNUSED(event), unsigned int UNUSED(t))
{ {
girara_info("in sc_abort");
g_return_val_if_fail(session != NULL, false); g_return_val_if_fail(session != NULL, false);
g_return_val_if_fail(session->global.data != NULL, false); g_return_val_if_fail(session->global.data != NULL, false);
zathura_t* zathura = session->global.data; zathura_t* zathura = session->global.data;
@ -29,7 +31,7 @@ sc_abort(girara_session_t* session, girara_argument_t* UNUSED(argument),
continue; continue;
} }
zathura_page_view_clear_rectangles(ZATHURA_PAGE_VIEW(page->drawing_area)); g_object_set(page->drawing_area, "draw-links", FALSE, NULL);
} }
girara_mode_set(session, session->modes.normal); girara_mode_set(session, session->modes.normal);
@ -119,29 +121,23 @@ sc_follow(girara_session_t* session, girara_argument_t* UNUSED(argument),
return false; return false;
} }
unsigned int link_id = 0; /* set pages to draw links */
for (unsigned int page_id = 0; page_id < zathura->document->number_of_pages; page_id++) { for (unsigned int page_id = 0; page_id < zathura->document->number_of_pages; page_id++) {
zathura_page_t* page = zathura->document->pages[page_id]; zathura_page_t* page = zathura->document->pages[page_id];
if (page == NULL) { if (page == NULL) {
continue; continue;
} }
zathura_page_view_clear_rectangles(ZATHURA_PAGE_VIEW(page->drawing_area)); if (page->visible == true) {
g_object_set(page->drawing_area, "draw-links", TRUE, NULL);
// TODO: is page visible? } else {
girara_list_t* links = zathura_page_links_get(page); g_object_set(page->drawing_area, "draw-links", FALSE, NULL);
if (links == NULL || girara_list_size(links) == 0) {
girara_list_free(links);
continue;
} }
GIRARA_LIST_FOREACH(links, zathura_link_t*, iter, link)
zathura_rectangle_t position = recalc_rectangle(page, link->position);
zathura_page_view_draw_rectangle(ZATHURA_PAGE_VIEW(page->drawing_area), &position, ++link_id);
GIRARA_LIST_FOREACH_END(links, zathura_link_t*, iter, link);
girara_list_free(links);
} }
/* ask for input */
girara_dialog(zathura->ui.session, "Follow link:", FALSE, NULL, NULL);
return false; return false;
} }
@ -362,7 +358,9 @@ sc_search(girara_session_t* session, girara_argument_t* argument,
zathura_t* zathura = session->global.data; zathura_t* zathura = session->global.data;
g_return_val_if_fail(argument != NULL, false); g_return_val_if_fail(argument != NULL, false);
g_return_val_if_fail(zathura->document != NULL, false); g_return_val_if_fail(zathura->document != NULL, false);
girara_info("in sc_search");
return false; return false;
} }