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

Android ListView常用小技巧匯總

 更新時(shí)間:2016年03月23日 15:38:52   作者:BetterLaterThanNever  
這篇文章為大家詳細(xì)介紹了Android ListView常用小技巧,幫助大家更好的開發(fā)Android項(xiàng)目,感興趣的小伙伴們可以參考一下

ListView在我們Android項(xiàng)目中的地位是有目共睹的,相信幾乎每一個(gè)App中都有它的身影。
ListView主要是用列表形式來加載數(shù)據(jù),在特定情況下需要實(shí)現(xiàn)一些特殊功能:如刷新數(shù)據(jù),加載數(shù)據(jù),實(shí)現(xiàn)動(dòng)畫效果等。
作為我們常用的控件,有哪些需要注意的呢?
**為L(zhǎng)istView的每一Item設(shè)置分隔線

第一種方法:也是最簡(jiǎn)單地方法,在布局文件中設(shè)置ListView的
divider屬性
如:android:divider=”@color/black”
第二種方法:設(shè)置android:divider=”@null”表示不要分隔線,然后,自己在Item布局中添加分隔線。

 <ListView>
    android:id="@+id/test_lv"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:divider="#d1d1d1"<!--設(shè)置分隔線顏色-->
    android:dividerHeight="1px"<!--設(shè)置分隔線高度-->
    >
 </ListView>

** 默認(rèn)情況下,ListView的item有點(diǎn)擊效果,怎么樣改變這種效果呢?
設(shè)置ListViewr的android:listSelector屬性,比如可以設(shè)置透明取消這種效果android:listSelector=”@android:color/transparent”
也可以設(shè)置自己想要的效果,添加對(duì)應(yīng)的color資源或drawble資源 就可以了。
** 當(dāng)數(shù)據(jù)比較多的時(shí)候,ListView在滾動(dòng)時(shí)候會(huì)顯示一個(gè)默認(rèn)的滾動(dòng)條,要取消這個(gè)滾動(dòng)條的話,可以設(shè)置android:scrollbars屬性
如:android:scrollbars=”none”
** ListView性能優(yōu)化,必用ViewHolder來充分發(fā)揮ListView的recycle機(jī)制
** ListView中數(shù)據(jù)動(dòng)態(tài)變化,添加或刪除數(shù)據(jù)操作,效果顯而易見。

//實(shí)現(xiàn)ListView數(shù)據(jù)添加刪除
public class MainActivity extends Activity implements View.OnClickListener {
  private ListView test_lv;
  private List<TestBean> dataList;
  private TestAdapter adapter;
  private Button add_btn, del_btn;
  private ImageView emptyIv;
  private LinearLayout operator_ll;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    initDatas();
    initViews();

  }

  private void initDatas() {
    dataList = new ArrayList<>();
    for (int i = 0; i < 5; i++) {
      TestBean bean = new TestBean();
      bean.setTitle("標(biāo)題_" + i);
      bean.setContent("這是內(nèi)容_" + i);
      bean.setType(i % 2 == 0 ? 1 : 2);
      dataList.add(bean);
    }
  }

  private void initViews() {
    this.test_lv = (ListView) findViewById(R.id.test_lv);
    this.add_btn = (Button) findViewById(R.id.add_btn);
    this.del_btn = (Button) findViewById(R.id.del_btn);
    emptyIv = (ImageView) findViewById(R.id.empty_iv);
    operator_ll=(LinearLayout)findViewById(R.id.operator_ll);
    this.add_btn.setOnClickListener(this);
    this.del_btn.setOnClickListener(this);
    if (dataList.size() == 0) {
      emptyIv.setVisibility(View.VISIBLE);
      operator_ll.setVisibility(View.GONE);
      test_lv.setEmptyView(emptyIv);
    } else {
      emptyIv.setVisibility(View.GONE);
      operator_ll.setVisibility(View.VISIBLE);
      adapter = new TestAdapter(this, dataList);
      test_lv.setAdapter(adapter);
    }
    test_lv.setSelection(15);
  }

  @Override
  public void onClick(View v) {
    switch (v.getId()) {
      case R.id.add_btn:
        //默認(rèn)增加在第一個(gè)位置
        TestBean bean = new TestBean();
        bean.setTitle("增加項(xiàng)");
        bean.setContent("這是增加內(nèi)容");
        bean.setType(1);
        dataList.add(0, bean);
        break;
      case R.id.del_btn:
        //默認(rèn)刪除第一條數(shù)據(jù)
        dataList.remove(0);
        break;
    }
    adapter.notifyDataSetChanged();//刷新ListView數(shù)據(jù)
  }
}
//ListView對(duì)應(yīng)Adapter
public class TestAdapter extends BaseAdapter {
  private Context mContext;
  private List<TestBean> listDatas;

