我一直在开发应用程序。在构建我的应用程序时,我在logcat上收到onLayout时间过长的ANR警告。所以我的问题是究竟是什么问题?
ANR Warning]onLayout time too long, this =android.widget.FrameLayout{b7ebc83 V.E...... ......ID 0,0-720,1200 #7f0b005f app:id/content}time =651 ms
D/View: [ANR Warning]onLayout time too long, this =android.widget.LinearLayout{2b85e00 V.E...... ......ID 0,0-720,1200}time =652 ms
D/View: [ANR Warning]onLayout time too long, this =android.widget.FrameLayout{9243639 V.E...... ......ID 0,96-720,1296 #7f0b0065 app:id/view_content}time =652 ms
D/View: [ANR Warning]onLayout time too long, this =android.widget.LinearLayout{606a47e V.E...... ......ID 0,0-720,1296}time =654 ms
D/View: [ANR Warning]onLayout time too long, this =android.support.v7.widget.ContentFrameLayout{e669ddf V.E...... ......ID 0,0-720,1296 #1020002 android:id/content}time =654 ms
D/View: [ANR Warning]onLayout time too long, this =android.support.v7.widget.FitWindowsLinearLayout{f455a2c V.E...... ......ID 0,0-720,1296 #7f0b004b app:id/action_bar_root}time =655 ms
D/View: [ANR Warning]onLayout time too long, this =android.widget.FrameLayout{c08fcf5 V.E...... ......ID 0,48-720,1344}time =655 ms
D/View: [ANR Warning]onLayout time too long, this =android.widget.LinearLayout{7648a8a V.E...... ......ID 0,0-720,1344}time =656 ms
D/View: [ANR Warning]onLayout time too long, this =DecorView@23d1963[MainActivity]time =656 ms
这是我的应用程序布局文件,遇到上述问题
fragment_video_browser.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/fragment_video"
android:layout_width="match_parent"
android:layout_height="fill_parent"
android:orientation="vertical">
<android.support.v7.widget.RecyclerView
android:id="@+id/recycler_view1_video"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scrollbars="vertical" />
<!--/>-->
<!--android:background="@color/novided_bg"-->
</LinearLayout>
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/content"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"/>
activity_title_base.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="@dimen/toolbar_height"
android:background="?attr/colorPrimary"
android:fitsSystemWindows="true"
app:contentInsetEnd="0dp"
app:contentInsetStart="0dp">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="@dimen/toolbar_height"
android:gravity="center_vertical"
android:orientation="horizontal">
<ImageView
android:id="@+id/back"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/toolbar_backmenu_margin_start"
android:background="?android:attr/actionBarItemBackground"
android:clickable="true"
android:src="@mipmap/back"
android:visibility="invisible" />
<TextView
android:id="@+id/title_text"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:lines="1"
android:textColor="@color/toolbar_title_color"
android:textDirection="locale"
android:textSize="@dimen/toolbar_title_size" />
<ImageView
android:id="@+id/menu"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_marginEnd="@dimen/toolbar_menu_marginend"
android:background="?android:attr/actionBarItemBackground"
android:clickable="true"
android:paddingEnd="@dimen/toolbar_menu_padding"
android:paddingStart="@dimen/toolbar_menu_padding"
android:src="@drawable/ic_more"
android:visibility="gone"/>
<ImageView
android:id="@+id/edit"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_marginEnd="@dimen/toolbar_menu_marginend"
android:background="?android:attr/actionBarItemBackground"
android:clickable="true"
android:paddingEnd="@dimen/toolbar_menu_padding"
android:paddingStart="@dimen/toolbar_menu_padding"
android:src="@drawable/ic_btn_edit"
android:visibility="gone" />
<TextView
android:id="@+id/all_select"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginEnd="@dimen/toolbar_selectall_margin_end"
android:background="?android:attr/selectableItemBackgroundBorderless"
android:textColor="@color/toolbar_selectall_color"
android:textDirection="locale"
android:textSize="@dimen/toolbar_selectall_textsize"
android:visibility="gone" />
</LinearLayout>
</android.support.v7.widget.Toolbar>
<FrameLayout
android:id="@+id/view_content"
android:layout_width="fill_parent"
android:layout_height="0dp"
android:layout_weight="1"/>
</LinearLayout>
fragment.java
public class VideoBrowserFragment extends BaseFragment implements LoaderManager.LoaderCallbacks<Cursor>,
VideoBrowserAdapter.OnRecyclerViewItemClickListener,
VideoBrowserAdapter.OnItemLongClickListener,
EditionMode.OnEditionModeListener {
public final static String TAG = "Video/VideoBrowserFragment";
private int defaultSort = MediaInfoComparator.SORT_BY_NAME;
protected VideoBrowserAdapter mAdapter;
private VideoBrowserData videoMedia;
private View view;
private String bucketID;
private String bucketName;
private UiHanlder uiHanlder = new UiHanlder();
private class UiHanlder extends Handler {
@Override
public void handleMessage(final Message msg) {
((BaseActivity) getActivity()).onBackPressed();
}
}
@Override
public boolean onBackPressed() {
if (editionMode != null) {
if (editionMode.inEdionModle) {
editionMode.leaveEdition();
if (videoMedia != null && videoMedia.videoArrayList.size() == 0) {
return false;
} else {
return true;
}
}
} else {
this.onDestroy();
}
return false;
}
@Override
public boolean inEditModel() {
if (editionMode == null) {
return false;
}
if (editionMode.inEdionModle) {
if (editionMode.selectionManager.getCheckedItemsCount() == mAdapter.getItemCount()) {
editionMode.allNotSelect();
} else {
editionMode.allSelect((ArrayList<VideoInfoBean>) videoMedia.videoArrayList.clone());
}
} else {
editionMode.inEdition();
}
return false;
}
@Override
public boolean sortByType(int type) {
if (videoMedia == null) {
return false;
}
sortData(type);
defaultSort = type;
return false;
}
private void sortData(int type) {
Collections.sort(videoMedia.videoArrayList, MediaInfoComparator.getInstance(type));
mAdapter.setData(videoMedia.videoArrayList);
}
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Bundle bundle = getArguments();
if (bundle != null) {
bucketID = bundle.getString(FileBrowserFragment.BUCKETID);
bucketName = bundle.getString(FileBrowserFragment.BUCKETNAME);
}
}
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
Log.d("MY_LOG", "vdo FRAGMENT started");
super.onCreateView(inflater, container, savedInstanceState);
view = inflater.inflate(R.layout.fragment_video_browser, container, false);
init();
Log.d("MY_LOG", "vdo FRAGMENT ended");
return view;
}
private void init() {
((BaseActivity) getActivity()).setTitleText(bucketName);
((BaseActivity) getActivity()).setBackVisible();
((BaseActivity) getActivity()).setAllSelectVisible(View.GONE);
((BaseActivity) getActivity()).setEditVisible(View.GONE);
((BaseActivity) getActivity()).setMenuVisible(View.VISIBLE);
RecyclerView.LayoutManager layoutManager = new LinearLayoutManager(this.getContext());
layoutManager.setAutoMeasureEnabled(false);
mRecyclerView = (RecyclerView) view.findViewById(R.id.recycler_view1_video);
mRecyclerView.setHasFixedSize(true);
mRecyclerView.setItemViewCacheSize(20);
mRecyclerView.setDrawingCacheEnabled(true);
mRecyclerView.setDrawingCacheBackgroundColor(View.DRAWING_CACHE_QUALITY_HIGH);
mRecyclerView.setLayoutManager(layoutManager);
mAdapter = new VideoBrowserAdapter(this.getContext());
mAdapter.mThumbnailCache = new ThumbnailCache(getContext());
mRecyclerView.setAdapter(mAdapter);
// mRecyclerView.addItemDecoration(new DividerItemDecoration(getContext(), DividerItemDecoration.VERTICAL_LIST));
// mRecyclerView.setItemAnimator(new DefaultItemAnimator());
mAdapter.setOnItemClickListener(this);
mAdapter.setOnItemClickLongListener(this);
getLoaderManager().initLoader(1, null, this);
editionMode = new EditionMode(this, (BaseVideoActivity) this.getActivity(), mAdapter, getContext(), view, R.id.fragment_video);
editionMode.setOnEditionModeListener(this);
mAdapter.mActionMode = editionMode;
mAdapter.mThumbnailCache.addListener(mAdapter);
}
@Override
public Loader<Cursor> onCreateLoader(int id, Bundle args) {
videoMedia = new VideoBrowserData(this.getContext());
return videoMedia.getCursorLoader(bucketID);
}
@Override
public void onLoadFinished(Loader<Cursor> loader, Cursor data) {
if (videoMedia == null) {
videoMedia = new VideoBrowserData(this.getContext());
}
if (data != null && videoMedia != null) {
videoMedia.queryAllVideo(data);
setPlayInfo();
sortData(defaultSort);
if (editionMode.inEdionModle) {
editionMode.refreshCheckedItem((ArrayList<VideoInfoBean>) videoMedia.videoArrayList.clone());
editionMode.updateAllSize();
}
if (videoMedia.videoArrayList.size() == 0) {
uiHanlder.sendEmptyMessage(0);
}
}
}
@Override
public void onLoaderReset(Loader<Cursor> loader) {
}
@Override
public void onResume() {
super.onResume();
if (videoMedia == null) {
getLoaderManager().restartLoader(0, null, this);
return;
}
setPlayInfo();
mAdapter.notifyDataSetChanged();
}
@Override
public void onDestroy() {
Log.d("onDestroy", "onDestroy");
if (mAdapter != null) {
mAdapter.clearCachedHolder();
if (mAdapter.mThumbnailCache != null) {
mAdapter.mThumbnailCache.clear();
mAdapter.mThumbnailCache = null;
}
}
getLoaderManager().destroyLoader(1);
super.onDestroy();
}
@Override
public void onItemClick(View view, RecyclerView.ViewHolder data) {
Log.i(TAG, "onItemClick video : inEdionModle:" + editionMode.inEdionModle);
final Object obj = view.getTag();
int index = 0;
if (obj == null || !(obj instanceof RecyclerView.ViewHolder)) {
return;
}
if (editionMode.inEdionModle) {
editionMode.select((VideoBrowserAdapter.VideoViewHolder) obj);
} else {
for (int i = 0; i < videoMedia.videoArrayList.size(); i++) {
if (((BaseAdapter.VideoViewHolder) data).mId == videoMedia.videoArrayList.get(i).mediaID) {
index = i;
break;
}
}
VideoActivity.startPlayVideoList(getActivity(), index, videoMedia.videoArrayList);
}
}
@Override
public void onItemLongClick(View view, RecyclerView.ViewHolder data) {
final Object obj = view.getTag();
if (obj == null || !(obj instanceof RecyclerView.ViewHolder)) {
return;
}
editionMode.inEditionSelect((VideoBrowserAdapter.VideoViewHolder) obj);
}
public void setPlayInfo() {
for (int i = 0; i < videoMedia.videoArrayList.size(); i++) {
VideoInfoBean videoInfoBean = videoMedia.videoArrayList.get(i);
float index = VideoActivity.getLastPlayedVidePosition(videoInfoBean.mediaPath);
if (index == 0.0) {
videoInfoBean.playIndex = null;
} else {
videoInfoBean.playIndex = Utils.getIndex(index);
}
if (VideoActivity.getLastPlayedVideo() != null) {
if (VideoActivity.getLastPlayedVideo().equals(String.valueOf(videoInfoBean.mediaPath))) {
videoInfoBean.isLastPlay = true;
} else {
videoInfoBean.isLastPlay = false;
}
}
}
}
@Override
public int getAllSize() {
return videoMedia.videoArrayList.size();
}
}
编辑:将回收器视图的布局高度降低到300dp时,我没有收到警告。