聊天软件界面开发
前言:
          这是开始学习Android的开发的第5天,一直是跟着郭霖大师的第一行代码学习,
             这里边发篇博文记录,边帮自己整理下思路,毕竟思路顺了,才是真的学会。
一、整体构思:
      1. 准备3张背景图片
         ① chat_bg; //用于当作聊天背景图片
            ② chat__ed_left.9.png; //用于当作左聊天气泡
            ③ chat__ed_right.9.png; //用于当作右聊天气泡
             注:*.9.png怎么制作在之前说过。
     2. 编写主界面chatmain_layout.xml,主界面的特点:
         ① 主界面由聊天对话框部分和输入框部分组成,且聊天对话框部分位于
                  输入框的上部,可以理解为这俩部分是纵向线性排列,所以主界面
                  采用<LinearLayout/>

            ② 分析聊天对话框部分:聊天就是你一句我一句,先说的在上,后说的
                  在下依次纵 向排列,所以我们对这部分使用<ListView/>控件。具体
                  ListView怎么进行布局,后面再说,我们现在直说主界面。
            ③ 分析输入框部分:输入部分由俩部分组成,一个输入框(<EditText/>
                  和一个发送按钮(<Button/>),且它们处于同一条直线上,是横向线性排列。
            ④ 聊天对话框部分和输入框部分用透明分隔线分割android:divider="#0000"。
            ⑤ 主界面的背景图片是chat_bg。
       
        3. 编写聊天对话框子界面msg_layout.xml,子界面的特点:
         ① 子界面就是前面说的ListView的界面,我们不能就让聊天时按普通ListView
                 的格式显示吧,也得美化一下,所以我们新增此布局。ListView就是纵向线
                 性排列,所以主布局我们用<LinearLayout/>。

            ② 对于每一条聊天记录,又是由一个气泡背景图+一串字符串组成的。聊天背景
                 图我们借用LinearLayout的background设置,字符串由<TextView/>设置。
            ③ 一般聊天分左右气泡,俩格式一样,只是区分好id和背景气泡就好。
       4. 编写聊天信息实体类Msg.java:
         ①里面包含消息内容和消息类型(接受/发送)。
       5. 编写ListView适配器类MsgAdapter,它的特点如下:
         ① 此类继承适配器类ArrayAdapter,并指定泛型为<Msg>。
            ② 为什么要用到此类:ListView是用来给我们展示数据的,而需要展示的这些数据
                 是无法直接通过数组传递给ListView的,我们还需借助适配器来完成;再者此类
                 还需将自定义的ListView布局加载到主布局内。
            ③ ArrayAdapter的构造函数很多,我们选用其中的一种,它有3个参数:
Context context,  // 传入上下文,一会将传入主活动类
                   inttextViewResourceId, //ListView子项布局的id,
                                                        //我们已经为List自定义好了布局,一会传入msg_layout的id
                   List<Msg>objects  //我们准备加载的数据
             ④ 本类里面还有一个重要的方法getView(),它的作用在ListView的子项滚动到屏幕内
                  的时候被调用,它用来处理子布局的逻辑。具体解释看代码里面的注释。
      6. 编写主活动ChatActivity,它的特点如下:
          ①  加载主布局

             ②  初始化数据
             ③ 初始化适配器(传入上下文,传入ListView子布局,传入显示的数据)
             ④ 为主布局里面的控件创建实例(主活动只加载主布局里面的控件,适配器加载子布局里面的控件)
             ⑤ 为发送按钮,设置点击事件。
二、代码部分:
     
1.chatmain_layout.xml
<pre style="background-color:#ffffff;color:#000000;font-family:'Courier New';font-size:15.0pt;"><pre class="html" name="code"><span style="font-size:14px;"><?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"android:background="@drawable/chat_bg"><!--聊天对话框部分android:divider="#0000"透明分隔线--><ListViewandroid:id="@+id/msg_list_view"android:layout_width="match_parent"android:layout_height="0dp"android:layout_weight="1"android:divider="#0000"/><!--输入框部分(横排排列)--><LinearLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"><!--输入框--><EditTextandroid:id="@+id/input_text"android:layout_width="0dp"android:layout_height="wrap_content"android:layout_weight="1"android:hint="Type something here"android:maxLines="2"/><!--发送按钮--><Buttonandroid:id="@+id/send"android:layout_width="wrap_content"android:layout_height="wrap_content"android:textAllCaps="false"android:text="Send"/></LinearLayout></LinearLayout>
</span>
<pre style="background-color:#ffffff;color:#000000;font-family:'Courier New';font-size:15.0pt;"><span><span><span><span style="font-size:18px;"><span style="font-size:24px;"><strong><span style="color:#cc33cc;">2.msg</span></strong><span style="font-size:24px;"><strong><span style="color:#cc33cc;">_layout.xml</span></strong></span></span></span></span></span></span>
<span style="font-size:14px;"><?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"android:padding="10dp"><!--左chat--><LinearLayoutandroid:id="@+id/left_layout"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="left"android:background="@drawable/chat_ed_left"><TextViewandroid:id="@+id/left_msg"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="center"android:layout_margin="10dp"android:textColor="#fff"/></LinearLayout><!--右chat--><LinearLayoutandroid:id="@+id/right_layout"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="right"android:background="@drawable/chat_ed_right"><TextViewandroid:id="@+id/right_msg"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="center"android:layout_margin="10dp"android:textColor="#a40d88"/></LinearLayout></LinearLayout>
</span>

3.Msg.java
<span style="font-size:14px;">public class Msg {public static final int TYPE_RECEIVED = 0;//收到的消息public static final int TYPE_SENT = 1;//发送的消息private String content;//消息内容private  int type;//消息类型public  Msg(String content, int type){this.content = content;this.type = type;}public String getContent() {return content;}public int getType() {return type;}
}</span>

4.MsgAdapter.java
<span style="font-size:14px;">package com.example.cpj.UICustomerViews;import android.content.Context;
import android.support.v7.widget.RecyclerView.ViewHolder;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.LinearLayout;
import android.widget.TextView;import java.util.List;
import com.example.cpj.uiwidgettest.R;/*** Created by cpj on 2016/3/15.*/
public class MsgAdapter extends ArrayAdapter<Msg>{private int resourceId;public MsgAdapter(Context context, int textViewResourceId,List<Msg> objects){super(context, textViewResourceId, objects);resourceId = textViewResourceId;}/*** 功能描述:这个方法在每个子项滚动到屏幕内的时候被调用*         1.首先通过 getItem()获取当前项的ToolBar实例*         2.使用LayoutInflater将这个子布局项加载并传入我们的主布局*         3.调用View的findViewById()分别获取到左右Layout、左右Msg的实例*         4.调用它们的setText()来显示文字*         5.最后返回布局* */public View getView(int position, View convertView, ViewGroup parent){Msg msg = getItem(position);/** 新增内部类ViewHolder,用于对控件的实例进行缓存。* 1.当convertView为空时,创建一个ViewHolder对象,并将控件的实例对象存放在ViewHolder里。* 2.然后调用View的setTag()方法,将ViewHolder对象存储在View中。* 3.当convertView不为空时,调用View的getTag()方法把ViewHolder重新取出来。* */View view;ViewHolder viewHolder;/*加载自定义布局与控件实例*/if(convertView == null){view = LayoutInflater.from(getContext()).inflate(resourceId, null);//创建控件实例并进行缓存viewHolder = new ViewHolder();viewHolder.leftLayout = (LinearLayout) view.findViewById(R.id.left_layout);viewHolder.rightLayout = (LinearLayout) view.findViewById(R.id.right_layout);viewHolder.leftMsg = (TextView) view.findViewById(R.id.left_msg);viewHolder.rightMsg = (TextView) view.findViewById(R.id.right_msg);view.setTag(viewHolder);} else {//convertView参数用于将之前加载好的布局进行缓存,以便之后可以进行复用(提高效率)view = convertView;viewHolder = (ViewHolder) view.getTag();}/*接受与发送消息的分类处理*///如果为收到的消息,则显示左边的消息布局,将右边的消息布局隐藏if(msg.getType() == Msg.TYPE_RECEIVED){viewHolder.leftLayout.setVisibility(View.VISIBLE);viewHolder.rightLayout.setVisibility(View.GONE);viewHolder.leftMsg.setText(msg.getContent());} else if(msg.getType() == Msg.TYPE_SENT){viewHolder.rightLayout.setVisibility(View.VISIBLE);viewHolder.leftLayout.setVisibility(View.GONE);viewHolder.rightMsg.setText(msg.getContent());}return view;}//新增内部类ViewHolder,用于对控件的实例进行缓存。class ViewHolder{LinearLayout leftLayout;LinearLayout rightLayout;TextView leftMsg;TextView rightMsg;}
}
</span>

5.ChatActivity.java
<span style="font-size:14px;">package com.example.cpj.UICustomerViews;import android.os.Bundle;
import android.view.View;
import android.view.Window;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;import com.example.cpj.uiwidgettest.BaseActivity;
import com.example.cpj.uiwidgettest.R;import java.util.ArrayList;
import java.util.List;/*** Created by cpj on 2016/3/15.*/
public class ChatActivity extends BaseActivity{private ListView msgListView;private EditText inputText;private Button send;private MsgAdapter adapter;private List<Msg> msgList = new ArrayList<Msg>();protected void onCreate(Bundle saveInstanceState){super.onCreate(saveInstanceState);requestWindowFeature(Window.FEATURE_NO_TITLE);setContentView(R.layout.chatmain_layout);initMsgs();//初始化消息数据</span><span style="font-size:14px;">adapter = new MsgAdapter(ChatActivity.this, R.layout.msg_layout, msgList);inputText = (EditText)findViewById(R.id.input_text);send = (Button)findViewById(R.id.send);msgListView = (ListView)findViewById(R.id.msg_list_view);msgListView.setAdapter(adapter);//发送按钮的点击事件send.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {String content = inputText.getText().toString();if(!"".equals(content)){Msg msg = new Msg(content, Msg.TYPE_SENT);msgList.add(msg);adapter.notifyDataSetChanged();//当有消息时刷新msgListView.setSelection(msgList.size());//将ListView定位到最后一行inputText.setText("");//清空输入框的内容}}});}/*** 初始化消息数据* */private void initMsgs(){Msg msg1 = new Msg("Hello cpj.", Msg.TYPE_RECEIVED);msgList.add(msg1);Msg msg2 = new Msg("Hello Who is that?", Msg.TYPE_SENT);msgList.add(msg2);Msg msg3 = new Msg("This is pengpeng,Nice talking to you.", Msg.TYPE_RECEIVED);msgList.add(msg3);}
}
</span>

三、思路回顾:
      
      1.我们创建了2个布局:
     第一个是主布局,这是一个聊天界面的大框架,分为对话框部分(ListView)和
                  消息输入部分(EditText和Button)。
     第二个布局子布局,是为了对话框部分的美化而设置的布局(气泡背景图+聊天文字)。
  2.聊天时消息时主体,所以创建消息实体类Msg,就是对消息的封装。
   3. 创建适配器类MsgAdapter去对应子布局,对子布局加载并加入处理逻辑。
   4. 创建主活动类ChatActivity,加载主布局,并初始化数据和适配器。
         附一张没那么漂亮的图片(气泡图片好难找):

Android聊天软件界面开发相关推荐

  1. Android聊天软件的开发(七)--聊天通信

    聊天通信通过Socket实现,大概的框架如下图: 通信流程: 1.服务器在启动时开启聊天服务线程 可以通过ServletContextListener监听Servlet的初始化和销毁,来开启和关闭聊天 ...

  2. Android聊天软件的开发--聊天通信

    Android聊天软件的开发(七)--聊天通信 2014-06-20 23:17:49CSDN-vaintwyt-点击数:338  聊天通信通过Socket实现,大概的框架如下图: 通信流程: 1.服 ...

  3. Android聊天软件的开发(四)--通讯录

    一,好友排序    好友排序是按照昵称拼音进行A-Z排序.效果如下图:      对好友昵称进行排序,需要先将首字转换为ASCII码,然后根据ASCII码得到对应的拼音,最后根据拼音进行A-Z排序.点 ...

  4. Android聊天软件的开发(六)--表情

    表情用于聊天对话的输入,实现的原理主要是:在EditText或TextView中,使用SpannableString,将特定字符串替换为图片. 首先,我们可以规定,表情的字符串为[**],图片名称为s ...

  5. Android聊天软件的开发(二)--数据库

    一,服务器数据库    服务器端的数据库是MySQL,使用Hibernate实现数据的增删改查.主要存储的数据有:用户信息,好友列表.             其中,好友列表中的friend_list ...

  6. Android聊天软件的开发(三)--网络连接

    一,服务器网络接口    服务器网络接口通过Servlet实现,可以获得客户端提交的数据,对数据进行查询存储操作,以及返回结果数据给客户端.客户端可以通过HTTP协议直接访问网络接口.    HTTP ...

  7. 开发简单Android聊天软件(6)

    构建完整消息接收加载流程 在 "开发简单Android聊天软件(5)" 中,完成了会话窗口的绘制,以及消息发送.现在我们来完成消息接收和加载,构建一个完整的聊天流程. 消息加载,那 ...

  8. 【基于Android聊天软件开发-哔哩哔哩】 https://b23.tv/109B82i

    [基于Android聊天软件开发-哔哩哔哩] https://b23.tv/109B82i https://b23.tv/109B82i Android聊天软件开发(仿QQ) 要求: Android ...

  9. 开发简单Android聊天软件(1)

    总体介绍 开篇 大概思路 一. 客户端主要依赖 二.包引用完成后,创建wsClient类. 三.连接成功后,就可以在对于业务逻辑调用以下方法开始发送消息 开篇 本人是一位开发新人,将自己的开发学习过程 ...

最新文章

  1. 【怎样写代码】偷窥高手 -- 反射技术(四):深入窥视属性
  2. 正则表达式匹配分组(|、(ab)、\num、(?P<name>)(?P=name))
  3. Python 学习笔记 - 字典
  4. c++入门代码_Golang Gin 实战(一)| 快速安装入门
  5. insmod 和modprobe的区别
  6. JavaScript基础:(加号,数值转换,布尔转换)
  7. php协程实现mysql异步_swoole与php协程实现异步非阻塞IO开发
  8. Enterprise Library 5.0 开发向导- 简介(1)
  9. 中石油训练赛 - Edit Distance(思维+构造)
  10. PHP简单实现单点登录功能示例
  11. android launcher 字体大小,Android6.0 Launcher3 修改app字体大小
  12. EtherCAT是什么?
  13. python抓取贴吧_python抓取百度贴吧-校花吧,网页图片
  14. android网格布局间距,android – 删除回收站视图网格布局中的默认间距
  15. WEB自动化(Python+selenium)的API
  16. 信号与系统(六)z变换
  17. head first系列pdf下载
  18. 前台获取服务器端的值
  19. 用Unity进行网络游戏开发(一)
  20. 二分图最大匹配与其应用

热门文章

  1. javase 双色球选7球 红球在【1-36】之间,选出6个,且不能重复 篮球在【1-16】之间,选出1个
  2. python打印数组部分元素_Python打印输出数组中全部元素
  3. 阿里巴巴融资破17亿美金创纪录
  4. 基于Nodejs的知识信息分享平台的设计和实现
  5. 最新好看的HYBBS程序极品论坛模板带插件
  6. 某电子计算机主机,2018年南开大学数学科学学院432统计学[专业硕士]之概率论与数理统计教程考研仿真模拟五套题...
  7. 成功处理挖矿病毒劫持,crontab注入顽固脚本,cpu、内存飙升
  8. Codeforces Round #683 (Div. 2) C. Knapsack(贪心)
  9. java false 0_Java中false指的是1还是0
  10. Unity和安卓(二):接入 google 广告