默认
打赏 发表评论 7
想开发IM:买成品怕坑?租第3方怕贵?找开源自已撸?尽量别走弯路了... 找站长给点建议
Android版高仿微信聊天界面源码 [附件下载]
阅读(102572) | 评论(7 收藏9 淘帖2 1
微信扫一扫关注!

前言


微信的聊天界面是挺漂亮的,每条消息都带一个气泡,给人一种很清新的感觉,其实实现起来也不是那么的难,下面我们就来实现一下。

代码执行效果图


Android版高仿微信聊天界面源码 [附件下载]_1348323388_9818.jpg

项目工程结构


Android版高仿微信聊天界面源码 [附件下载]_1348321913_7226.jpg

Activity主类的代码


package com.way.demo;

import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;

/**
 * @author way
 */
public class WeixinChatDemoActivity extends Activity implements OnClickListener {

        private Button mBtnSend;// 发送btn
        private Button mBtnBack;// 返回btn
        private EditText mEditTextContent;
        private ListView mListView;
        private ChatMsgViewAdapter mAdapter;// 消息视图的Adapter
        private List<ChatMsgEntity> mDataArrays = new ArrayList<ChatMsgEntity>();// 消息对象数组

        public void onCreate(Bundle savedInstanceState) {
                super.onCreate(savedInstanceState);
                setContentView(R.layout.main);

                initView();// 初始化view

                initData();// 初始化数据
                mListView.setSelection(mAdapter.getCount() - 1);
        }

        /**
         * 初始化view
         */
        public void initView() {
                mListView = (ListView) findViewById(R.id.listview);
                mBtnSend = (Button) findViewById(R.id.btn_send);
                mBtnSend.setOnClickListener(this);
                mBtnBack = (Button) findViewById(R.id.btn_back);
                mBtnBack.setOnClickListener(this);
                mEditTextContent = (EditText) findViewById(R.id.et_sendmessage);
        }

        private String[] msgArray = new String[] { "有大吗", "有!你呢?", "我也有", "那上吧",
                        "打啊!你放大啊!", "你TM咋不放大呢?留大抢人头啊?CAO!你个菜B", "2B不解释", "尼滚...",
                        "今晚去网吧包夜吧?", "有毛片吗?", "种子一大堆啊~还怕没片?", "OK,搞起!!" };

        private String[] dataArray = new String[] { "2012-09-22 18:00:02",
                        "2012-09-22 18:10:22", "2012-09-22 18:11:24",
                        "2012-09-22 18:20:23", "2012-09-22 18:30:31",
                        "2012-09-22 18:35:37", "2012-09-22 18:40:13",
                        "2012-09-22 18:50:26", "2012-09-22 18:52:57",
                        "2012-09-22 18:55:11", "2012-09-22 18:56:45",
                        "2012-09-22 18:57:33", };
        private final static int COUNT = 12;// 初始化数组总数

        /**
         * 模拟加载消息历史,实际开发可以从数据库中读出
         */
        public void initData() {
                for (int i = 0; i < COUNT; i++) {
                        ChatMsgEntity entity = new ChatMsgEntity();
                        entity.setDate(dataArray[i]);
                        if (i % 2 == 0) {
                                entity.setName("肖B");
                                entity.setMsgType(true);// 收到的消息
                        } else {
                                entity.setName("必败");
                                entity.setMsgType(false);// 自己发送的消息
                        }
                        entity.setMessage(msgArray[i]);
                        mDataArrays.add(entity);
                }

                mAdapter = new ChatMsgViewAdapter(this, mDataArrays);
                mListView.setAdapter(mAdapter);
        }

        @Override
        public void onClick(View v) {
                switch (v.getId()) {
                case R.id.btn_send:// 发送按钮点击事件
                        send();
                        break;
                case R.id.btn_back:// 返回按钮点击事件
                        finish();// 结束,实际开发中,可以返回主界面
                        break;
                }
        }

        /**
         * 发送消息
         */
        private void send() {
                String contString = mEditTextContent.getText().toString();
                if (contString.length() > 0) {
                        ChatMsgEntity entity = new ChatMsgEntity();
                        entity.setName("必败");
                        entity.setDate(getDate());
                        entity.setMessage(contString);
                        entity.setMsgType(false);

                        mDataArrays.add(entity);
                        mAdapter.notifyDataSetChanged();// 通知ListView,数据已发生改变

                        mEditTextContent.setText("");// 清空编辑框数据

                        mListView.setSelection(mListView.getCount() - 1);// 发送一条消息时,ListView显示选择最后一项
                }
        }

        /**
         * 发送消息时,获取当前事件
         * 
         * @return 当前时间
         */
        private String getDate() {
                SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
                return format.format(new Date());
        }
}

ListView的代码


package com.way.demo;

import java.util.List;

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


/**
 * 消息ListView的Adapter
 * 
 * @author way
 */
public class ChatMsgViewAdapter extends BaseAdapter {

        public static interface IMsgViewType {
                int IMVT_COM_MSG = 0;// 收到对方的消息
                int IMVT_TO_MSG = 1;// 自己发送出去的消息
        }

        private static final int ITEMCOUNT = 2;// 消息类型的总数
        private List<ChatMsgEntity> coll;// 消息对象数组
        private LayoutInflater mInflater;

        public ChatMsgViewAdapter(Context context, List<ChatMsgEntity> coll) {
                this.coll = coll;
                mInflater = LayoutInflater.from(context);
        }

        public int getCount() {
                return coll.size();
        }

        public Object getItem(int position) {
                return coll.get(position);
        }

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

        /**
         * 得到Item的类型,是对方发过来的消息,还是自己发送出去的
         */
        public int getItemViewType(int position) {
                ChatMsgEntity entity = coll.get(position);

                if (entity.getMsgType()) {//收到的消息
                        return IMsgViewType.IMVT_COM_MSG;
                } else {//自己发送的消息
                        return IMsgViewType.IMVT_TO_MSG;
                }
        }

        /**
         * Item类型的总数
         */
        public int getViewTypeCount() {
                return ITEMCOUNT;
        }

        public View getView(int position, View convertView, ViewGroup parent) {

                ChatMsgEntity entity = coll.get(position);
                boolean isComMsg = entity.getMsgType();

                ViewHolder viewHolder = null;
                if (convertView == null) {
                        if (isComMsg) {
                                convertView = mInflater.inflate(
                                                R.layout.chatting_item_msg_text_left, null);
                        } else {
                                convertView = mInflater.inflate(
                                                R.layout.chatting_item_msg_text_right, null);
                        }

                        viewHolder = new ViewHolder();
                        viewHolder.tvSendTime = (TextView) convertView
                                        .findViewById(R.id.tv_sendtime);
                        viewHolder.tvUserName = (TextView) convertView
                                        .findViewById(R.id.tv_username);
                        viewHolder.tvContent = (TextView) convertView
                                        .findViewById(R.id.tv_chatcontent);
                        viewHolder.isComMsg = isComMsg;

                        convertView.setTag(viewHolder);
                } else {
                        viewHolder = (ViewHolder) convertView.getTag();
                }
                viewHolder.tvSendTime.setText(entity.getDate());
                viewHolder.tvUserName.setText(entity.getName());
                viewHolder.tvContent.setText(entity.getMessage());
                return convertView;
        }

        static class ViewHolder {
                public TextView tvSendTime;
                public TextView tvUserName;
                public TextView tvContent;
                public boolean isComMsg = true;
        }

}

消息对象的实现代码


package com.way.demo;

/**
 * 一个消息的JavaBean
 * 
 * @author way
 * 
 */
public class ChatMsgEntity {
        private String name;//消息来自
        private String date;//消息日期
        private String message;//消息内容
        private boolean isComMeg = true;// 是否为收到的消息

        public String getName() {
                return name;
        }

        public void setName(String name) {
                this.name = name;
        }

        public String getDate() {
                return date;
        }

        public void setDate(String date) {
                this.date = date;
        }

        public String getMessage() {
                return message;
        }

        public void setMessage(String message) {
                this.message = message;
        }

        public boolean getMsgType() {
                return isComMeg;
        }

        public void setMsgType(boolean isComMsg) {
                isComMeg = isComMsg;
        }

        public ChatMsgEntity() {
        }

        public ChatMsgEntity(String name, String date, String text, boolean isComMsg) {
                super();
                this.name = name;
                this.date = date;
                this.message = text;
                this.isComMeg = isComMsg;
        }

}

OK,大功告成,大家耐心点看看吧,文字比较少。

源码下载


高仿微信聊天界面(52im.net).zip (203.23 KB , 下载次数: 99 , 售价: 2 金币)

(本源码来自csdn博客lnb333666,感谢原作者分享)

附录:全站精品资源下载


[1] 精品源码下载:
轻量级即时通讯框架MobileIMSDK的iOS源码(开源版)[附件下载]
开源IM工程“蘑菇街TeamTalk”2015年5月前未删减版完整代码 [附件下载]
微信本地数据库破解版(含iOS、Android),仅供学习研究 [附件下载]
NIO框架入门(四):Android与MINA2、Netty4的跨平台UDP双向通信实战 [附件下载]
NIO框架入门(三):iOS与MINA2、Netty4的跨平台UDP双向通信实战 [附件下载]
NIO框架入门(二):服务端基于MINA2的UDP双向通信Demo演示 [附件下载]
NIO框架入门(一):服务端基于Netty4的UDP双向通信Demo演示 [附件下载]
用于IM中图片压缩的Android工具类源码,效果可媲美微信 [附件下载]
高仿Android版手机QQ可拖拽未读数小气泡源码 [附件下载]
一个WebSocket实时聊天室Demo:基于node.js+socket.io [附件下载]
Android聊天界面源码:实现了聊天气泡、表情图标(可翻页) [附件下载]
高仿Android版手机QQ首页侧滑菜单源码 [附件下载]
开源libco库:单机千万连接、支撑微信8亿用户的后台框架基石 [源码下载]
分享java AMR音频文件合并源码,全网最全
微信团队原创Android资源混淆工具:AndResGuard [有源码]
一个基于MQTT通信协议的完整Android推送Demo [附件下载]
Android版高仿微信聊天界面源码 [附件下载]
仿微信的IM聊天时间显示格式(含iOS/Android/Web实现)[图文+源码]

[2] 精品文档和工具下载:
计算机网络通讯协议关系图(中文珍藏版)[附件下载]
史上最全即时通讯软件简史(精编大图版)[附件下载]
基于RTMP协议的流媒体技术的原理与应用(技术论文)[附件下载]
独家发布《TCP/IP详解 卷1:协议》CHM版 [附件下载]
良心分享:WebRTC 零基础开发者教程(中文)[附件下载]
MQTT协议手册(中文翻译版)[附件下载]
经典书籍《UNIX网络编程》最全下载(卷1+卷2、中文版+英文版)[附件下载]
音视频开发理论入门书籍之《视频技术手册(第5版)》[附件下载]
国际电联H.264视频编码标准官方技术手册(中文版)[附件下载]
Apache MINA2.0 开发指南(中文版)[附件下载]
网络通讯数据抓包和分析工具 Wireshark 使用教程(中文) [附件下载]
最新收集NAT穿越(p2p打洞)免费STUN服务器列表 [附件下载]
高性能网络编程经典:《The C10K problem(英文)》[附件下载]
即时通讯系统的原理、技术和应用(技术论文)[附件下载]
技术论文:微信对网络影响的技术试验及分析[附件下载]
华为内部3G网络资料: WCDMA系统原理培训手册[附件下载]
网络测试:Android版多路ping命令工具EnterprisePing[附件下载]
Android反编译利器APKDB:没有美工的日子里继续坚强的撸
一款用于P2P开发的NAT类型检测工具 [附件下载]
两款增强型Ping工具:持续统计、图形化展式网络状况 [附件下载]

[3] 精选视频、演讲PPT下载:
QQ空间移动端10亿级视频播放技术优化揭秘(视频+PPT)[附件下载]
RTC实时互联网2017年度大会精选演讲PPT [附件下载]
微信分享开源IM网络层组件库Mars的技术实现(视频+PPT)[附件下载]
微服务理念在微信海量用户后台架构中的实践(视频+PPT)[附件下载]
移动端IM开发和构建中的技术难点实践分享(视频+PPT)[附件下载]
网易云信的高品质即时通讯技术实践之路(视频+PPT)[附件下载]
腾讯音视频实验室:直面音视频质量评估之痛(视频+PPT)[附件下载]
腾讯QQ1.4亿在线用户的技术挑战和架构演进之路PPT[附件下载]
微信朋友圈海量技术之道PPT[附件下载]
手机淘宝消息推送系统的架构与实践(音频+PPT)[附件下载]
如何进行实时音视频的质量评估与监控(视频+PPT)[附件下载]
Go语言构建高并发消息推送系统实践PPT(来自360公司)[附件下载]
网易IM云千万级并发消息处理能力的架构设计与实践PPT [附件下载]
手机QQ的海量用户移动化实践分享(视频+PPT)[附件下载]
钉钉——基于IM技术的新一代企业OA平台的技术挑战(视频+PPT)[附件下载]
微信技术总监谈架构:微信之道——大道至简(PPT讲稿)[附件下载]
Netty的架构剖析及应用案例介绍(视频+PPT)[附件下载]
声网架构师谈实时音视频云的实现难点(视频采访)
滴滴打车架构演变及应用实践(PPT讲稿)[附件下载]
微信海量用户背后的后台系统存储架构(视频+PPT)[附件下载]
在线音视频直播室服务端架构最佳实践(视频+PPT)[附件下载]
从0到1:万人在线的实时音视频直播技术实践分享(视频+PPT)[附件下载]
微信移动端应对弱网络情况的探索和实践PPT[附件下载]
Android版微信从300KB到30MB的技术演进(PPT讲稿)[附件下载]

即时通讯网 - 即时通讯开发者社区! 来源: - 即时通讯开发者社区!

标签:聊天界面
上一篇:Android聊天界面源码:实现了聊天气泡、表情图标(可翻页) [附件下载]下一篇:Netty的架构剖析及应用案例介绍(视频+PPT) [附件下载]

本帖已收录至以下技术专辑

推荐方案
评论 7
有这样的代码,新手写简单的聊天界面就不用从0开始了,不然还是需要费点时间的
签名: 国庆长假还没有缓过来,请让我静一静,产品狗死远点...
感谢这些无私人的,当初做聊天界面的时候用的也是别人分享的,不过不是这篇里的代码,但都大同小异,比从0开始要舒服多了
收藏了
签名: 来过
收藏了
看看
签名: 不错,好好学习
看了 看了
打赏楼主 ×
使用微信打赏! 使用支付宝打赏!

返回顶部