Mercurial > audlegacy
changeset 3146:670c41ca0147 trunk
few alternations to scrolling
author | Tomasz Mon <desowin@gmail.com> |
---|---|
date | Mon, 23 Jul 2007 10:38:18 +0200 |
parents | 19908efce4e5 |
children | f8a449aa8a6f |
files | src/audacious/ui_main.c src/audacious/ui_skinned_playlist_slider.c |
diffstat | 2 files changed, 25 insertions(+), 6 deletions(-) [+] |
line wrap: on
line diff
--- a/src/audacious/ui_main.c Sat Jul 21 20:25:56 2007 +0200 +++ b/src/audacious/ui_main.c Mon Jul 23 10:38:18 2007 +0200 @@ -476,7 +476,6 @@ gtk_widget_hide(equalizerwin); gtk_widget_hide(playlistwin); gtk_widget_hide(mainwin); - gdk_flush(); g_source_remove(mainwin_timeout_id);
--- a/src/audacious/ui_skinned_playlist_slider.c Sat Jul 21 20:25:56 2007 +0200 +++ b/src/audacious/ui_skinned_playlist_slider.c Mon Jul 23 10:38:18 2007 +0200 @@ -45,6 +45,8 @@ gint resize_height; gint move_x; + gint prev_y; + gint drag_y; }; static void ui_skinned_playlist_slider_class_init (UiSkinnedPlaylistSliderClass *klass); @@ -118,6 +120,8 @@ playlist_slider->pressed = FALSE; priv->resize_height = 0; priv->move_x = 0; + priv->drag_y = 0; + priv->prev_y = 0; } GtkWidget* ui_skinned_playlist_slider_new(GtkWidget *fixed, gint x, gint y, gint h) { @@ -236,6 +240,8 @@ if (y < 0) y=0; if (y > priv->height - 19) y = priv->height - 19; + priv->prev_y = y; + /* FIXME: uses bmp_active_skin->pixmaps directly and may need calibration */ /* drawing background */ gint c; @@ -269,13 +275,26 @@ static gboolean ui_skinned_playlist_slider_button_press(GtkWidget *widget, GdkEventButton *event) { UiSkinnedPlaylistSlider *ps = UI_SKINNED_PLAYLIST_SLIDER (widget); + UiSkinnedPlaylistSliderPrivate *priv = UI_SKINNED_PLAYLIST_SLIDER_GET_PRIVATE(widget); + if (event->button != 1 && event->button != 2) + return TRUE; + + gint y = event->y; if (event->type == GDK_BUTTON_PRESS) { - if (event->button == 1) { - ps->pressed = TRUE; - gint y = event->y; + ps->pressed = TRUE; + if ((y >= priv->prev_y && y < priv->prev_y + 18)) { + priv->drag_y = y - priv->prev_y; + } else if (event->button == 2) { ui_skinned_playlist_slider_set_position(widget, y); + priv->drag_y = 0; + } else { + gint n = playlistwin_list_get_visible_count() / 2; + if (y < priv->prev_y) + n *= -1; + playlistwin_scroll(n); } + gtk_widget_queue_draw(widget); } return TRUE; @@ -284,7 +303,7 @@ static gboolean ui_skinned_playlist_slider_button_release(GtkWidget *widget, GdkEventButton *event) { UiSkinnedPlaylistSlider *ps = UI_SKINNED_PLAYLIST_SLIDER(widget); - if (event->button == 1) { + if (event->button == 1 || event->button == 2) { ps->pressed = FALSE; gtk_widget_queue_draw(widget); } @@ -293,9 +312,10 @@ static gboolean ui_skinned_playlist_slider_motion_notify(GtkWidget *widget, GdkEventMotion *event) { UiSkinnedPlaylistSlider *ps = UI_SKINNED_PLAYLIST_SLIDER(widget); + UiSkinnedPlaylistSliderPrivate *priv = UI_SKINNED_PLAYLIST_SLIDER_GET_PRIVATE(widget); if (ps->pressed) { - gint y = event->y; + gint y = event->y - priv->drag_y; ui_skinned_playlist_slider_set_position(widget, y); } return TRUE;