  public TestAdapter(Context mContext, List<TestBean> listDatas) {
    this.mContext = mContext;
    this.listDatas = listDatas;
  }

  @Override
  public int getCount() {
    return listDatas.size();
  }

  @Override
  public Object getItem(int position) {
    return listDatas.get(position);
  }

  @Override
  public long getItemId(int position) {
    return position;
  }

  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
    ViewHolder holder = null;
    if (convertView == null) {
      holder = new ViewHolder();
      convertView = LayoutInflater.from(mContext).inflate(R.layout.test_item, null);
      holder.title = (TextView) convertView.findViewById(R.id.item_title);
      holder.content = (TextView) convertView.findViewById(R.id.item_content);
      convertView.setTag(holder);
    } else {
      holder = (ViewHolder) convertView.getTag();
    }
    holder.content.setText(listDatas.get(position).getContent());
    holder.title.setText(listDatas.get(position).getTitle());
    return convertView;
  }

  final class ViewHolder {
    TextView title;
    TextView content;
  }
}

** 類似聊天界面,ListView中有多種item樣式效果

//實(shí)現(xiàn)ListView中多種item樣式
public class TypeActivity extends Activity {
  private ListView type_lv;
  private List<TestBean> dataList;
  private TypeAdapter adapter;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_type);
    initDatas();
    initViews();

  }

  private void initDatas() {
    dataList = new ArrayList<>();
    for (int i = 0; i < 9; i++) {
      TestBean bean = new TestBean();
      bean.setTitle("標(biāo)題_" + i);
      bean.setContent("這是內(nèi)容_" + i);
      bean.setType(i % 2 == 0 ? 1 : 2);
      dataList.add(bean);
    }
  }

  private void initViews() {
    this.type_lv = (ListView) findViewById(R.id.type_lv);
    adapter = new TypeAdapter(this, dataList);
    type_lv.setAdapter(adapter);

  }
}
//對(duì)應(yīng)Adapter
public class TypeAdapter extends BaseAdapter {
  private Context mContext;
  private List<TestBean> listDatas;

  public TypeAdapter(Context mContext, List<TestBean> listDatas) {
    this.mContext = mContext;
    this.listDatas = listDatas;
  }

  @Override
  public int getCount() {
    return listDatas.size();
  }

  @Override
  public Object getItem(int position) {
    return listDatas.get(position);
  }

  @Override
  public long getItemId(int position) {
    return position;
  }

  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
    ViewHolder holder = null;
    //根據(jù)樣式設(shè)置不同的布局及數(shù)據(jù)展示
    int type = getItemViewType(position);
    if (convertView == null) {
      holder = new ViewHolder();
      if (type == 1) {
        convertView = LayoutInflater.from(mContext).inflate(R.layout.test_item, null);
        holder.title = (TextView) convertView.findViewById(R.id.item_title);
        holder.content = (TextView) convertView.findViewById(R.id.item_content);
      } else {
        convertView = LayoutInflater.from(mContext).inflate(R.layout.type_item, null);
        holder.title = (TextView) convertView.findViewById(R.id.type_title);
        holder.content = (TextView) convertView.findViewById(R.id.type_title);
      }
      convertView.setTag(holder);
    } else {
      holder = (ViewHolder) convertView.getTag();
    }
    holder.content.setText(listDatas.get(position).getContent());
    holder.title.setText(listDatas.get(position).getTitle());
    return convertView;
  }
//關(guān)鍵方法之getViewTypeCount:獲取有多少種樣式
  @Override
  public int getViewTypeCount() {
    return 2;
  }
//關(guān)鍵方法之getItemViewType:獲取item類型
  @Override
  public int getItemViewType(int position) {
    return listDatas.get(position).getType();
  }

  final class ViewHolder {
    TextView title;
    TextView content;
  }
}

