- 浏览: 498686 次
- 性别:
- 来自: 福州
文章分类
- 全部博客 (165)
- iphone (2)
- android (13)
- 设计模式 (8)
- ND实习小记之Android (63)
- mac使用技巧 (1)
- window phone (1)
- 错误总结 (2)
- 开发记录 (6)
- Android控件常用属性 (7)
- 代码管理工具 (5)
- 黑莓开发 (2)
- Eclipse (9)
- Android实践项目 (6)
- 常用布局 (1)
- 自定义Widget (5)
- adapter (2)
- OsChina Android客户端研究 (1)
- android之我见 (4)
- Java相关 (1)
- 存储 (1)
- 调试 (1)
- NDK相关 (2)
- App Components (7)
- Android_提醒 (2)
- Android_存储 (0)
- Android_线程 (3)
- Android控件使用实例 (5)
- 键盘相关 (1)
- android之我见,源码 (1)
最新评论
-
xy_feng_zhi_chao:
多谢楼主分享
Android中使用styles -
michaelye1988:
soldier93 写道无关素质,我只发表自己的看法!既然你发 ...
如何在window上把你的项目提交到github -
soldier93:
无关素质,我只发表自己的看法!既然你发表了博客我就有权对其评价 ...
如何在window上把你的项目提交到github -
michaelye1988:
soldier93 写道laji 素质真低
如何在window上把你的项目提交到github -
soldier93:
laji
如何在window上把你的项目提交到github
微信中的ListView有一个特点就是存在许多不同的Item,即并不是平常的ListView,所有的Item布局都是一样的。针对这种情况,Google的Adapter提供了两个方法getItemViewType和getViewTypeCount。通过覆盖这两个方法就可以实现一个ListView中存在多种不同的Layout。实现了更加个性化的ListView效果。我归纳了下微信中的Item可以分为7中。针对这7种Item我对应地写了7中listItem。在getView的时候判断下当前数据对象中需要通过哪种布局来展现,来实时获取布局。
下面看代码:
Message.java
public class Message { private int type;//指定是哪种类型 private String value;//值 public int getType() { return type; } public void setType(int type) { this.type = type; } public String getValue() { return value; } public void setValue(String value) { this.value = value; } }
MainActivity.java:
public class MainActivity extends Activity { private ListView lvData; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); lvData = (ListView)findViewById(R.id.lv_data); lvData.setAdapter(getAdapter()); } private BaseAdapter getAdapter(){ return new MyAdapter(this, getMyData()); } private List<Message> getMyData(){ List<Message> msgList = new ArrayList<Message>(); Message msg; msg = new Message(); msg.setType(MyAdapter.VALUE_LEFT_TEXT); msg.setValue("食堂真难吃啊"); msgList.add(msg); msg = new Message(); msg.setType(MyAdapter.VALUE_TIME_TIP); msg.setValue("2012-12-23 下午2:23"); msgList.add(msg); msg = new Message(); msg.setType(MyAdapter.VALUE_RIGHT_TEXT); msg.setValue("我就说食堂的饭难吃吧,你不相信!"); msgList.add(msg); msg = new Message(); msg.setType(MyAdapter.VALUE_LEFT_TEXT); msg.setValue("好吧,这次听你的了。"); msgList.add(msg); msg = new Message(); msg.setType(MyAdapter.VALUE_TIME_TIP); msg.setValue("2012-12-23 下午2:25"); msgList.add(msg); msg = new Message(); msg.setType(MyAdapter.VALUE_RIGHT_TEXT); msg.setValue("就要圣诞了,有什么安排没有?"); msgList.add(msg); msg = new Message(); msg.setType(MyAdapter.VALUE_LEFT_TEXT); msg.setValue("没有啊,你呢?"); msgList.add(msg); msg = new Message(); msg.setType(MyAdapter.VALUE_TIME_TIP); msg.setValue("2012-12-23 下午3:25"); msgList.add(msg); msg = new Message(); msg.setType(MyAdapter.VALUE_LEFT_IMAGE); msg.setValue("7min"); msgList.add(msg); msg = new Message(); msg.setType(MyAdapter.VALUE_RIGHT_TEXT); msg.setValue("高帅富有三宝 木耳 跑车 和名表," + "黑木耳有三宝 美瞳 备胎 黑丝脚 ,穷矮挫有三宝 AV 手纸 射得早 ,女神有三宝 干嘛 呵呵 去洗澡 ,宅男有三宝 Dota 基友 破电脑 " + "女屌丝有三宝 虎背 熊腰 眼睛小 , 女屌丝还有三宝 饼脸 花痴 卖萌照"); msgList.add(msg); msg = new Message(); msg.setType(MyAdapter.VALUE_LEFT_TEXT); msg.setValue("碉堡了"); msgList.add(msg); msg = new Message(); msg.setType(MyAdapter.VALUE_LEFT_AUDIO); msg.setValue("7min"); msgList.add(msg); msg = new Message(); msg.setType(MyAdapter.VALUE_RIGHT_IMAGE); msg.setValue("7min"); msgList.add(msg); return msgList; } }
下面是最重要的地方:
MyAdapter.java:
public class MyAdapter extends BaseAdapter{ public static final String KEY = "key"; public static final String VALUE = "value"; public static final int VALUE_TIME_TIP = 0;//7种不同的布局 public static final int VALUE_LEFT_TEXT = 1; public static final int VALUE_LEFT_IMAGE = 2; public static final int VALUE_LEFT_AUDIO = 3; public static final int VALUE_RIGHT_TEXT = 4; public static final int VALUE_RIGHT_IMAGE = 5; public static final int VALUE_RIGHT_AUDIO = 6; private LayoutInflater mInflater; private Context context; private List<Message> myList; public MyAdapter(Context context, List<Message> myList){ this.context = context; this.myList = myList; for(Message msg:myList){ Log.d("myList:", msg.getType()+""); } mInflater = (LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE); } public void addItem(final Message item) { myList.add(item); notifyDataSetChanged(); } @Override public int getCount() { return myList.size(); } @Override public Object getItem(int arg0) { return myList.get(arg0); } @Override public long getItemId(int arg0) { return arg0; } @Override public View getView(int position, View convertView, ViewGroup arg2) { Message msg = myList.get(position); int type = getItemViewType(position); ViewHolder holder = null; if(convertView == null){ holder = new ViewHolder(); switch (type) { case VALUE_TIME_TIP: convertView = mInflater.inflate(R.layout.list_item_time_tip, null); holder.tvTimeTip = (TextView)convertView.findViewById(R.id.tv_time_tip); holder.tvTimeTip.setText(msg.getValue()); break; //左边 case VALUE_LEFT_TEXT: convertView = mInflater.inflate(R.layout.list_item_left_text, null); holder.ivLeftIcon = (ImageView)convertView.findViewById(R.id.iv_icon); holder.btnLeftText = (Button)convertView.findViewById(R.id.btn_left_text); holder.btnLeftText.setText(msg.getValue()); break; case VALUE_LEFT_IMAGE: convertView = mInflater.inflate(R.layout.list_item_left_iamge, null); holder.ivLeftIcon = (ImageView)convertView.findViewById(R.id.iv_icon); holder.ivLeftImage = (ImageView)convertView.findViewById(R.id.iv_left_image); holder.ivLeftImage.setImageResource(R.drawable.test); break; case VALUE_LEFT_AUDIO: convertView = mInflater.inflate(R.layout.list_item_left_audio, null); holder.ivLeftIcon = (ImageView)convertView.findViewById(R.id.iv_icon); holder.btnLeftAudio = (Button)convertView.findViewById(R.id.btn_left_audio); holder.tvLeftAudioTime = (TextView)convertView.findViewById(R.id.tv_left_audio_time); holder.tvLeftAudioTime.setText(msg.getValue()); break; //右边 case VALUE_RIGHT_TEXT: convertView = mInflater.inflate(R.layout.list_item_right_text, null); holder.ivRightIcon = (ImageView)convertView.findViewById(R.id.iv_icon); holder.btnRightText = (Button)convertView.findViewById(R.id.btn_right_text); holder.btnRightText.setText(msg.getValue()); break; case VALUE_RIGHT_IMAGE: convertView = mInflater.inflate(R.layout.list_item_right_iamge, null); holder.ivRightIcon = (ImageView)convertView.findViewById(R.id.iv_icon); holder.ivRightImage = (ImageView)convertView.findViewById(R.id.iv_right_image); holder.ivRightImage.setImageResource(R.drawable.test); break; case VALUE_RIGHT_AUDIO: convertView = mInflater.inflate(R.layout.list_item_right_audio, null); holder.ivRightIcon = (ImageView)convertView.findViewById(R.id.iv_icon); holder.btnRightAudio = (Button)convertView.findViewById(R.id.btn_right_audio); holder.tvRightAudioTime = (TextView)convertView.findViewById(R.id.tv_right_audio_time); holder.tvRightAudioTime.setText(msg.getValue()); break; default: break; } convertView.setTag(holder); }else{ holder = (ViewHolder)convertView.getTag(); } return convertView; } /** * 根据数据源的position返回需要显示的的layout的type * * */ @Override public int getItemViewType(int position) { Message msg = myList.get(position); int type = msg.getType(); Log.e("TYPE:", ""+type); return type; } /** * 返回所有的layout的数量 * * */ @Override public int getViewTypeCount() { return 7; } class ViewHolder{ private TextView tvTimeTip;//时间 private ImageView ivLeftIcon;//左边的头像 private Button btnLeftText;//左边的文本 private ImageView ivLeftImage;//左边的图像 private Button btnLeftAudio;//左边的声音 private TextView tvLeftAudioTime;//左边的声音时间 private ImageView ivRightIcon;//右边的头像 private Button btnRightText;//右边的文本 private ImageView ivRightImage;//右边的图像 private Button btnRightAudio;//右边的声音 private TextView tvRightAudioTime;//右边的声音时间 } }
在getView()的时候通过switch判断当前一条数据需要使用的是哪种布局,实时进行加载。
getItemViewType() 和getViewTypeCount() 这两个方法起到的作用是循环回收利用不同的布局,起到了优化的作用!这是不同于平时使用Adapter的地方。
效果如下:
项目地址:
https://github.com/michaelye/WeiXinListView
发表评论
-
利用Intent,打开word,pdf等文件
2012-12-25 14:52 4292本例演示如何通过Intent来打开手机sd卡中的word,pd ... -
ArrayAdapter的使用
2012-09-11 10:35 1251在开发中,我们经常需要在ListView中模拟一些数据,最快速 ... -
对话框,去白边
2012-07-28 21:39 16031. res/values/styles.xml & ... -
生成Google Map KeyGen
2012-01-16 15:52 1047打开CMD进入到jdk安装目录:cd C:\Program F ... -
实现应用程序在Notification在标题栏提醒
2012-01-10 21:24 1158public class Main extends Activ ... -
导入的工程如果显示不认识API中的所有类解决方法
2011-12-22 16:32 984如果导入的包里面出现的错误是所有的API中的类都不认识。 解 ... -
搭建Android开发环境
2011-12-19 11:32 10081.安装jdk 2.安装Eclipse 3.打开Eclip ... -
结束整个应用程序
2011-12-07 15:06 1073Intent startmain=new Intent(Int ... -
字符串的拼接
2011-12-07 15:00 818String str = String ... -
实现按钮按下的效果
2011-12-07 14:35 1159public boolean onTouch(View v, ... -
实现LoadingActivity
2011-12-07 14:33 1236@Override protected void onCrea ... -
Android隐藏标题栏,设置全屏
2011-12-07 14:30 1179requestWindowFeature(Window.FEA ... -
九宫格的实现,屏幕底部加入log
2011-12-01 11:44 1197<?xml version="1.0 ...
相关推荐
在Android平台上,构建一个高度仿真的微信聊天界面是一项复杂而精细的工作,涉及到多个技术层面和设计元素。这个项目包括了用户登录、摇一摇功能以及信息发送等核心交互部分,充分体现了Android应用开发中的UI设计与...
微信聊天界面的核心元素包括输入框、表情键盘、发送按钮、消息列表以及头像等。使用Android Studio和XML布局文件,我们可以创建这些组件。输入框通常是一个EditText,用于输入文字;表情键盘则需要自定义视图,包含...
1. **WinForm控件**:WinForm提供了丰富的控件库,如Label、TextBox、Button、PictureBox等,用于构建聊天界面。例如,用于输入文字的TextBox,发送按钮,显示聊天记录的ListBox或ListView,以及可能用到的头像展示...
综上所述,实现类似微信信息界面的下拉刷新功能涉及多个方面,包括下拉刷新组件的使用、ListView的适配、数据加载逻辑以及动画效果。通过合理的设计和编码,可以创建出流畅、自然的用户交互体验。
【标题】"高仿微信聊天界面"涉及到的是在Android平台上创建一个类似微信的聊天界面的实践项目。在Android开发中,构建这样的用户界面是提升用户体验的关键步骤,它要求开发者对UI设计、数据处理以及交互逻辑有深入...
本文将围绕“Android仿微信的ListView”这一主题,详细讲解如何实现类似微信聊天界面和好友列表界面的ListView组件。 首先,我们要理解ListView在Android中的角色。ListView是一种可滚动的视图容器,它可以显示一列...
本项目以"基于RecyclerView实现的仿微信聊天界面,item长按根据触摸位置弹出对话框"为主题,旨在帮助开发者了解如何利用RecyclerView构建类似微信的聊天体验,并实现长按菜单功能。 首先,我们需要理解RecyclerView...
微信聊天界面包含输入框、发送按钮、消息列表以及头像等元素。我们可以使用Android Studio中的布局编辑器,如XML布局文件,来设计这些元素。例如,`RecyclerView`用于展示消息列表,`ImageView`和`TextView`分别用于...
在IT行业中,构建一个类似微信或QQ的聊天界面是一项常见的任务,这涉及到用户界面(UI)设计和用户体验(UX)的优化。在这个项目中,我们主要关注的是如何在ListView中实现上拉加载更多和下拉刷新的功能,这些都是...
在IT行业中,构建一个类似QQ或微信的聊天界面是一项常见的任务,这涉及到用户界面设计、交互体验以及功能实现等多个方面。下面将详细讲解这个过程中的关键知识点。 首先,我们需要了解聊天界面的基础架构。一个基本...
2. 聊天界面:设计消息列表展示,支持文本、图片、语音、视频等多种消息类型,同时需要实时更新未读消息数。 3. 消息发送与接收:使用WebSocket或Firebase Realtime Database实现实时通信,确保消息即时传递。 4. ...
在Android应用开发中,创建一个类似微信聊天列表的界面是一项常见的任务。这个任务涉及到对用户界面(UI)的设计以及对数据展示技术的掌握。在这个场景中,我们将关注的重点放在使用`RecyclerView`来实现这样一个...
3. **聊天界面**:聊天界面的核心是消息列表和输入框。Android中的`RecyclerView`或iOS的`UITableView`可以用来展示消息历史,每个消息项需要自定义视图以适应不同类型的消息(文本、图片、语音等)。`EditText`...
4. **仿微信**:指的是根据微信的设计风格进行开发,通常包括底部导航栏、滑动切换页面、聊天界面、个人信息展示等元素。 在深入这个项目时,开发者可以学到以下知识点: 1. **Material Design**:微信5.2界面虽...
为了实现类似微信的消息推送,开发者可能采用了Google的Firebase Cloud Messaging (FCM) 或者其他第三方推送服务。这部分涉及后台服务的编写,以及Android权限管理。 6. **多媒体支持**: 微信支持图片、视频和...
6. **数据加载和缓存**:为了实现类似微信的聊天记录加载,需要理解异步加载数据的概念,使用ListView或RecyclerView(Android)和UITableView(iOS)来实现无限滚动。同时,还要处理数据缓存,提高用户体验。 7. *...
【标题】"仿微信聊天安卓源码"是一个针对Android平台的开发项目,旨在实现类似微信的聊天功能。这个源码对于初级或者中级Android开发者来说,是一个极好的学习资源,可以帮助他们理解和掌握移动应用中即时通讯(IM)...
在本文中,我们将探讨如何在Android平台上实现一个类似微信的语音聊天界面设计。这个设计包括用户录制语音、播放语音以及显示相应的UI交互元素。以下是一些关键知识点和实现步骤: 1. **ListView**:在Android应用...
3. **仿微信聊天界面**: - **ListView**:聊天界面的核心是显示历史消息,可以使用ListView控件来实现。每个条目是一个自定义的View,包含发送者、时间戳和消息内容。 - **适配器**:创建一个继承自BaseAdapter的...
在Android应用开发中,"仿微信聊天置顶"是一个常见的需求,它涉及到用户界面(UI)设计、消息管理以及数据结构的运用。这个功能允许用户将特定的聊天对话置于聊天列表的顶部,以便快速访问。下面将详细介绍实现这一...