Android应用开发之(按需加载View)

有些情况下,您的界面中包含了一些复杂的但是不长使用的布局内容。例如 进度条、一条撤销操作的提示信息等,最明显的一个例子就是当用户第一次使用该应用程序的时候,显示一个帮助提示内容。您可以当需要显示这些内容的时候在载入这些布局内容,这样就可以减少内存使用并提高界面的渲染速度。

定义 ViewStub

ViewStub是一个轻量级的View,没有尺寸也不会绘制任何东西到屏幕上去。因此,去解析这个View是相当快的。每个ViewStub只需要指定 android:layout属性即可。

下面的 ViewStub是一个 半透明的进度条。只有当新的条目导入到程序中的时候才会显示这个进度条。

<ViewStub
    android:id="@+id/stub_import"
    android:inflatedId="@+id/panel_import"
    android:layout="@layout/progress_overlay"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:layout_gravity="bottom"/>

载入 ViewStub 布局

当需要载入由 ViewStub指定的布局的时候,可以通过调用函数 setVisibility(View.VISIBLE)或者通过调用函数 inflate()

((ViewStub) findViewById(R.id.stub_import)).setVisibility(View.VISIBLE); 
// 或者 
View importPanel = ((ViewStub) findViewById(R.id.stub_import)).inflate();

注意:inflate()函数返回解析后的 View,所以你没有必要在调用函数 findViewById()来得到这个View。

一旦可见或者解析(visible/inflated)后, 这个 ViewStub就不在界面层级结构中了,被锁引用的布局替代了,新的ID是 ViewStub的属性 android:inflatedId中设置的值。

注意:目前 ViewStub有个缺点就是还没有支持 <merge/>标签。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
RecyclerViewAndroid 开发中一个非常常用的控件,它可以高效地显示大量数据,并且支持各种布局和交互效果。而 SwipeToLoadLayout 则是一个实现下拉刷新和上拉加载更多的库,它可以和 RecyclerView 结合使用来实现更好的用户体验。 下面将介绍如何在 Android 应用开发中使用 RecyclerView 和 SwipeToLoadLayout。 1. 添加依赖 首先要在项目的 build.gradle 文件中添加以下依赖: ``` dependencies { implementation 'com.android.support:recyclerview-v7:28.0.0' implementation 'com.aspsine:swipetoloadlayout:1.2.0' } ``` 2. 布局文件 在布局文件中添加 SwipeToLoadLayout 和 RecyclerView 控件: ``` <com.aspsine.swipetoloadlayout.SwipeToLoadLayout android:id="@+id/swipeToLoadLayout" android:layout_width="match_parent" android:layout_height="match_parent"> <android.support.v7.widget.RecyclerView android:id="@+id/recyclerView" android:layout_width="match_parent" android:layout_height="match_parent" /> </com.aspsine.swipetoloadlayout.SwipeToLoadLayout> ``` 3. 初始化控件 在 Activity 或 Fragment 中初始化 SwipeToLoadLayout 和 RecyclerView 控件,并设置下拉刷新和上拉加载更多的监听器: ``` private SwipeToLoadLayout swipeToLoadLayout; private RecyclerView recyclerView; // 初始化控件 private void initViews() { swipeToLoadLayout = findViewById(R.id.swipeToLoadLayout); recyclerView = findViewById(R.id.recyclerView); // 设置下拉刷新和上拉加载更多的监听器 swipeToLoadLayout.setOnRefreshListener(new OnRefreshListener() { @Override public void onRefresh() { // 执行下拉刷新操作 } }); swipeToLoadLayout.setOnLoadMoreListener(new OnLoadMoreListener() { @Override public void onLoadMore() { // 执行上拉加载更多操作 } }); } ``` 4. 实现 RecyclerView.Adapter 在 RecyclerView 的 Adapter 中实现数据的绑定和显示: ``` public class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> { private List<String> mData; // 构造方法 public MyAdapter(List<String> data) { mData = data; } // 创建 ViewHolder @Override public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { View view = LayoutInflater.from(parent.getContext()) .inflate(R.layout.item_layout, parent, false); return new ViewHolder(view); } // 绑定数据到 ViewHolder @Override public void onBindViewHolder(ViewHolder holder, int position) { String data = mData.get(position); holder.textView.setText(data); } // 获取数据数量 @Override public int getItemCount() { return mData.size(); } // ViewHolder 类 static class ViewHolder extends RecyclerView.ViewHolder { TextView textView; ViewHolder(View itemView) { super(itemView); textView = itemView.findViewById(R.id.textView); } } } ``` 5. 加载数据 在 Activity 或 Fragment 中加载数据,然后将数据设置给 RecyclerView 的 Adapter: ``` private List<String> mData = new ArrayList<>(); private MyAdapter mAdapter; // 加载数据 private void loadData() { // 模拟加载数据 for (int i = 0; i < 20; i++) { mData.add("Item " + (i + 1)); } // 设置数据到 RecyclerView 的 Adapter mAdapter = new MyAdapter(mData); recyclerView.setAdapter(mAdapter); } ``` 6. 刷新数据 在下拉刷新的监听器中执行刷新操作,并将数据设置给 RecyclerView 的 Adapter: ``` // 下拉刷新监听器 swipeToLoadLayout.setOnRefreshListener(new OnRefreshListener() { @Override public void onRefresh() { // 模拟刷新数据 mData.clear(); for (int i = 0; i < 20; i++) { mData.add("Refreshed Item " + (i + 1)); } // 设置数据到 RecyclerView 的 Adapter mAdapter = new MyAdapter(mData); recyclerView.setAdapter(mAdapter); // 停止下拉刷新动画 swipeToLoadLayout.setRefreshing(false); } }); ``` 7. 加载更多数据 在上拉加载更多的监听器中执行加载更多操作,并将新数据添加到 RecyclerView 的 Adapter: ``` // 上拉加载更多监听器 swipeToLoadLayout.setOnLoadMoreListener(new OnLoadMoreListener() { @Override public void onLoadMore() { // 模拟加载更多数据 int size = mData.size(); for (int i = size; i < size + 20; i++) { mData.add("Loaded Item " + (i + 1)); } // 添加新数据到 RecyclerView 的 Adapter mAdapter.notifyDataSetChanged(); // 停止上拉加载更多动画 swipeToLoadLayout.setLoadingMore(false); } }); ``` 这样就实现了 RecyclerView 和 SwipeToLoadLayout 的结合使用,可以实现下拉刷新和上拉加载更多的功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值