Merge "Fix folder app icon truncation after rotating to landscape." into tm-dev am: af8b7d3313

Original change: https://googleplex-android-review.googlesource.com/c/platform/packages/apps/Launcher3/+/18090271

Change-Id: I44d1b4d98035645e7046a1d8846ef288ad4b6a4c
Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
Stefan Andonian
2022-05-24 18:25:18 +00:00
committed by Automerger Merge Worker
2 changed files with 15 additions and 4 deletions
+1
View File
@@ -37,4 +37,5 @@
<item type="id" name="quick_settings_button" />
<item type="id" name="notifications_button" />
<item type="id" name="cache_entry_tag_id" />
</resources>
+14 -4
View File
@@ -21,6 +21,8 @@ import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import com.android.launcher3.R;
/**
* Utility class to cache views at an activity level
*/
@@ -39,18 +41,26 @@ public class ViewCache {
mCache.put(layoutId, entry);
}
T result;
if (entry.mCurrentSize > 0) {
entry.mCurrentSize --;
T result = (T) entry.mViews[entry.mCurrentSize];
result = (T) entry.mViews[entry.mCurrentSize];
entry.mViews[entry.mCurrentSize] = null;
return result;
} else {
result = (T) LayoutInflater.from(context).inflate(layoutId, parent, false);
result.setTag(R.id.cache_entry_tag_id, entry);
}
return (T) LayoutInflater.from(context).inflate(layoutId, parent, false);
return result;
}
public void recycleView(int layoutId, View view) {
CacheEntry entry = mCache.get(layoutId);
if (entry != view.getTag(R.id.cache_entry_tag_id)) {
// Since this view was created, the cache has been reset. The view should not be
// recycled since this means the environment could also have changed, requiring new
// view setup.
return;
}
if (entry != null && entry.mCurrentSize < entry.mMaxSize) {
entry.mViews[entry.mCurrentSize] = view;
entry.mCurrentSize++;