ZHChat一款開源的聊天組件框架

ZHChat

ZHChat是一個開源的聊天組件,能夠幫助iOS開發者快速集成即時聊天功能。支持聲音,視頻,圖片,文字,表情,地理位置等消息模塊,易擴展,支持二次開發。Welcome to pull Request.

Gif
Gif

Features

  1. 界面模仿蘋果消息應用。
  2. 支持高度自定義,例如聊天氣泡自定義,聊天消息模塊自定義。
  3. 支持的消息種類滿足大部分即時通訊需求。
  4. 基于蘋果原生UITableView,二次開發成本低。
  5. 支持Objective-C 和 Swift 兩種語言。

Design Goals

簡單快捷集成聊天UI框架。

Requirements

  • iOS 7.0+
  • ARC

Usage

CocoaPods (recommended)

pod 'ZHChat', '~> 0.2.2'

拷貝整個ZHCMessagesViewController文件夾至你工程中。

Getting Started

導入所有ZHChat頭文件:

#import <ZHChat/ZHCMessages.h> // import all the things

關于Objective-C/Swift Demo的使用

  1. 下載整個工程。
  2. 終端進入相關文件夾運行 pod install 或者 pod update

自定義消息模塊

  1. 繼承 ZHCMediaItem類。
  2. 實現 ZHCMessageMediaData協議中的方法:
  • - (nullable UIView *)mediaView//用于展示所有非文字的消息類型,例如圖片,聲音,視頻,地理位置。這里你也可以自定義所有你想要的消息類型例如圖片+文字組合。
  • -(CGSize)mediaViewDisplaySize//用于確定mediaView消息視圖的大小。這里你可以根據需求限定一個最大值或者最小值,也可以是固定的大小。

自定義時可以參考ZHCMediaItem,添加自己的新增的屬性(例如網絡下載資源鏈接),和初始化方法,并實現前面介紹的兩個接口即可。

這里重點提下關于網絡下載資源,例如圖片:你可以增加一個下載地址:imgUrl 然后實現一個有下載地址的初始化接口:

-(instancetype)initWithImgUrl:(NSString *)url

并實現多媒體展示視圖接口:

- (UIView *)mediaView
{
    if (self.cachedImageView == nil) {
        CGSize size = [self mediaViewDisplaySize];
        UIImageView *imageView = [[UIImageView alloc] init];
        imageView.frame = CGRectMake(0.0f, 0.0f, size.width, size.height);
        imageView.contentMode = UIViewContentModeScaleAspectFill;
        imageView.clipsToBounds = YES;
        [ZHCMessagesMediaViewBubbleImageMasker applyBubbleImageMaskToMediaView:imageView isOutgoing:self.appliesMediaViewMaskAsOutgoing];
        self.cachedImageView = imageView;
        [imageView sd_setImageWithURL:[NSURL URLWithString:self.imageUrl] placeholderImage:nil completed:^(UIImage *image, NSError *error, SDImageCacheType cacheType, NSURL *imageURL) {
            if (!error) {
                dispatch_async(dispatch_get_main_queue(), ^{
                    self.cachedImageView = imageView;
                });
            }
        }];
    }
    return self.cachedImageView;
}

當然這只是很簡單的網絡下載圖片顯示的例子:實際iM通訊中消息有很多狀態:你需要根據不同的狀態進行相應的顯示,例如下載進度,上傳進度,下載失敗,上傳失敗,發送上傳成功等等....

網絡加載頭像

需要在繼承ZHCMessagesViewController的接口中進行操作:

- (nullable id<ZHCMessageAvatarImageDataSource>)tableView:(ZHCMessagesTableView *)tableView avatarImageDataForCellAtIndexPath:(NSIndexPath *)indexPath

這里你可以下載完成后刷新TableView即可。

消息點擊事件

需要在繼承ZHCMessagesViewController的接口中進行操作:

-(void)tableView:(ZHCMessagesTableView *)tableView didTapMessageBubbleAtIndexPath:(NSIndexPath *)indexPath

你可以根據消息的類型進行相關操作,例如展示大圖片,播放視頻等等。

** 更多使用方法請看參考Demo,接口和屬性介紹請看工程頭文件的介紹。如果您在使用中遇到了什么疑問可以通過郵件或者在GitHub中新建Issue,或者直接留言。**

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 發現 關注 消息 iOS 第三方庫、插件、知名博客總結 作者大灰狼的小綿羊哥哥關注 2017.06.26 09:4...
    肇東周閱讀 12,229評論 4 61
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 173,264評論 25 708
  • Spring Cloud為開發人員提供了快速構建分布式系統中一些常見模式的工具(例如配置管理,服務發現,斷路器,智...
    卡卡羅2017閱讀 134,923評論 18 139
  • 也許有人會說,沒關系,我不在乎,我想沒結婚的很多女孩子會有這種想法吧。 以前妹妹對我說,她覺得很遺憾,由于男方家里...
    墨香19閱讀 789評論 0 0
  • 爺爺笑著說:“如果我后悔了咋辦?”“后悔?晚啦,這一輩子都要守著我嘍”奶奶又倒了一杯大鍋蓋兒,自己飲了下去。
    幽若紫辰閱讀 270評論 12 1