//---------------主要是适配器里面-------------------------------------

package com.bwie.test.adapter;

import java.net.ContentHandler;
import java.util.List;

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

import android.content.Context;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;

public class MyAdapter extends BaseAdapter{
    private List<News> news;
    private Context context;
    
     //定义样式常量,注意常量值要从0开始
    private static final int TYPE_LISTVIEW_NORMAL = 0;//有图片
    private static final int TYPE_LISTVIEW_NO_PIC = 1;//无图片

    

    public MyAdapter(List<News> news, Context context) {
        super();
        this.news = news;
        this.context = context;
    }

    @Override
    public int getCount() {
        // TODO Auto-generated method stub
        return news.size();
    }

    @Override
    public Object getItem(int position) {
        // TODO Auto-generated method stub
        return news.get(position);
    }

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

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

        return TYPE_LISTVIEW_NO_PIC;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        
        // 获取当前条目的类型
        int itemViewType = getItemViewType(position);

        ViewHolder holder;
        News newss=news.get(position);
        if (convertView==null) {            
            holder=new ViewHolder();            
            switch (itemViewType) {
            case TYPE_LISTVIEW_NORMAL:
                convertView=View.inflate(context, R.layout.list_item1, null);
                holder.iv=(ImageView) convertView.findViewById(R.id.iv);
                convertView.setTag(holder);
                break;
            case TYPE_LISTVIEW_NO_PIC:
                convertView=View.inflate(context, R.layout.list_item, null);
                convertView.setTag(holder);
                break;
            default:
                break;
            }
            holder.TITLE=(TextView) convertView.findViewById(R.id.tv_TITLE);
            holder.SUBTITLE=(TextView) convertView.findViewById(R.id.tv_SUBTITLE);
            holder.FROMNAME=(TextView) convertView.findViewById(R.id.tv_FROMNAME);
            holder.SHOWTIME=(TextView) convertView.findViewById(R.id.tv_SHOWTIME);
            
            
        }else{
            holder=(ViewHolder) convertView.getTag();
            switch (itemViewType) {
            case TYPE_LISTVIEW_NORMAL:
                ImageLoader.getInstance().init(ImageLoaderConfiguration.createDefault(context));
                DisplayImageOptions options=new DisplayImageOptions.Builder().cacheInMemory(true).cacheOnDisk(true).build();
                ImageLoader.getInstance().displayImage(newss.getIMAGEURL(), holder.iv, options);
                break;
                case TYPE_LISTVIEW_NO_PIC:
                    
                    break;

            default:
                break;
            }
        }
        
        holder.TITLE.setText(newss.getTITLE());
        holder.SUBTITLE.setText(newss.getSUBTITLE());
        holder.FROMNAME.setText(newss.getFROMNAME());
        holder.SHOWTIME.setText(newss.getSHOWTIME());
        
        
        return convertView;
    }
    static class ViewHolder{
        public TextView TITLE;
        public TextView SUBTITLE;
        public TextView FROMNAME;
        public TextView SHOWTIME;
        public ImageView iv;
    }

}

//--------------第一个Listview条目没有图片------------------------

<?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="match_parent"
    android:orientation="vertical" >
   
    <TextView android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:textSize="20sp"
        android:id="@+id/tv_TITLE"/>
    <TextView android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:id="@+id/tv_SUBTITLE"/>
    <LinearLayout android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal">
        <TextView android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/tv_FROMNAME"/>
        <TextView android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/tv_SHOWTIME"
            android:layout_marginLeft="20dp"/>
    </LinearLayout>
   
</LinearLayout>

//-----------------有图片的Listview布局----------------------------------

<?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="match_parent"
    android:orientation="vertical" >
    <LinearLayout android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal">
        <ImageView android:layout_width="80dp"
            android:layout_height="80dp"
            android:scaleType="fitXY"
            android:id="@+id/iv"/>
        <LinearLayout android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical">
            <TextView android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:textSize="20sp"
        android:id="@+id/tv_TITLE"/>
    <TextView android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:id="@+id/tv_SUBTITLE"/>
    <LinearLayout android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal">
        <TextView android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/tv_FROMNAME"/>
        <TextView android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/tv_SHOWTIME"
            android:layout_marginLeft="20dp"/>
    </LinearLayout>
        </LinearLayout>
    </LinearLayout>
    
   
</LinearLayout>