相關(guān)布局

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:orientation="vertical">

  <LinearLayout
    android:id="@+id/operator_ll"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="horizontal">

    <Button
      android:id="@+id/add_btn"
      android:layout_width="0dp"
      android:layout_height="wrap_content"
      android:layout_weight="1"
      android:gravity="center"
      android:text="添加" />

    <Button
      android:id="@+id/del_btn"
      android:layout_width="0dp"
      android:layout_height="wrap_content"
      android:layout_weight="1"
      android:gravity="center"
      android:text="刪除" />
  </LinearLayout>

  <ListView
    android:id="@+id/test_lv"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:divider="#d1d1d1"<!--分隔線顏色-->
    android:dividerHeight="1px"<!--分隔線高度-->
    android:listSelector="@android:color/transparent"<!--取消默認(rèn)點(diǎn)擊效果-->
    android:scrollbars="none"><!--隱藏滾動(dòng)條-->
    </ListView>

  <ImageView
    android:id="@+id/empty_iv"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="center"
    android:layout_marginTop="100dp"
    android:src="@mipmap/empty"
    android:visibility="gone" />

</LinearLayout>

activity_type.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:orientation="vertical">


  <ListView
    android:id="@+id/type_lv"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    ></ListView>


</LinearLayout>

test_item.xml

<?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="vertical"
 android:paddingLeft="15dp"
 android:layout_marginTop="5dp"
 android:layout_marginBottom="5dp">

 <TextView
  android:id="@+id/item_title"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:text="Hello World!" />

 <TextView
  android:id="@+id/item_content"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:layout_marginTop="5dp"
  android:text="Hello World!" />
</LinearLayout>

以上就是搜集的Android ListView常用小技巧全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。

相關(guān)文章

  • Android使用Notification實(shí)現(xiàn)通知功能

    Android使用Notification實(shí)現(xiàn)通知功能

    這篇文章主要為大家詳細(xì)介紹了Android使用Notification實(shí)現(xiàn)通知功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • Android自定義view實(shí)現(xiàn)圓形與半圓形菜單

    Android自定義view實(shí)現(xiàn)圓形與半圓形菜單

    這篇文章主要介紹了Android自定義view實(shí)現(xiàn)圓形與半圓形菜單的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • Android實(shí)現(xiàn)淘寶倒計(jì)時(shí)功能

    Android實(shí)現(xiàn)淘寶倒計(jì)時(shí)功能

    這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)淘寶倒計(jì)時(shí),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-02-02
  • Android如何讀寫CSV文件方法示例

    Android如何讀寫CSV文件方法示例

    CSV 文件是Excel 的標(biāo)準(zhǔn)文件格式,在開發(fā)過程中經(jīng)常需要格式化輸出數(shù)據(jù)。CSV 的格式非常簡(jiǎn)單,都是一行一行存儲(chǔ)的,同一行不同列之間用逗號(hào)隔開。下面這篇文章主要給大家介紹了關(guān)于Android如何讀寫CSV文件的相關(guān)資料,需要的朋友可以參考下。
    2017-08-08
  • Android+Html5混合開發(fā)仿微信朋友圈

    Android+Html5混合開發(fā)仿微信朋友圈

    這篇文章主要為大家詳細(xì)介紹了Android+Html5混合開發(fā)仿微信朋友圈的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • Android 使用<layer-list>實(shí)現(xiàn)微信聊天輸入框功能

    Android 使用<layer-list>實(shí)現(xiàn)微信聊天輸入框功能

    <layer-list> 標(biāo)簽可以設(shè)置LayerDrawable,一種有層次的Drawable疊加效果,<layer-list> 可以包含多個(gè) <item>標(biāo)簽。這篇文章主要介紹了Android 使用<layer-list>實(shí)現(xiàn)微信聊天輸入框,需要的朋友可以參考下
    2017-05-05
  • Android 混淆代碼詳解及實(shí)例

    Android 混淆代碼詳解及實(shí)例

    本文主要介紹Android 混淆代碼的資料,這里整理了詳細(xì)資料及代碼實(shí)例,有需要做Android 混淆代碼的朋友可以參考下
    2016-09-09
  • Android 的Bitmap的修改方法

    Android 的Bitmap的修改方法

    Android 的Bitmap的修改方法,需要的朋友可以參考一下
    2013-05-05
  • Android自定義UI手勢(shì)密碼改進(jìn)版

    Android自定義UI手勢(shì)密碼改進(jìn)版

    這篇文章主要為大家詳細(xì)介紹了改進(jìn)版的Android自定義UI手勢(shì)密碼功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • Android藍(lán)牙開發(fā)深入解析

    Android藍(lán)牙開發(fā)深入解析

    由于近期正在開發(fā)一個(gè)通過藍(lán)牙進(jìn)行數(shù)據(jù)傳遞的模塊,在參考了有關(guān)資料,并詳細(xì)閱讀了Android的官方文檔后,總結(jié)了Android中藍(lán)牙模塊的使用
    2013-10-10

最新評(píng)論