Android  ListView 条目多样式展示实例详解

ListView的多种样式条目展示

  • 这里给大家介绍一下简单的ListView的多种样式展示
  • 在布局文件中和往常一样写一个ListViwe的布局
 <ListView
    android:id="@+id/main_listview"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    />

其他的这里就不多说了,直接介绍适配器里的操作

package com.bwei.test.BaseAdapter;

import java.util.List;

import com.bwei.test.R;
import com.bwei.test.bean.News;
import com.nostra13.universalimageloader.core.DisplayImageOptions;
import com.nostra13.universalimageloader.core.ImageLoader;

import android.R.color;
import android.R.layout;
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;

public class MyBaseAdapter extends BaseAdapter {

  private Context context;
  private List<News> newlist;
  //ImageLoader
  private DisplayImageOptions Options;
  //定义样式常量,注意常量值要从0开始
  private static final int TYPE_LISTVIEW_NORMAL = 0;
  private static final int TYPE_LISTVIEW_NO_PIC = 1;

  public MyBaseAdapter(Context context, List<News> newlist,
      DisplayImageOptions options) {
    super();
    this.context = context;
    this.newlist = newlist;
    Options = options;
  }

  @Override
  public int getCount() {
    //ListView的总共条数
    return newlist.size();
  }

  @Override
  public Object getItem(int arg0) {
    // TODO Auto-generated method stub
    return null;
  }

  @Override
  public long getItemId(int arg0) {
    // TODO Auto-generated method stub
    return 0;
  }

  /*
   * 注意我们要填充的布局个数和我们要展示的样式个数一样
   * 最好一个样式一个填充布局
   *
   * */
  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
    // TODO Auto-generated method stub
    // 获取当前条目的类型
    int itemViewType = getItemViewType(position);
    ViewHolder viewHolder;
    if (convertView==null) {
      viewHolder=new ViewHolder();
      switch (itemViewType) {
      case TYPE_LISTVIEW_NORMAL:

        convertView=LayoutInflater.from(context).inflate(R.layout.title_pic, null);
        viewHolder.imageView=(ImageView) convertView.findViewById(R.id.imageView1);
        ImageLoader.getInstance().displayImage(newlist.get(position).getImgs(), viewHolder.imageView,Options);
        convertView.setTag(viewHolder);
        break;
      case TYPE_LISTVIEW_NO_PIC:
        convertView=LayoutInflater.from(context).inflate(R.layout.title, null);
        convertView.setTag(viewHolder);
        break;

      default:
        break;
      }

      viewHolder.textcopyright=(TextView) convertView.findViewById(R.id.copyright);
      viewHolder.texttime=(TextView) convertView.findViewById(R.id.data);
      viewHolder.texttitle=(TextView) convertView.findViewById(R.id.title);
  viewHolder.texttitle.setText(
      newlist.get(position).getTitle());
  viewHolder.texttime.setText(
      newlist.get(position).getPubDate());
  viewHolder.textcopyright.setText(
      newlist.get(position).getCopyright());

    } else {
      viewHolder=(ViewHolder) convertView.getTag();
      switch (itemViewType) {
      case TYPE_LISTVIEW_NORMAL:
ImageLoader.getInstance().displayImage(
       newlist.get(position).getImgs(),
             viewHolder.imageView,Options);

        break;
      case TYPE_LISTVIEW_NO_PIC:

        break;

      default:
        break;
      }
viewHolder.texttitle.setText(
      newlist.get(position).getTitle());

viewHolder.texttime.setText(
      newlist.get(position).getPubDate());
viewHolder.textcopyright.setText(
      newlist.get(position).getCopyright());
    }
    return convertView;
  }

  /**
   * 获取具体的某个索引值下的条目的条目类型
   */
  @Override
  public int getItemViewType(int position) {
    // TODO Auto-generated method stub
    //判断以什么结束的属性
    if ( newlist.get(position).getImgs().endsWith(".jpg")) {
      return TYPE_LISTVIEW_NORMAL;
    }

    return TYPE_LISTVIEW_NO_PIC;
  }

  /**
   * 获取listView条目类别的个数(样式)
   */
  @Override
  public int getViewTypeCount() {
    // TODO Auto-generated method stub
    return 2;
  }
  //容器
  class ViewHolder{

      ImageView imageView;
      TextView texttitle,textcopyright,texttime;

}

}

以上是多条目样式展示的一种

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

(0)

