Fix jumps with media preview for some devices

This commit is contained in:
Thomas 2022-12-19 16:20:42 +01:00
parent 221bf45f27
commit d7a2a6b855

View file

@ -1163,15 +1163,15 @@ public class StatusAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder>
float mediaH = -1.0f; float mediaH = -1.0f;
if (attachment.measuredWidth > 0) { if (attachment.measuredWidth > 0) {
if (attachment.meta != null && attachment.meta.small != null) {
float viewWidth = attachment.measuredWidth; float viewWidth = attachment.measuredWidth;
if (attachment.meta != null && attachment.meta.small != null) {
mediaH = attachment.meta.small.height; mediaH = attachment.meta.small.height;
float mediaW = attachment.meta.small.width; float mediaW = attachment.meta.small.width;
if (mediaW != 0) { if (mediaW != 0) {
ratio = viewWidth / mediaW; ratio = viewWidth / mediaW;
} }
} }
loadAndAddAttachment(context, layoutMediaBinding, holder, adapter, mediaPosition, mediaH, ratio, statusToDeal, attachment, singleMedia); loadAndAddAttachment(context, layoutMediaBinding, holder, adapter, mediaPosition, viewWidth, mediaH, ratio, statusToDeal, attachment, singleMedia);
} else { } else {
int finalMediaPosition = mediaPosition; int finalMediaPosition = mediaPosition;
layoutMediaBinding.media.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() { layoutMediaBinding.media.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
@ -1181,20 +1181,20 @@ public class StatusAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder>
attachment.measuredWidth = layoutMediaBinding.media.getWidth(); attachment.measuredWidth = layoutMediaBinding.media.getWidth();
float ratio = 1.0f; float ratio = 1.0f;
float mediaH = -1.0f; float mediaH = -1.0f;
if (attachment.meta != null && attachment.meta.small != null) {
float viewWidth = attachment.measuredWidth; float viewWidth = attachment.measuredWidth;
if (attachment.meta != null && attachment.meta.small != null) {
mediaH = attachment.meta.small.height; mediaH = attachment.meta.small.height;
float mediaW = attachment.meta.small.width; float mediaW = attachment.meta.small.width;
if (mediaW != 0) { if (mediaW != 0) {
ratio = viewWidth / mediaW; ratio = viewWidth / mediaW;
} }
} }
loadAndAddAttachment(context, layoutMediaBinding, holder, adapter, finalMediaPosition, mediaH, ratio, statusToDeal, attachment, singleMedia); loadAndAddAttachment(context, layoutMediaBinding, holder, adapter, finalMediaPosition, viewWidth, mediaH, ratio, statusToDeal, attachment, singleMedia);
} }
}); });
} }
} else { } else {
loadAndAddAttachment(context, layoutMediaBinding, holder, adapter, mediaPosition, -1.f, -1.f, statusToDeal, attachment, singleMedia); loadAndAddAttachment(context, layoutMediaBinding, holder, adapter, mediaPosition, -1.f, -1.f, -1.f, statusToDeal, attachment, singleMedia);
} }
mediaPosition++; mediaPosition++;
if (fullAttachement || singleMedia) { if (fullAttachement || singleMedia) {
@ -1966,7 +1966,7 @@ public class StatusAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder>
private static void loadAndAddAttachment(Context context, LayoutMediaBinding layoutMediaBinding, private static void loadAndAddAttachment(Context context, LayoutMediaBinding layoutMediaBinding,
StatusViewHolder holder, StatusViewHolder holder,
RecyclerView.Adapter<RecyclerView.ViewHolder> adapter, RecyclerView.Adapter<RecyclerView.ViewHolder> adapter,
int mediaPosition, float mediaH, float ratio, int mediaPosition, float viewWidth, float mediaH, float ratio,
Status statusToDeal, Attachment attachment, boolean singleImage) { Status statusToDeal, Attachment attachment, boolean singleImage) {
SharedPreferences sharedpreferences = PreferenceManager.getDefaultSharedPreferences(context); SharedPreferences sharedpreferences = PreferenceManager.getDefaultSharedPreferences(context);
final int timeout = sharedpreferences.getInt(context.getString(R.string.SET_NSFW_TIMEOUT), 5); final int timeout = sharedpreferences.getInt(context.getString(R.string.SET_NSFW_TIMEOUT), 5);
@ -2037,6 +2037,7 @@ public class StatusAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder>
requestBuilder = requestBuilder.apply(new RequestOptions().transform(new GlideFocus(focusX, focusY))); requestBuilder = requestBuilder.apply(new RequestOptions().transform(new GlideFocus(focusX, focusY)));
} else { } else {
requestBuilder = requestBuilder.placeholder(R.color.transparent_grey); requestBuilder = requestBuilder.placeholder(R.color.transparent_grey);
requestBuilder = requestBuilder.apply(new RequestOptions().override((int) viewWidth, (int) mediaH));
requestBuilder = requestBuilder.fitCenter(); requestBuilder = requestBuilder.fitCenter();
} }
requestBuilder.into(layoutMediaBinding.media); requestBuilder.into(layoutMediaBinding.media);