这个界面  实现的不是微信对话界面。实现的是,focus的状态下,变为放大的另一种布局

重点:

一、定义类型个数

private final int TYPE_COUNT = 2;
    private final int FIRST_TYPE = 0;
    private final int OTHERS_TYPE = 1;

二、重写两个函数

 @Override
    public int getViewTypeCount() {
        return TYPE_COUNT;
    }

@Override
    public int getItemViewType(int position) {
        if (position == mSelectedPosition) {
            return FIRST_TYPE;
        } else {
            return OTHERS_TYPE;
        }
    }

public class CallContactListViewAdapter extends BaseAdapter {

public static final String TAG = CallContactListViewAdapter.class.getName();
    private final int TYPE_COUNT = 2;
    private final int BIG_TYPE = 0;
    private final int SMALL_TYPE = 1;
    private int currentType;

private List<ContactIndex> mContactList;
    private Context mContext;
    private LayoutInflater layoutInflater;
    private int mSelectedPosition = -1;

private Bitmap mBitmap = null;

// private Matrix mMatrix;

public CallContactListViewAdapter(Context context,
            List<ContactIndex> contactList) {
        mContext = context;
        mContactList = contactList;

this.layoutInflater = LayoutInflater.from(context);

// mMatrix = new Matrix();
        // mMatrix.postScale(0.6f,0.6f);
    }

public void setSelectItem(int position) {
        mSelectedPosition = position;
    }

/*
     * (non-Javadoc)
     *
     * @see android.widget.Adapter#getCount()
     */
    @Override
    public int getCount() {
        // Log.d(TAG, "contact list size:" + mContactList.size());
        return mContactList.size();
    }

/*
     * (non-Javadoc)
     *
     * @see android.widget.Adapter#getItem(int)
     */
    @Override
    public Object getItem(int position) {
        if (position >= 0 && position < mContactList.size()) {
            return mContactList.get(position);
            // return mList.get(position % mList.siez());
        }
        return null;
    }

/*
     * (non-Javadoc)
     *
     * @see android.widget.Adapter#getItemId(int)
     */
    @Override
    public long getItemId(int arg0) {
        return arg0;
    }

@Override
    public int getViewTypeCount() {
        return TYPE_COUNT;
    }

@Override
    public int getItemViewType(int position) {
        if (position == mSelectedPosition) {
            return BIG_TYPE;
        } else {
            return SMALL_TYPE;
        }
    }

/*
     * (non-Javadoc)
     *
     * @see android.widget.Adapter#getView(int, android.view.View,
     * android.view.ViewGroup)
     */
    @Override
    public View getView(int position, View convertView, ViewGroup viewGroup) {

Log.d(TAG, "position:" + position);
        ViewHolder viewHolder = null;

currentType = getItemViewType(position);
        System.out.println("type=" + currentType);
        if (currentType == BIG_TYPE) {

if (convertView == null) {
                viewHolder = new ViewHolder();

convertView = layoutInflater.inflate(R.layout.call_item, null);

viewHolder.friendPic = (ImageView) convertView
                        .findViewById(R.id.callFriendPic);
                viewHolder.friendName = (TextView) convertView
                        .findViewById(R.id.callFriendName);

convertView.setTag(viewHolder);
            } else {
                viewHolder = (ViewHolder) convertView.getTag();
            }
        } else {
            if (convertView == null) {
                viewHolder = new ViewHolder();

convertView = layoutInflater.inflate(R.layout.call_item_small,
                        null);

viewHolder.friendPic = (ImageView) convertView
                        .findViewById(R.id.callFriendPic);
                viewHolder.friendName = (TextView) convertView
                        .findViewById(R.id.callFriendName);

convertView.setTag(viewHolder);
            } else {
                viewHolder = (ViewHolder) convertView.getTag();
            }
        }

//         if(mSelectedPosition == position){
//             viewHolder.friendPicBorder.setVisibility(View.VISIBLE);
//             viewHolder.friendName.setTextSize(mContext.getResources().getDimension(R.dimen.callListNameTextSizeBig));
//         }
//         else{
//             mBitmap = BitmapFactory.decodeResource(mContext.getResources(),
//             mContactList.get(position).getPicId());
//             Bitmap resizeBmp =
//             Bitmap.createBitmap(mBitmap,0,0,mBitmap.getWidth(),mBitmap.getHeight(),mMatrix,true);
//             viewHolder.friendPic.setImageBitmap(resizeBmp);
//         }

viewHolder.friendPic.setImageResource(mContactList.get(position)
                .getPicId());
        viewHolder.friendName.setText(mContactList.get(position).getUserName());

return convertView;
    }

private static class ViewHolder {
        ImageView friendPic;
        TextView friendName;
    }
}

三、TV 版本中,ListView 首尾循环相接的方法:

  即,到了最后一个,再按向下键的时候,跳到第一个

  到了第一个,再按向上键的时候,跳到最后一个

@Override
    public boolean onKeyDown(int keyCode, KeyEvent event) {

switch (keyCode) {
        case KeyEvent.KEYCODE_DPAD_DOWN:
            if (mOldPosition == mContactListAdapter.getCount() - 1) {
                mCallContactListContainer.setSelection(0);
            }
            break;
        case KeyEvent.KEYCODE_DPAD_UP:
            if (mOldPosition == 0) {
                mCallContactListContainer.setSelection(mContactListAdapter
                        .getCount() - 1);
            }
            break;
        }

return super.onKeyDown(keyCode, event);
    }

如果是触屏,涉及到滚动,就比较麻烦

四、 Adapter中自定义的方法  用来在Activity中,一个处于focus状态的item的position