相关推荐

  • Android条目拖拽删除功能实例代码

    项目中需求,要做条目条目拖拽删除效果,实际效果和QQ消息删除一样,侧滑有制定和删除. 效果图 第一步效果图 1.0自定义控件 SwipeLayout 继承FrameLayout重写里面三个构造方法,分别调用initView(). 2.0在布局中使用自定义控件 3.0在initView()方法中,创建拖拽辅辅助工具 ViewDragHelper() 该方法需要传入回调 MyCallBack() 4.0,创建MyCallBack()回调,继承ViewDragHelper.Callback 在回调中

  • Android自定义SwipeLayout仿QQ侧滑条目

    Android自定义SwipeLayout仿QQ侧滑条目,供大家参考,具体内容如下 先看动图 看布局文件 activity_main.xml <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent

  • Android仿京东分类模块左侧分类条目效果

    本文实例为大家分享了Android仿京东左侧分类条目效果的具体代码,供大家参考,具体内容如下 import android.app.Activity; import android.os.Bundle; import android.view.View; import android.widget.LinearLayout; import android.widget.ScrollView; import android.widget.TextView; import com.frame.R;

  • 详解Android中实现ListView左右滑动删除条目的方法

    使用Scroller实现绚丽的ListView左右滑动删除Item效果 这里来给大家带来使用Scroller的小例子,同时也能用来帮助初步解除的读者更加熟悉的掌握Scroller的使用,掌握好了Scroller的使用我们就能实现很多滑动的效果.例如侧滑菜单,launcher,ListView的下拉刷新等等效果,我今天实现的是ListView的item的左右滑动删除item的效果,现在很多朋友看到这个效果应该是在Android的通知栏下拉中看到这个滑动删除的效果吧,我看到这个效果是在我之前的三星手

  • Android 中 SwipeLayout一个展示条目底层菜单的侧滑控件源码解析

    由于项目上的需要侧滑条目展示收藏按钮,记得之前代码家有写过一个厉害的开源控件 AndroidSwipeLayout 本来准备直接拿来使用,但是看过 issue 发现现在有不少使用者反应有不少的 bug ,而且代码家现在貌似也不进行维护了.故自己实现了一个所要效果的一个控件.因为只是实现我需要的效果,所以大家也能看到,代码里有不少地方我是写死的.希望对大家有些帮助.而且暂时也不需要 AndroidSwipeLayout 大而全的功能,算是变相给自己做的项目精简代码了. 完整示例代码请看:GitHu

  • Android更多条目收缩展开控件ExpandView的示例代码

    在Android开发中,我们经常使用列表控件,而有时候列表控件条目中又会是多条目数据,这时候,我们无法确定每个条目的数据多少,而为了美观,我们就希望条目统一高度,多数据的条目能够进行折叠.展开.今天,就为大家介绍一个这样的自定义控件 ExpandView. 效果演示图 演示图 Android Studio集成方式 dependencies{ compile 'com.wkp:ExpandView:1.0.4' //Android Studio3.0+可用以下方式 //implementation

  • Android编程实现canvas绘制饼状统计图功能示例【自动适应条目数量与大小】

    本文实例讲述了Android编程实现canvas绘制饼状统计图功能.分享给大家供大家参考,具体如下: 本例的目的是实现一个简单的饼状统计图,效果如下:    特点: 1.使用非常方便,可放在xml布局文件中,然后在代码中设置内容,即: PieChartView pieChartView = (PieChartView) findViewById(R.id.pie_chart); PieChartView.PieItemBean[] items = new PieChartView.PieItem

  • Android XRecyclerView实现多条目加载

    本文实例为大家分享了Android实现多条目加载展示的具体代码,供大家参考,具体内容如下 展示效果 这里写图片描述 依赖 testCompile 'junit:junit:4.12' compile 'com.hjm:BottomTabBar:1.1.1' compile 'com.android.support:design:23.4.0' compile 'com.android.support:mediarouter-v7:25.0.0' compile 'com.android.supp

  • Android RecyclerView实现点击条目删除

    本文实例为大家分享了RecyclerView实现点击条目删除的具体代码,供大家参考,具体内容如下 MainActivity.java public class MainActivity extends AppCompatActivity implements View.OnClickListener{ private Button mButton1; private Button mButton2; private Button mButton3; private Button mButton4

  • Android中RecyclerView上拉下拉,分割线,多条目的实例代码

    //activity的xml <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/activity

  • Android实现下拉展示条目效果

    本文实例为大家分享了Android下拉展示条目的具体代码,供大家参考,具体内容如下 布局文件 <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools"

  • Android ListView自动生成列表条目的实例

    activity_list.xml文件代码如下: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent

  • Android中listview和imageview实现条目单选效果

    前段时间在项目开发中,有listview实现单选和多选的效果,特别是listview的单选效果,一开始项目比较紧,自己考虑的是用listview和radionbutton实现的,可能是自己考虑不周到的原因,效果是实现了,但是用户体验不怎么好,做完项目后,自己又弄了下,使用listview和imageview实现,点击listview条目的时候就可以实现单选效果,这样用户体验就稍微好些.以下就是实现的方式: activity_main.xml文件: <RelativeLayout xmlns:an

  • android RecyclerView实现条目Item拖拽排序与滑动删除

    效果演示 需求和技术分析 RecyclerView Item拖拽排序::长按RecyclerView的Item或者触摸Item的某个按钮. RecyclerView Item滑动删除:RecyclerView Item滑动删除:RecyclerView的Item滑动删除. 实现方案与技术 利用ItemTouchHelper绑定RecyclerView.ItemTouchHelper.Callback来实现UI更新,并且实现动态控制是否开启拖拽功能和滑动删除功能. 实现步骤 继承抽象类ItemTo

随机推荐