Basics of lister scrolling in place
parent
13cda93f55
commit
c8a4b7e20a
|
@ -1544,6 +1544,16 @@ unlerp(f32 a, f32 x, f32 b){
|
||||||
return(r);
|
return(r);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal f32
|
||||||
|
lerp(Range_f32 range, f32 t){
|
||||||
|
return(lerp(range.min, t, range.max));
|
||||||
|
}
|
||||||
|
|
||||||
|
internal f32
|
||||||
|
clamp_range(Range_f32 range, f32 x){
|
||||||
|
return(clamp(range.min, x, range.max));
|
||||||
|
}
|
||||||
|
|
||||||
////////////////////////////////
|
////////////////////////////////
|
||||||
|
|
||||||
internal b32
|
internal b32
|
||||||
|
|
|
@ -77,8 +77,6 @@ lister_render(Application_Links *app, View_ID view, Frame_Info frame_info, Rect_
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Basic_Scroll scroll = lister->data.scroll;
|
|
||||||
(void)scroll;
|
|
||||||
Rect_f32 region = view_get_screen_rect(app, view);
|
Rect_f32 region = view_get_screen_rect(app, view);
|
||||||
// TODO(allen): eliminate this. bad bad bad bad :(
|
// TODO(allen): eliminate this. bad bad bad bad :(
|
||||||
region = rect_inner(region, 3.f);
|
region = rect_inner(region, 3.f);
|
||||||
|
@ -106,10 +104,25 @@ lister_render(Application_Links *app, View_ID view, Frame_Info frame_info, Rect_
|
||||||
}
|
}
|
||||||
|
|
||||||
Range_f32 x = rect_range_x(layout.list_rect);
|
Range_f32 x = rect_range_x(layout.list_rect);
|
||||||
f32 y_pos = layout.list_rect.y0;
|
Rect_f32 prev_clip = draw_set_clip(app, layout.list_rect);
|
||||||
|
|
||||||
i32 count = lister->data.filtered.count;
|
i32 count = lister->data.filtered.count;
|
||||||
for (i32 i = 0; i < count; i += 1){
|
Range_f32 scroll_range = If32(0.f, clamp_bot(0.f, count*block_height - block_height));
|
||||||
|
lister->data.scroll.position.y = clamp_range(scroll_range, lister->data.scroll.position.y);
|
||||||
|
lister->data.scroll.position.x = 0.f;
|
||||||
|
lister->data.scroll.target.y = clamp_range(scroll_range, lister->data.scroll.target.y);
|
||||||
|
lister->data.scroll.target.x = 0.f;
|
||||||
|
|
||||||
|
// TODO(allen): get scroll rule from context
|
||||||
|
lister->data.scroll.position = lister->data.scroll.target;
|
||||||
|
|
||||||
|
f32 scroll_y = lister->data.scroll.position.y;
|
||||||
|
|
||||||
|
f32 y_pos = layout.list_rect.y0 - scroll_y;
|
||||||
|
i32 first_index = (i32)(scroll_y/block_height);
|
||||||
|
y_pos += first_index*block_height;
|
||||||
|
|
||||||
|
for (i32 i = first_index; i < count; i += 1){
|
||||||
Lister_Node *node = lister->data.filtered.node_ptrs[i];
|
Lister_Node *node = lister->data.filtered.node_ptrs[i];
|
||||||
|
|
||||||
Range_f32 y = If32(y_pos, y_pos + block_height);
|
Range_f32 y = If32(y_pos, y_pos + block_height);
|
||||||
|
@ -135,8 +148,8 @@ lister_render(Application_Links *app, View_ID view, Frame_Info frame_info, Rect_
|
||||||
highlight = UIHighlight_Hover;
|
highlight = UIHighlight_Hover;
|
||||||
}
|
}
|
||||||
|
|
||||||
draw_rectangle(app, item_rect, 3.f, get_margin_color(highlight));
|
draw_rectangle(app, item_rect, 6.f, get_margin_color(highlight));
|
||||||
draw_rectangle(app, item_inner, 3.f, Stag_Back);
|
draw_rectangle(app, item_inner, 6.f, Stag_Back);
|
||||||
|
|
||||||
Fancy_String_List line = {};
|
Fancy_String_List line = {};
|
||||||
push_fancy_string(scratch, &line, fancy_id(Stag_Default), node->string);
|
push_fancy_string(scratch, &line, fancy_id(Stag_Default), node->string);
|
||||||
|
@ -146,6 +159,8 @@ lister_render(Application_Links *app, View_ID view, Frame_Info frame_info, Rect_
|
||||||
Vec2_f32 p = V2f32(item_inner.x0 + 3.f, item_inner.y0 + (block_height - line_height)*0.5f);
|
Vec2_f32 p = V2f32(item_inner.x0 + 3.f, item_inner.y0 + (block_height - line_height)*0.5f);
|
||||||
draw_fancy_string(app, face_id, line.first, p, Stag_Default, 0, 0, V2(1.f, 0.f));
|
draw_fancy_string(app, face_id, line.first, p, Stag_Default, 0, 0, V2(1.f, 0.f));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
draw_set_clip(app, prev_clip);
|
||||||
}
|
}
|
||||||
|
|
||||||
function void*
|
function void*
|
||||||
|
|
Loading…
Reference in New Issue