public void setSelectItem(int position) {
        mSelectedPosition = position;
    }

Activity中,给ListView设置选中的Listener

mListView.setOnItemSelectedListener(new OnItemSelectedListener() {

@Override
                    public void onItemSelected(AdapterView<?> adapterView,
                            View view, int position, long arg3) {

mMyAdapter.setSelectItem(position);
                        mMyAdapter.notifyDataSetChanged();
                    }

@Override
                    public void onNothingSelected(AdapterView<?> arg0) {
                    }
});

两种布局的ListVIew Adapter。例如微信对话界面的更多相关文章

  1. RecyclerView添加两种布局

    简介: 本篇博客主要介绍如何在RecyclerView中添加两种布局 思路:主要重写Recyclerview.Adapter中的一些方法 1.public int getItemViewType(in ...

  2. Android 常用UI控件之TabHost(1)TabHost的两种布局方式

    TabHost是Android中的tab组件. TabHost布局文件的基本结构 TabHost下有个layout,这个layout中有TabWidget与FrameLayout.TabWidget是 ...

  3. Android中通过数组资源文件xml与适配器两种方式给ListView列表视图设置数据源

    场景 实现效果如下 注: 博客: https://blog.csdn.net/badao_liumang_qizhi 关注公众号 霸道的程序猿 获取编程相关电子书.教程推送与免费下载. 实现 将布局改 ...

  4. 两种经典电商CSS布局

    圣杯布局和双飞翼布局! 两种布局功能相同,都是为了实现两端宽度固定,中间宽度自适应的三栏布局 圣杯布局: 三个区域都处于左浮动状态,并使main的宽度成父容器的100% 为两侧侧边栏添加负margin ...

  5. 七种CSS左侧固定,右侧自适应两栏布局

    一 两栏布局基本HTML和CSS 首先创建基本的HTML布局和最基本的样式. 基本的样式是,两个盒子相距20px, 左侧盒子宽120px,右侧盒子宽度自适应 <div class="w ...

  6. bootstrap的栅格布局与两列布局结合使用

    在工作中我们常常需要实现响应式布局,这个可以使用bootstrap的栅格系统来实现,我们在列里也需要实现一部分的响应式.比如下面的效果图,需要实现左边图标固定,右边的自适应 : 左边固定宽度,右边自适 ...

  7. TouTiao开源项目 分析笔记15 新闻详情之两种类型的实现

    1.预览效果 1.1.首先看一下需要实现的效果. 第一种,文字类型新闻. 第二种,图片类型新闻. 1.2.在NewsArticleTextViewBinder中设置了点击事件 RxView.click ...

  8. 实现顶部轮播,下部listview经典布局的两种方式

    开头: 在做android开发的时候,我们经常会遇到这样的布局,上面是一个图片轮播图,下面是一些列表的项目.很多新闻app,视频类app都采用这样的布局.起初的时候 由于没有很多参考,我自己想到了一种 ...

  9. ListView加载两种以上不同的布局

    不同的项目布局(item layout) Listview一种单一的item 布局有时候不能完全满足业务需求,我们需要加载两种或两种以上不同的布局,实现方法很简单: 重写 getViewTypeCou ...

随机推荐

  1. FilterDispatcher处理流程

    org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter 前身是:org.apache.struts2.dispatc ...

  2. java: InputStreamReader将字节的输入流变成字符的输入流,OutputStreamWriter将字符的输出流变成字节的输出流

    InputStreamReader:将字节的输入流变成字符的输入流, OutputStreamWriter:将字符的输出流变成字节的输出流 //将缓冲区的内容读取,可以一次读取 //可以接收键盘的输入 ...

  3. zoj 3960 What Kind of Friends Are You?(哈希)

    What Kind of Friends Are You? Time Limit: 1 Second      Memory Limit: 65536 KB Japari Park is a larg ...

  4. pycharm配置PyQt5,以及创建第一个项目

    认你已经安装好了pycharm,也正确安装了PyQt5 否则,请移步https://www.cnblogs.com/longbigbeard/p/9628102.html来安装PyQt5 下一步,To ...

  5. 深入javascript之原型和原型链

    原型和原型链是js中的难点也是重点,明白了原型和原型链会让我们在后面不管是学习还是工作都会更加高效,并且原型和原型链会是面试中必不可少的话题.看完此篇文章一定会让你对原型,原型链有深刻全面的了解. 一 ...

  6. 打印控件Lodop

    官网:http://www.lodop.net/demo.html Lodop.C-Lodop使用说明及样例   Lodop(标音:劳道谱,俗称:露肚皮)是专业WEB控件,用它既可裁剪输出页面内容,又 ...

  7. 网络编程基础--多线程---concurrent.futures 模块---事件Event---信号量Semaphore---定时器Timer---死锁现象 递归锁----线程队列queue

    1 concurrent.futures 模块: # from abc import abstractmethod,ABCMeta # # class A(metaclass=ABCMeta): # ...

  8. PhotoShop使用指南(3)—— 将多张图片添加到图层

    第一步:选择文件菜单>脚本>将文件载入堆栈 第二步:点击浏览添加要批量载入的图片

  9. Codeforces Round #254(div2)B

    就是看无向图有几个连通块,答案就是2n-num. 范围很小,就用矩阵来存图减少代码量. #include<iostream> #include<cstdio> #include ...

  10. 不带缓存IO和标准(带缓存)IO

    linux对IO文件的操作分为: 不带缓存:open read.posix标准,在用户空间没有缓冲,在内核空间还是进行了缓存的.数据-----内核缓存区----磁盘 假设内核缓存区长度为100字节,你 ...