欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android列表組件ListView使用詳解之動態(tài)加載或修改列表數(shù)據(jù)

 更新時間:2019年03月28日 10:29:43   作者:Karen Chia  
今天小編就為大家分享一篇關(guān)于Android列表組件ListView使用詳解之動態(tài)加載或修改列表數(shù)據(jù),小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧

在使用ListView組件來顯示列表數(shù)據(jù)時,有的時候我們需要改變列表中的數(shù)據(jù),有以下方法:

1、重新給ListView組件設置適配器

這種方法重新創(chuàng)建了ListView,效率不好。

2、使用適配器中的方法

/**
   * Notifies the attached observers that the underlying data has been changed
   * and any View reflecting the data set should refresh itself.
   */
  public void notifyDataSetChanged() {
    mDataSetObservable.notifyChanged();
  }

這種方法旨在告知適配器,ListView中的數(shù)據(jù)源發(fā)生變化,需要重新加載新的數(shù)據(jù),不會重新創(chuàng)建ListView。使用此方法時,需要確保使用的是同一數(shù)據(jù)存儲對象,只是存儲對象中的值發(fā)生變化,才能使改動生效。關(guān)鍵代碼如下:

listViewDemoAdapter.notifyDataSetChanged();

效果圖:

當前界面顯示的代碼:

package net.oschina.git.zhaikun.androiddeveloped.activitys;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.Button;
import android.widget.ListView;
import net.oschina.git.zhaikun.androiddeveloped.R;
import net.oschina.git.zhaikun.androiddeveloped.adapter.ListViewDemoAdapter;
import java.util.ArrayList;
import java.util.List;
/**
 * Created by zhaikun68 on 2018/3/5.
 * <p>
 * ListView演示Demo
 */
public class ListViewDemoActivity extends AppCompatActivity implements View.OnClickListener {
  private ListView testLv;//ListView組件
  private Button updateDataBtn;//動態(tài)加載數(shù)據(jù)組件
  private List<String> dataList = new ArrayList<>();//存儲數(shù)據(jù)
  private ListViewDemoAdapter listViewDemoAdapter;//ListView的數(shù)據(jù)適配器
  @Override
  protected void onCreate(@Nullable Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_listview_demo);
    initView();//初始化組件
    initData();//初始化數(shù)據(jù)
  }
  /**
   * 初始化組件
   */
  private void initView() {
    testLv = (ListView) findViewById(R.id.test_lv);
    updateDataBtn = (Button) findViewById(R.id.update_data_btn);
    updateDataBtn.setOnClickListener(this);
  }
  /**
   * 初始化數(shù)據(jù)
   */
  private void initData() {
    //初始化10項數(shù)據(jù)
    for (int i = 1; i <= 20; i++) {
      dataList.add("顯示內(nèi)容" + i);
    }
    //設置ListView的適配器
    listViewDemoAdapter = new ListViewDemoAdapter(this, dataList);
    testLv.setAdapter(listViewDemoAdapter);
    testLv.setSelection(4);
  }
  @Override
  public void onClick(View v) {
    switch (v.getId()) {
      case R.id.update_data_btn://動態(tài)加載列表數(shù)據(jù)
        dataList.add("動態(tài)加載的數(shù)據(jù)項");
        //通知ListView更改數(shù)據(jù)源
        if (listViewDemoAdapter != null) {
          listViewDemoAdapter.notifyDataSetChanged();
          testLv.setSelection(dataList.size() - 1);//設置顯示列表的最后一項
        } else {
          listViewDemoAdapter = new ListViewDemoAdapter(this, dataList);
          testLv.setAdapter(listViewDemoAdapter);
          testLv.setSelection(dataList.size() - 1);
        }
        break;
    }
  }
}

界面布局文件:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
  <Button
    android:id="@+id/update_data_btn"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:layout_margin="10dp"
    android:text="動態(tài)加載數(shù)據(jù)"/>
  <ListView
    android:id="@+id/test_lv"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_above="@id/update_data_btn"
    android:divider="@color/colorPrimaryDark"
    android:dividerHeight="3dp"
    android:listSelector="#ff0000"
    android:scrollbars="none"/>
</RelativeLayout>

適配器代碼:

package net.oschina.git.zhaikun.androiddeveloped.adapter;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;
import net.oschina.git.zhaikun.androiddeveloped.R;
import java.util.List;
/**
 * Created by zhaikun68 on 2018/3/5.
 * <p>
 * ListView演示Demo中的數(shù)據(jù)適配器
 */
public class ListViewDemoAdapter extends BaseAdapter {
  private Context context;//上下文對象
  private List<String> dataList;//ListView顯示的數(shù)據(jù)
  /**
   * 構(gòu)造器
   *
   * @param context 上下文對象
   * @param dataList 數(shù)據(jù)
   */
  public ListViewDemoAdapter(Context context, List<String> dataList) {
    this.context = context;
    this.dataList = dataList;
  }
  @Override
  public int getCount() {
    return dataList == null ? 0 : dataList.size();
  }
  @Override
  public Object getItem(int position) {
    return dataList.get(position);
  }
  @Override
  public long getItemId(int position) {
    return position;
  }
  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
    ViewHolder viewHolder;
    //判斷是否有緩存
    if (convertView == null) {
      convertView = LayoutInflater.from(context).inflate(R.layout.item_listview_demo, null);
      viewHolder = new ViewHolder(convertView);
      convertView.setTag(viewHolder);
    } else {
      //得到緩存的布局
      viewHolder = (ViewHolder) convertView.getTag();
    }
    //設置圖片
    viewHolder.pictureImg.setImageResource(R.mipmap.ic_launcher);
    //設置內(nèi)容
    viewHolder.contentTv.setText(dataList.get(position));
    return convertView;
  }
  /**
   * ViewHolder類
   */
  private final class ViewHolder {
    ImageView pictureImg;//圖片
    TextView contentTv;//內(nèi)容
    /**
     * 構(gòu)造器
     *
     * @param view 視圖組件(ListView的子項視圖)
     */
    ViewHolder(View view) {
      pictureImg = (ImageView) view.findViewById(R.id.picture_img);
      contentTv = (TextView) view.findViewById(R.id.content_tv);
    }
  }
}

列表子項的布局文件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
       android:layout_width="match_parent"
       android:layout_height="wrap_content"
       android:orientation="horizontal"
       android:padding="5dp">
  <ImageView
    android:id="@+id/picture_img"
    android:layout_width="30dp"
    android:layout_height="30dp"
    android:layout_marginRight="5dp"
    android:src="@mipmap/ic_launcher"/>
  <TextView
    android:id="@+id/content_tv"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="center_vertical"
    android:text="顯示內(nèi)容"/>
</LinearLayout>

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接

相關(guān)文章

最新評論