diff options
Diffstat (limited to 'shell/ev-utils.c')
-rw-r--r-- | shell/ev-utils.c | 84 |
1 files changed, 0 insertions, 84 deletions
diff --git a/shell/ev-utils.c b/shell/ev-utils.c index 342f838e..ebfca1ec 100644 --- a/shell/ev-utils.c +++ b/shell/ev-utils.c @@ -26,90 +26,6 @@ #include <string.h> #include <glib/gi18n.h> -static int -_gtk_get_monitor_num (GdkMonitor *monitor) -{ - GdkDisplay *display; - int n_monitors, i; - - display = gdk_monitor_get_display (monitor); - n_monitors = gdk_display_get_n_monitors (display); - - for(i = 0; i < n_monitors; i++) - { - if (gdk_display_get_monitor (display, i) == monitor) return i; - } - - return -1; -} - -static void -ev_gui_sanitise_popup_position (GtkMenu *menu, - GtkWidget *widget, - gint *x, - gint *y) -{ - GdkDisplay *display = gtk_widget_get_display (widget); - GdkMonitor *monitor_num; - GdkRectangle monitor; - GtkRequisition req; - - g_return_if_fail (widget != NULL); - - gtk_widget_get_preferred_size (GTK_WIDGET (menu), &req, NULL); - - monitor_num = gdk_display_get_monitor_at_point (display, *x, *y); - gtk_menu_set_monitor (menu, _gtk_get_monitor_num (monitor_num)); - gdk_monitor_get_geometry (monitor_num, &monitor); - - *x = CLAMP (*x, monitor.x, monitor.x + MAX (0, monitor.width - req.width)); - *y = CLAMP (*y, monitor.y, monitor.y + MAX (0, monitor.height - req.height)); -} - -void -ev_gui_menu_position_tree_selection (GtkMenu *menu, - gint *x, - gint *y, - gboolean *push_in, - gpointer user_data) -{ - GtkTreeSelection *selection; - GList *selected_rows; - GtkTreeModel *model; - GtkTreeView *tree_view = GTK_TREE_VIEW (user_data); - GtkWidget *widget = GTK_WIDGET (user_data); - GtkRequisition req; - GtkAllocation allocation; - GdkRectangle visible; - - gtk_widget_get_preferred_size (GTK_WIDGET (menu), &req, NULL); - gdk_window_get_origin (gtk_widget_get_window (widget), x, y); - gtk_widget_get_allocation (widget, &allocation); - - *x += (allocation.width - req.width) / 2; - - /* Add on height for the treeview title */ - gtk_tree_view_get_visible_rect (tree_view, &visible); - *y += allocation.height - visible.height; - - selection = gtk_tree_view_get_selection (tree_view); - selected_rows = gtk_tree_selection_get_selected_rows (selection, &model); - if (selected_rows) - { - GdkRectangle cell_rect; - - gtk_tree_view_get_cell_area (tree_view, selected_rows->data, - NULL, &cell_rect); - - *y += CLAMP (cell_rect.y + cell_rect.height, 0, visible.height); - - g_list_foreach (selected_rows, (GFunc)gtk_tree_path_free, NULL); - g_list_free (selected_rows); - } - - ev_gui_sanitise_popup_position (menu, widget, x, y); -} - void file_chooser_dialog_add_writable_pixbuf_formats (GtkFileChooser *chooser) { |