X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/982645201216ab85899291b3bdeb4a803f24bd01..8a18ea3f03ee46d13545a26156631ac102441fc1:/src/gtk/scrolbar.cpp diff --git a/src/gtk/scrolbar.cpp b/src/gtk/scrolbar.cpp index dc05a81b0a..413e8fbe3c 100644 --- a/src/gtk/scrolbar.cpp +++ b/src/gtk/scrolbar.cpp @@ -33,14 +33,19 @@ gtk_value_changed(GtkRange* range, wxScrollBar* win) { const int orient = win->HasFlag(wxSB_VERTICAL) ? wxVERTICAL : wxHORIZONTAL; const int value = win->GetThumbPosition(); - wxScrollEvent event(eventType, win->GetId(), value, orient); - event.SetEventObject(win); - win->GetEventHandler()->ProcessEvent(event); + const int id = win->GetId(); + + // first send the specific event for the user action + wxScrollEvent evtSpec(eventType, id, value, orient); + evtSpec.SetEventObject(win); + win->HandleWindowEvent(evtSpec); + if (!win->m_isScrolling) { - wxScrollEvent event(wxEVT_SCROLL_CHANGED, win->GetId(), value, orient); - event.SetEventObject(win); - win->GetEventHandler()->ProcessEvent(event); + // and if it's over also send a general "changed" event + wxScrollEvent evtChanged(wxEVT_SCROLL_CHANGED, id, value, orient); + evtChanged.SetEventObject(win); + win->HandleWindowEvent(evtChanged); } } } @@ -73,14 +78,15 @@ gtk_event_after(GtkRange* range, GdkEvent* event, wxScrollBar* win) const int value = win->GetThumbPosition(); const int orient = win->HasFlag(wxSB_VERTICAL) ? wxVERTICAL : wxHORIZONTAL; + const int id = win->GetId(); - wxScrollEvent event(wxEVT_SCROLL_THUMBRELEASE, win->GetId(), value, orient); - event.SetEventObject(win); - win->GetEventHandler()->ProcessEvent(event); + wxScrollEvent evtRel(wxEVT_SCROLL_THUMBRELEASE, id, value, orient); + evtRel.SetEventObject(win); + win->HandleWindowEvent(evtRel); - wxScrollEvent event2(wxEVT_SCROLL_CHANGED, win->GetId(), value, orient); - event2.SetEventObject(win); - win->GetEventHandler()->ProcessEvent(event2); + wxScrollEvent evtChanged(wxEVT_SCROLL_CHANGED, id, value, orient); + evtChanged.SetEventObject(win); + win->HandleWindowEvent(evtChanged); } } } @@ -139,7 +145,7 @@ bool wxScrollBar::Create(wxWindow *parent, wxWindowID id, else m_widget = gtk_hscrollbar_new( (GtkAdjustment *) NULL ); - m_scrollBar[int(isVertical)] = (GtkRange*)m_widget; + m_scrollBar[0] = (GtkRange*)m_widget; g_signal_connect_after(m_widget, "value_changed", G_CALLBACK(gtk_value_changed), this); @@ -188,21 +194,11 @@ void wxScrollBar::SetThumbPosition( int viewStart ) { if (GetThumbPosition() != viewStart) { - GtkAdjustment* adj = ((GtkRange*)m_widget)->adjustment; - const int i = (GtkRange*)m_widget == m_scrollBar[1]; - const int max = int(adj->upper - adj->page_size); - if (viewStart > max) - viewStart = max; - if (viewStart < 0) - viewStart = 0; - - m_scrollPos[i] = - adj->value = viewStart; - g_signal_handlers_block_by_func(m_widget, (gpointer)gtk_value_changed, this); - gtk_adjustment_value_changed(adj); + gtk_range_set_value((GtkRange*)m_widget, viewStart); + m_scrollPos[0] = gtk_range_get_value((GtkRange*)m_widget); g_signal_handlers_unblock_by_func(m_widget, (gpointer)gtk_value_changed, this); @@ -217,17 +213,15 @@ void wxScrollBar::SetScrollbar(int position, int thumbSize, int range, int pageS range = thumbSize = 1; } - if (position > range - thumbSize) - position = range - thumbSize; - if (position < 0) - position = 0; GtkAdjustment* adj = ((GtkRange*)m_widget)->adjustment; adj->step_increment = 1; adj->page_increment = pageSize; adj->page_size = thumbSize; - adj->upper = range; - SetThumbPosition(position); - gtk_adjustment_changed(adj); + adj->value = position; + g_signal_handlers_block_by_func(m_widget, (void*)gtk_value_changed, this); + gtk_range_set_range((GtkRange*)m_widget, 0, range); + m_scrollPos[0] = adj->value; + g_signal_handlers_unblock_by_func(m_widget, (void*)gtk_value_changed, this); } void wxScrollBar::SetPageSize( int pageLength )