mirror of https://github.com/M66B/FairEmail.git
Fixed/improved scroll to top/bottom of expanded message
This commit is contained in:
parent
3e3d0006bc
commit
77440f7181
|
@ -1028,32 +1028,37 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
|
|||
}
|
||||
|
||||
private void scrollToVisibleItem(LinearLayoutManager llm, boolean bottom) {
|
||||
int pos = llm.findLastVisibleItemPosition();
|
||||
if (pos == RecyclerView.NO_POSITION)
|
||||
int first = llm.findFirstVisibleItemPosition();
|
||||
int last = llm.findLastVisibleItemPosition();
|
||||
if (first == RecyclerView.NO_POSITION || last == RecyclerView.NO_POSITION)
|
||||
return;
|
||||
|
||||
int pos = (bottom ? last : first);
|
||||
do {
|
||||
Long key = adapter.getKeyAtPosition(pos);
|
||||
if (key != null && iProperties.getValue("expanded", key)) {
|
||||
int first = llm.findFirstVisibleItemPosition();
|
||||
View child = rvMessage.getChildAt(pos - (first < 0 ? 0 : first));
|
||||
|
||||
View child = llm.findViewByPosition(pos);
|
||||
if (child != null) {
|
||||
TranslateAnimation bounce = new TranslateAnimation(
|
||||
0, 0, Helper.dp2pixels(getContext(), bottom ? -12 : 12), 0);
|
||||
0, 0, Helper.dp2pixels(getContext(), bottom ? -6 : 6), 0);
|
||||
bounce.setDuration(getResources().getInteger(android.R.integer.config_shortAnimTime));
|
||||
child.startAnimation(bounce);
|
||||
}
|
||||
|
||||
if (bottom && child != null)
|
||||
llm.scrollToPositionWithOffset(pos, rvMessage.getHeight() - llm.getDecoratedMeasuredHeight(child));
|
||||
if (bottom)
|
||||
llm.scrollToPositionWithOffset(pos,
|
||||
rvMessage.getHeight() - llm.getDecoratedMeasuredHeight(child) + child.getPaddingBottom());
|
||||
else
|
||||
rvMessage.scrollToPosition(pos);
|
||||
llm.scrollToPositionWithOffset(pos, -child.getPaddingTop());
|
||||
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (bottom)
|
||||
pos--;
|
||||
} while (pos >= 0);
|
||||
else
|
||||
pos++;
|
||||
} while (pos >= first && pos <= last);
|
||||
}
|
||||
|
||||
private void onSwipeRefresh() {
|
||||
|
|
Loading…
Reference in New Issue