@ -896,7 +896,9 @@ void ImGui::Scrollbar(ImGuiAxis axis)
}
}
float size_avail = window - > InnerRect . Max [ axis ] - window - > InnerRect . Min [ axis ] ;
float size_avail = window - > InnerRect . Max [ axis ] - window - > InnerRect . Min [ axis ] ;
float size_contents = window - > ContentSize [ axis ] + window - > WindowPadding [ axis ] * 2.0f ;
float size_contents = window - > ContentSize [ axis ] + window - > WindowPadding [ axis ] * 2.0f ;
ScrollbarEx ( bb , id , axis , & window - > Scroll [ axis ] , size_avail , size_contents , rounding_corners ) ;
ImS64 scroll = ( ImS64 ) window - > Scroll [ axis ] ;
ScrollbarEx ( bb , id , axis , & scroll , ( ImS64 ) size_avail , ( ImS64 ) size_contents , rounding_corners ) ;
window - > Scroll [ axis ] = ( float ) scroll ;
}
}
// Vertical/Horizontal scrollbar
// Vertical/Horizontal scrollbar
@ -905,7 +907,7 @@ void ImGui::Scrollbar(ImGuiAxis axis)
// - We store values as normalized ratio and in a form that allows the window content to change while we are holding on a scrollbar
// - We store values as normalized ratio and in a form that allows the window content to change while we are holding on a scrollbar
// - We handle both horizontal and vertical scrollbars, which makes the terminology not ideal.
// - We handle both horizontal and vertical scrollbars, which makes the terminology not ideal.
// Still, the code should probably be made simpler..
// Still, the code should probably be made simpler..
bool ImGui : : ScrollbarEx ( const ImRect & bb_frame , ImGuiID id , ImGuiAxis axis , float * p_scroll_v , float size_avail_v , float size_contents_v , ImDrawFlags flags )
bool ImGui : : ScrollbarEx ( const ImRect & bb_frame , ImGuiID id , ImGuiAxis axis , ImS64 * p_scroll_v , ImS64 size_avail_v , ImS64 size_contents_v , ImDrawFlags flags )
{
{
ImGuiContext & g = * GImGui ;
ImGuiContext & g = * GImGui ;
ImGuiWindow * window = g . CurrentWindow ;
ImGuiWindow * window = g . CurrentWindow ;
@ -936,8 +938,8 @@ bool ImGui::ScrollbarEx(const ImRect& bb_frame, ImGuiID id, ImGuiAxis axis, floa
// Calculate the height of our grabbable box. It generally represent the amount visible (vs the total scrollable amount)
// Calculate the height of our grabbable box. It generally represent the amount visible (vs the total scrollable amount)
// But we maintain a minimum size in pixel to allow for the user to still aim inside.
// But we maintain a minimum size in pixel to allow for the user to still aim inside.
IM_ASSERT ( ImMax ( size_contents_v , size_avail_v ) > 0.0f ) ; // Adding this assert to check if the ImMax(XXX,1.0f) is still needed. PLEASE CONTACT ME if this triggers.
IM_ASSERT ( ImMax ( size_contents_v , size_avail_v ) > 0.0f ) ; // Adding this assert to check if the ImMax(XXX,1.0f) is still needed. PLEASE CONTACT ME if this triggers.
const float win_size_v = ImMax ( ImMax ( size_contents_v , size_avail_v ) , 1.0f ) ;
const ImS64 win_size_v = ImMax ( ImMax ( size_contents_v , size_avail_v ) , ( ImS64 ) 1 ) ;
const float grab_h_pixels = ImClamp ( scrollbar_size_v * ( size_avail_v / win_size_v ) , style . GrabMinSize , scrollbar_size_v ) ;
const float grab_h_pixels = ImClamp ( scrollbar_size_v * ( ( float ) size_avail_v / ( float ) win_size_v ) , style . GrabMinSize , scrollbar_size_v ) ;
const float grab_h_norm = grab_h_pixels / scrollbar_size_v ;
const float grab_h_norm = grab_h_pixels / scrollbar_size_v ;
// Handle input right away. None of the code of Begin() is relying on scrolling position before calling Scrollbar().
// Handle input right away. None of the code of Begin() is relying on scrolling position before calling Scrollbar().
@ -945,13 +947,13 @@ bool ImGui::ScrollbarEx(const ImRect& bb_frame, ImGuiID id, ImGuiAxis axis, floa
bool hovered = false ;
bool hovered = false ;
ButtonBehavior ( bb , id , & hovered , & held , ImGuiButtonFlags_NoNavFocus ) ;
ButtonBehavior ( bb , id , & hovered , & held , ImGuiButtonFlags_NoNavFocus ) ;
float scroll_max = ImMax ( 1.0f , size_contents_v - size_avail_v ) ;
const ImS64 scroll_max = ImMax ( ( ImS64 ) 1 , size_contents_v - size_avail_v ) ;
float scroll_ratio = ImSaturate ( * p_scroll_v / scroll_max ) ;
float scroll_ratio = ImSaturate ( ( float ) * p_scroll_v / ( float ) scroll_max ) ;
float grab_v_norm = scroll_ratio * ( scrollbar_size_v - grab_h_pixels ) / scrollbar_size_v ; // Grab position in normalized space
float grab_v_norm = scroll_ratio * ( scrollbar_size_v - grab_h_pixels ) / scrollbar_size_v ; // Grab position in normalized space
if ( held & & allow_interaction & & grab_h_norm < 1.0f )
if ( held & & allow_interaction & & grab_h_norm < 1.0f )
{
{
float scrollbar_pos_v = bb . Min [ axis ] ;
const float scrollbar_pos_v = bb . Min [ axis ] ;
float mouse_pos_v = g . IO . MousePos [ axis ] ;
const float mouse_pos_v = g . IO . MousePos [ axis ] ;
// Click position in scrollbar normalized space (0.0f->1.0f)
// Click position in scrollbar normalized space (0.0f->1.0f)
const float clicked_v_norm = ImSaturate ( ( mouse_pos_v - scrollbar_pos_v ) / scrollbar_size_v ) ;
const float clicked_v_norm = ImSaturate ( ( mouse_pos_v - scrollbar_pos_v ) / scrollbar_size_v ) ;
@ -971,10 +973,10 @@ bool ImGui::ScrollbarEx(const ImRect& bb_frame, ImGuiID id, ImGuiAxis axis, floa
// Apply scroll (p_scroll_v will generally point on one member of window->Scroll)
// Apply scroll (p_scroll_v will generally point on one member of window->Scroll)
// It is ok to modify Scroll here because we are being called in Begin() after the calculation of ContentSize and before setting up our starting position
// It is ok to modify Scroll here because we are being called in Begin() after the calculation of ContentSize and before setting up our starting position
const float scroll_v_norm = ImSaturate ( ( clicked_v_norm - g . ScrollbarClickDeltaToGrabCenter - grab_h_norm * 0.5f ) / ( 1.0f - grab_h_norm ) ) ;
const float scroll_v_norm = ImSaturate ( ( clicked_v_norm - g . ScrollbarClickDeltaToGrabCenter - grab_h_norm * 0.5f ) / ( 1.0f - grab_h_norm ) ) ;
* p_scroll_v = IM_ROUND ( scroll_v_norm * scroll_max ) ; //(win_size_contents_v - win_size_v));
* p_scroll_v = ( ImS64 ) ( scroll_v_norm * scroll_max ) ;
// Update values for rendering
// Update values for rendering
scroll_ratio = ImSaturate ( * p_scroll_v / scroll_max ) ;
scroll_ratio = ImSaturate ( ( float ) * p_scroll_v / ( float ) scroll_max ) ;
grab_v_norm = scroll_ratio * ( scrollbar_size_v - grab_h_pixels ) / scrollbar_size_v ;
grab_v_norm = scroll_ratio * ( scrollbar_size_v - grab_h_pixels ) / scrollbar_size_v ;
// Update distance to grab now that we have seeked and saturated
// Update distance to grab now that we have seeked and saturated