Listview多条目展示的更多相关文章

  1. Windows程序==>>使用ListView控件展示数据

    使用ListView控件展示数据 01.ImageList控件 1.了解了解         属性 说明 Images 储存在图像列表中的所有图像 ImageSize 图像列表中图像的大小 Trans ...

  2. ListView的条目点击焦点的问题

    由于ListView条目里有ImageButton,导致抢占了条目点击事件,所以在item的跟布局中加入 android:descendantFocusability="blocksDesc ...

  3. listview去掉条目间的分割线

    未去掉前: 去掉后: java代码可以这么写: 1          listView.setDivider(null);//去掉条目间的分割线 PS:ListView的几个常用操作 listView ...

  4. listview设置条目点击的时候不变色(让状态选择器不起作用)

    未设置前的效果如下图: 很明显,“酷狗音乐”那个条目被点击的时候,条目背景变为蓝色,怎么去掉这个颜色呢? java代码可以这么写: listView.setSelector(new ColorDraw ...

  5. React-Native基础_5.列表视图ListView 网络数据展示

    //获取网络数据 并用列表展示 豆瓣Top250 api /** * Sample React Native App * https://github.com/facebook/react-nativ ...

  6. 使用ListView控件展示数据

    属性名称    说明items   指定显示那种视图View   指定显示那种视图largelmagelist  大图标图像的imagelist控件SmallLmagelist  小图标图像的imag ...

  7. WinForm 之 使用ListView控件展示数据

    在学习了这么多的WinForm基本控件后,今天在来学习一个比较有意思的包含图片的控件! >>>图像列表控件 ImageList是含有图像对象的集合,可以通过索引或关键字引用该集合中的 ...

  8. Listview的条目item内的点击响应事件

    还是这张图 这里的历史列表就是一个ListView,抛开该界面中ScrollView或者RecycleView与该ListView会有冲突,所谓的冲突,说白了就是父控件与子控件两者间的关系冲突,该冲突 ...

  9. 实现listview的条目点击后改变背景颜色

    gv_categoryeffect_gridview.setChoiceMode(GridView.CHOICE_MODE_SINGLE);,再设置一个selector的背景选择器 getResour ...

随机推荐

  1. hdu2063 匈牙利算法 二分最大匹配模版题

    过山车 Time Limit: 1000 MS Memory Limit: 32768 KB 64-bit integer IO format: %I64d , %I64u Java class na ...

  2. 1bpp像素遍历(找了半天,感谢github)

    /// <summary> /// 获取比例 /// </summary> /// <param name="rect"></param& ...

  3. ADO.NET 数据访问类查询、属性扩展

    今天,我首先在之前所做的人员管理系统的基础上,利用数据访问类进行了所有人员信息的查询. 主程序代码: List<Users> Ulist = new UsersData().Select( ...

  4. 34.编写2个接口:InterfaceA和InterfaceB;在接口InterfaceA中有个方法void printCapitalLetter();在接口InterfaceB中有个方法void printLowercaseLetter();然 后写一个类Print实现接口InterfaceA和InterfaceB,要求printCapitalLetter()方法 实现输出大写英文字母表的功能,

    //接口InterfaceA package jieKou; public interface IInterfaceA { void printCapitalLetter(); } //接口Inter ...

  5. C# 在word文档中复制表格并粘帖到下一页中

    C# 在word文档中复制表格并粘帖到下一页中 object oMissing = System.Reflection.Missing.Value;            Microsoft.Offi ...

  6. Python笔记3-20151027

    函数的参数 Python的函数定义非常简单,但是灵活度却非常大.除了正常定义的必选参数外,还可以使用默认参数.可变参数和关键字参数,使得函数定义出来的接口,不但能处理复杂的参数,还可以简化调用者的代码 ...

  7. 利用Ajax实现前端与.net后端实现数据交互

    使用场景和需求:用户在地址栏输入请求地址,先.net服务器发送页面请求,该页面包含Echart图表,在页面中向.net后端发送数据请求,获取数据后,将数据填充到Echart图表中.其中包含带参与不带参 ...

  8. Redis4- llist的操作

    数据类型List链表(1)介绍list类型其实就是一个双向链表.通过push,pop操作从链表的头部或者尾部添加删除元素.这使得list既可以用作栈,也可以用作队列.该list链表类型应用场景:获得最 ...

  9. js常用API 数据类型 基本类型,基本包装类型,引用类型 Object String Array Boolean Number Date Math

    数据类型 变量.作用域及内存 基础类型(primitive value):Undefined.Null.Boolean.Number和String.这些类型在内存中分别占用固定大小的空间,他们的值保存 ...

  10. hosts etc css-js

    http://laod.cn http://tool.css-js.com/rgba.html