Skip to content

Latest commit

 

History

History
125 lines (94 loc) · 6.15 KB

README.md

File metadata and controls

125 lines (94 loc) · 6.15 KB

iTopicChat

安装体验:

效果gif图:

现功能:

  • ✅ 一整套完善的聊天IM系统,包括ui,数据库,后台接口全开源
  • ✅ 线上正式环境,不用假数据,ios和后台php接口也都提供(关注我,等更新)
  • ✅ 长连接基于个推+华为push,全免费。不用融云环信腾讯等商业框架
  • ✅ 键盘、表情栏、功能栏、语音栏 切换自然无闪烁
  • ✅ 界面精致美观(仿微信)、流畅无卡顿
  • ✅ 语音条 + 微信表情 + 图片 + 视频通话 + 语音通话
  • ✅ 消息静音设置,黑名单设置
  • ✅ 无任何内存泄漏
  • ✅ 黑夜模式
  • ✅ java+mvc+okhttp+glide,封装都较简易,各模块都可方便替换成你自己的项目
  • ✅ 为方便测试,我额外集成了友盟的手机号一键登录,若无此需求,可删除

待完成功能:

  • ☑️ 群聊,但是目前android端代码是完全适配群聊功能的,只是群聊的后台接口我还没写好
  • ☑️ 音视频通话时候可用浮动小窗播放
  • ☑️ 小米手机对接小米push;oppo,vivo同理,目前代码已经封装的很好,再添加或更换第3方push很简单
  • ☑️ 聊天界面listView更换为recycleView
  • ☑️ 聊天气泡布局再用ConstraintLayout降层级

看一下消息的Bean,就明白整体架构

public class ChatBean {

    /**
     * 每一条字段后面的注释表明它的数据来源 :
     *
     * sqlite表示该变量来自手机本地sqlite数据库,服务器上无此字段,比如 是否已读,是否发送成功
     * service表示该变量来自服务器接口返回
     * service+sqlite 表示服务器也会返回,手机端也会去存
     * temp表示不入库也不是网络请求,只是Activity为了临时处理
     */

    public final static int INPROGRESS = 0;//客户端自己定义的。发送中
    public final static int SUCCESS = 1;//客户端自己定义的。发送成功
    public final static int FAIL = 2;//客户端自己定义的。发送失败

    public final static int TYPE_CHAT_SINGLE = 1;//单聊
    public final static int TYPE_CHAT_GROUP = 2;//群聊

    public final static int SUBTYPE_TIPS = 99;//聊天时候的tips,不入库

    public final static int SUBTYPE_TEXT = 1;//文本消息
    public final static int SUBTYPE_IMAGE = 2;//图片消息
    public final static int SUBTYPE_AUDIO = 3;//语音条消息
    public final static int SUBTYPE_GIFT = 4;//礼物消息

    public final static int SUBTYPE_CALL_AUDIO = 10;//电话消息
    public final static int SUBTYPE_CALL_VIDEO = 11;//视频消息

    private int dbid;//手机端本地数据库主键(sqlite)
    private int msgid;//服务器返回的主键id(service + sqlite)

    //如果是群聊(type==2),这里是发布人id; 如果是单聊,这里是对方id
    //如果是服务器返回的ChatBean,这里是发布人id,也就是对方id;
    //如果是本地发消息时候创建的单聊ChatBean,就用代码设为对方id; 如果是本地发消息时候创建的群聊ChatBean,就用代码设为自己
    private String other_userid; //(service + sqlite)
    private String other_name; //(service + sqlite)
    private String other_photo; //(service + sqlite)

    //如果是群聊(type==2),这里是群id;如果是单聊,这里是对方的userid(同other_userid)
    private String targetid; //(service + sqlite)

    private String content;//消息文本内容 //(service + sqlite)
    private int create_time;//1491545686 //(service + sqlite)
    private int type;//1为单聊 2为群聊 3为聊天时候的tips 4系统通知 //(service + sqlite)
    private int subtype;//0为文本 1为图片 2为语音 目前只可能为0 //(service + sqlite)
    private int issender;//当前登录账号是这个消息的发送者 //(sqlite)
    private int hadread;//0默认,未读 //(sqlite)

    //extend = 服务器返回的json,如果subtype是1图片,那么extend是{"height":2340,"width":1080}
    //如果subtype是2语音条,那么extend是{"duration":"6"}
    private String extend; //(service + sqlite)

    //filename = 附件本地沙盒文件名,同时也是七牛文件名
    //如果subtype是1图片,或者2语音条,那么就是文件名
    //如果subtype是11或者10电话消息,那么就是1611:800018:1586864352 (发送人id:接受人id:时间戳)
    private String filename; //(service + sqlite)

    // 图片
    private float thumbnailImageWidth;//客户端自己定义的,从extend解析出来的图片宽 //(temp)
    private float thumbnailImageHeight;//客户端自己定义的,从extend解析出来的图片高 //(temp)
    private int fileUploadProgress;//附件上传进度,范围为0--100 //(temp)

    //语音条
    private int duration;//秒,从extend解析出来的 //(temp)
    private int played;//0==没播放过,1==播放过,从extend解析出来的 //(temp)

    private int state;//客户端自己定义的。发送状态 //(sqlite)
    private int hisTotalUnReadedChatCount;//客户端自己定义的。与这个人的所有的未读消息数量 // (temp)
//    private String timeLag;//client定义的。直接显示的时间
    private String client_messageid;//客户端自己定义的临时消息id。// (sqlite)
    private boolean needShowTimeTips;//客户端自己定义的。是否要显示时间tips //(temp)
}

更多代码讲解我就先不写了,代码里注释挺多的,自己下载代码看去吧,不懂的问我

安装体验(上面有,怕你没看到再发一遍):

后续别的开源计划:

  1. ios版本的IM,后台php接口
  2. 仿小红书或快手的 详情页左滑进入个人主页demo
  3. 直播,连麦demo

对项目有什么问题,我24小时在线,QQ:285275534,微信:dz89415

另外,求广州、成都、南京地区的面试机会,android岗位,或者ios岗位,谢谢