android 聊天页面

公司想做一个客服系统,要求聊天内容要对外保密,不允许用第三方SDK,这要求也是略严格了,搜索了一下网上的博客,质量好的Demo大多基于第三方的UI框架,无奈只能硬着头皮自己摸索一下,时间允许的话再慢慢优化吧。

<big>布局</big>
三部分:标题栏,聊天内容,输入框。

标题栏写了一个简单的自定义控件,可以控制标题文字和一个左上角的返回按钮。聊天内容选择下拉刷新布局(PtrFrameLayout)包裹一个RecycleView ,下拉刷新查询历史数据。底部输入框暂时用相对布局堆起来,提供emoji表情和文字输入功能,将来如果有时间将输入框写成自定义控件。

布局.png

标题是长链接的链接状态,链接成功后显示对方信息,这里不做累述。

RecycleView 适配器里,设置两种类型,发送消息和接受消息

    public int getItemViewType(int position) {
        //判断消息类型
        if (isSend) { 
            return ITEM_TYPE.ITEM_RIGHT.ordinal();//发送
        } else {
            return ITEM_TYPE.ITEM_LEFT.ordinal();//接收
        }
    } ```

模拟发送两条信息看看

![聊天信息测试.png](http://upload-images.jianshu.io/upload_images/3027657-738c4f6a4bc08f0b.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

信息的气泡框的 .9图片需要仔细调整,不然很丑。

点击发送按钮,或者收到一条消息,更新页面。

public void add(int pos) {
notifyItemInserted(pos);
notifyDataSetChanged();
}


如果数据很多,再发送和接收消息后,页面需要定位到最后一条信息,控制recycleview滚动,用到recycleview的layoutManager

public void scrollToBottom() {
layoutManager.scrollToPosition(list.size()-1);
}


如果是查询聊天记录,并且聊天记录有多条,我们一般采用的是下拉刷新的办法,刷新成功后,页面不会滚动好刷新后的提一条数据,而是停留在刷新位置,我们向上滑动时,才会展示历史纪录,此时要看想要一次查询多少信息,例如如果查询10条信息,页面更新后,第一条item可见位置应该是第11个item位置

public void scrollToLastPos() {
int lastVisibleItemPosition = layoutManager.findLastVisibleItemPosition();
//每次更新10条信息,为了刷新后仍固定在相同的页面位置,所以滑动位置为 lastPos + 9 ,9为为了可以展示一个刷新出来的item
layoutManager.scrollToPosition(lastVisibleItemPosition + 9);
}


关于键盘的问题
为了避免布局被软键盘覆盖,我们需要监听键盘弹出,当键盘弹出时,聊天记录定位到记录最后位置。或者设置windowSoftInputMode 也可以,但是这里没有采用这样的方式,你可以自己测试。

判断键盘是否弹出思路:判断窗口可见区域的大小,如果屏幕高度和应用窗口可见区域高度差值大于整个屏幕的1/3,则便是软件盘显示中,否则为键盘隐藏状态。
参考链接:http://blog.csdn.net/ccpat/article/details/46730771

对输入框进行一些限制

android:inputType="textMultiLine"//允许多行显示
android:maxLines="3"//再无内容情况下,最多显示3行
android:maxLength="75"//输入内容不超过75个字符
android:maxEms="10"//每行长都不超过10ems长度,ems长度单位会随着字体大小的变化而变化

[demo](https://github.com/LikeBaker/LikePorject)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,313评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,369评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,916评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,333评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,425评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,481评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,491评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,268评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,719评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,004评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,179评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,832评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,510评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,153评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,402评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,045评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,071评论 2 352

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,958评论 25 707
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,080评论 4 62
  • 内容抽屉菜单ListViewWebViewSwitchButton按钮点赞按钮进度条TabLayout图标下拉刷新...
    皇小弟阅读 46,743评论 22 665
  • 本文写于2014年3月19日,原题《徐侠客》,最早发表于我的新浪博客,略有删改。 本人水平有限,若有任何疏漏错误之...
    鸟儿宇阅读 1,763评论 0 2
  • 推荐超感猎杀,有点小黄,剧里各种漏,各种群P。神剧情,各种高能。编剧脑洞大开,剪辑牛逼,配乐恰到好处,一首 wha...
    楠苜阅读 370评论 1 0