diff options
author | Marco Pesenti Gritti <marco@gnome.org> | 2005-01-07 10:30:52 (GMT) |
---|---|---|
committer | Marco Pesenti Gritti <marco@src.gnome.org> | 2005-01-07 10:30:52 (GMT) |
commit | 3a87fe3d6bd17d8151c675c9b4e9294619127b1b (patch) | |
tree | 17ce19206a2f6b3f82a303337ad672925b94cbc1 /shell | |
parent | a369c69460912502c842baffe73a373134f02fca (diff) |
Cleanup and add select all.
2005-01-07 Marco Pesenti Gritti <marco@gnome.org>
* data/evince-ui.xml:
Cleanup and add select all.
* shell/ev-view.c: (ev_view_select_all),
(ev_view_button_press_event):
* shell/ev-view.h:
* shell/ev-window.c: (ev_window_cmd_edit_select_all):
Add select all.
Clear selection on click.
Diffstat (limited to 'shell')
-rw-r--r-- | shell/ev-view.c | 20 | ||||
-rw-r--r-- | shell/ev-view.h | 1 | ||||
-rw-r--r-- | shell/ev-window.c | 12 |
3 files changed, 32 insertions, 1 deletions
diff --git a/shell/ev-view.c b/shell/ev-view.c index 9936ce1..f878812 100644 --- a/shell/ev-view.c +++ b/shell/ev-view.c @@ -422,6 +422,21 @@ ev_view_expose_event (GtkWidget *widget, } void +ev_view_select_all (EvView *ev_view) +{ + GtkWidget *widget = GTK_WIDGET (ev_view); + + g_return_if_fail (EV_IS_VIEW (ev_view)); + + ev_view->has_selection = TRUE; + ev_view->selection.x = ev_view->selection.y = 0; + ev_view->selection.width = widget->requisition.width; + ev_view->selection.height = widget->requisition.height; + + gtk_widget_queue_draw (widget); +} + +void ev_view_copy (EvView *ev_view) { GtkClipboard *clipboard; @@ -490,6 +505,11 @@ ev_view_button_press_event (GtkWidget *widget, switch (event->button) { case 1: + if (view->has_selection) { + view->has_selection = FALSE; + gtk_widget_queue_draw (widget); + } + view->selection.x = event->x; view->selection.y = event->y; view->selection.width = 0; diff --git a/shell/ev-view.h b/shell/ev-view.h index cddd274..c68bf9f 100644 --- a/shell/ev-view.h +++ b/shell/ev-view.h @@ -37,6 +37,7 @@ typedef struct _EvViewClass EvViewClass; GType ev_view_get_type (void) G_GNUC_CONST; GtkWidget* ev_view_new (void); void ev_view_copy (EvView *view); +void ev_view_select_all (EvView *view); void ev_view_set_document (EvView *view, EvDocument *document); void ev_view_set_page (EvView *view, diff --git a/shell/ev-window.c b/shell/ev-window.c index e110e1d..8f01111 100644 --- a/shell/ev-window.c +++ b/shell/ev-window.c @@ -584,6 +584,14 @@ find_not_supported_dialog (EvWindow *ev_window) } static void +ev_window_cmd_edit_select_all (GtkAction *action, EvWindow *ev_window) +{ + g_return_if_fail (EV_IS_WINDOW (ev_window)); + + ev_view_select_all (EV_VIEW (ev_window->priv->view)); +} + +static void ev_window_cmd_edit_find (GtkAction *action, EvWindow *ev_window) { g_return_if_fail (EV_IS_WINDOW (ev_window)); @@ -1239,7 +1247,9 @@ static GtkActionEntry entries[] = { { "EditCopy", GTK_STOCK_COPY, N_("_Copy"), "<control>C", N_("Copy text from the document"), G_CALLBACK (ev_window_cmd_edit_copy) }, - + { "EditSelectAll", NULL, N_("Select _All"), "<control>A", + N_("Select the entire page"), + G_CALLBACK (ev_window_cmd_edit_select_all) }, { "EditFind", GTK_STOCK_FIND, N_("_Find"), "<control>F", N_("Find a word or phrase in the document"), G_CALLBACK (ev_window_cmd_edit_find) }, |