/MessageDisplayKit

An IM App like WeChat App has to send text, pictures, audio, video, location messaging, managing local address book, share a circle of friends, drifting friends, shake a fun and more interesting features.

Primary LanguageObjective-CMIT LicenseMIT

image

MessageDisplayKit

一个类似微信App的IM应用,拥有发送文字、图片、语音、视频、地理位置消息,管理本地通信录、分享朋友圈、漂流交友、摇一摇乐趣和更多有趣的功能。
An IM APP like WeChat App has to send text, pictures, audio, video, location messaging, managing local address book, share a circle of friends, drifting friends, shake a fun and more interesting features.

如果有任何问题,请到githug开issue,点击这里移步新建一个issue,写上你不明白的地方,我会在github给予帮助。

It's ok if you don't understand how the code works. Most code has comments, which I believe will help you a lot. Feel free to [open an issue] (https://github.com/xhzengAIB/MessageDisplayKit/issues?state=open) if you have any questions. I will do my best to answer them.

注意,现在已经替换了这个插件的编译,使用Xcode6或者更高版本进行编译即可

这里的方法已经失效(很多朋友说不能直接编译该项目的主要工程,其实原因很简单,只是没有打包静态库的插件,需要安装一个Xcode插件,点击以下链接iOS-Universal-Framework,安装方法很简单的,里面有教程,只要安装了该插件后,重启你的xcode,就可以开始编译了!)

开源许可协议

很多人和我说,你不知道什么是开源许可协议,其实我也不清楚他是不知道还是不想知道,作为一个开发者,不懂得尊重别人的成果,那你到底想怎样,你自己最清楚。
说一件事吧!曾经我也这么做了,没尊重作者的成果,最终被人鄙视了一段时间,于是我删除了那个开源库,现在终于明白,尊重这个词,这对于别人来说是一个认可,我们不可以剥夺这份利益。 网易新闻App的开发者很厚道,他们有做到这一份尊重,他们是这么做的:

UIWebView *librariesWebView = [[UIWebView alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
    NSURLRequest *urlRequest = [NSURLRequest requestWithURL:[NSURL URLWithString:@"http://m.163.com/special/newsclient/ios_libraries.html"]]; // 这里的URL是网易新闻所用的,大家可以点击打开,如果你没有服务器,那你敢直接写个开源库的主页URL嘛?
[librariesWebView loadRequest:urlRequest];
[self.view addSubview:librariesWebView];

我把代码都给上了,哪怕你复制都不愿意,那我就无语了。
如果您还不知道开源许可协议是怎样的,那你点击这里看看网易大神们的节操。

组件要求 Requirements

  • Xcode6 or later
  • iOS 6.0+
  • ARC
  • System Frameworks : 'Foundation', 'CoreGraphics', 'UIKit', 'MobileCoreServices', 'AVFoundation', 'CoreLocation', 'MediaPlayer', 'CoreMedia', 'CoreText', 'AudioToolbox'.

Podfile

CocoaPods is the recommended method to install MessageDisplayKit, just add the following line to Podfile

pod 'MessageDisplayKit'

and run pod install, then you're all done!

TODO

  • 尽量去除绘制代码,由于现在引起性能下降的原因之一。
    Delete drawRect code, because of lead to lower FPS.
  • 语音转换处理,适应多平台可用语音、视频等数据。
    Convert audio format.
  • 搭建服务器。
    Build server
  • 模仿微信全部功能。

特性 Features

  • 1、高度可定制。
    Highly customizable.
  • 2、任意消息的大小。
    Arbitrary message sizes.
  • 3、复制&粘贴消息。
    Able to copy & paste messages.
  • 4、数据检查器(确认电话号码、链接、日期等)。
    Data detectors (recognizes phone numbers, links, dates, etc.).
  • 5、时间戳。
    Timestamps.
  • 6、头像。
    Avatars.
  • 7、向下滑动隐藏键盘。
    Swipe down to hide keyboard.
  • 8、动态调整输入文本视图类型。
    Dynamically resize input text view as you type.
  • 9、自动启用/禁用发送按钮(如果文本视图是空的或不是)。
    Automatically enable/disable send button according to the content of text view.
  • 10、发送/接收声音效果。
    Send/Receive sound effects.
  • 11、发送语音。
    Send voice messages.
  • 12、发送图片。
    Send photos.
  • 13、发送视频。
    Send videos.
  • 14、发送地理位置。
    Send geolocations.
  • 15、发送第三方gif表情。
    Send third party gif message.
  • 16、通用于iPhone和iPad。
    Support both iPhone and iPad.
  • 17、支持StoryBorad。
    Support the StoryBorad to user.
  • 18、支持下拉加载更多旧消息,处理了保持可见cell不滚动的效果。 Support pull down load more old message, keep visible cells static when inserting old message at top.
  • 19、支持通信录
  • 20、支持朋友圈
  • 21、支持扫一扫
  • 22、支持摇一摇
  • 23、支持附近的人
  • 24、支持漂流瓶
  • 25、支持多选联系人
  • 26、支持新闻模板嵌套
  • 27、支持弹出Menu菜单
  • 28、支持游戏室展示
  • 29、支持表情商店预览
  • 30、核心网络层。
    Core Network Layer.
  • 31、核心缓存层。
    Core Cache Layer.
  • 32、核心数据层。
    Core Model Layer.
  • 33、优化TableView性能
    Majorization tableView performance.
  • 34、强化gif播放机制
    Keep FPS due wih gif play.

How to use

Easy to drop into your project.

  • 1、#import "XHMessageTableViewController.h"

  • 2、Your must be subClass XHMessageTableViewController.

  • 3、implementation XHMessageTableViewController delegate due with message send.

  • 4、implementation XHMessageTableViewController DataSource due with message source.

  • 5、If you went to emotion message / plug function / audio play, must be implementation other delegate or dataSource.

  • Detail look this demo.

License

中文: MessageDisplayKit 是在MIT协议下使用的,可以在LICENSE文件里面找到相关的使用协议信息。

English: MessageDisplayKit is available under the MIT license, see the LICENSE file for more information.

须知 Notes

如果您在您的项目中使用该开源组件,请给我们发电子邮件告诉我们您的应用程序的名称,谢谢!主要是为了互推的效果,如果您的app火了,请给予少许的回报,如果您的App不火,或许能通过这个开源库了解到您的App!
主要目的只有一个,互推,使用该开源库的开发者,我都会向其保证,永远免费,不涉及任何商业纠纷的事情,请放心使用。

If you use this open source components in your project, please Email us to notify us the name of your application(s). Thanks!

What app use this open source

这里会列出所有使用该开源库的App列表。
leanchat-ios,LeanCloud 提供一站式后端云服务,从数据存储、实时聊天、消息推送到移动统计,涵盖应用开发的多方面后端需求。
家信-导购员家信,专属家居导购员的商务沟通APP。家信app,将家居消费者与离他最近的导购员及时对接。消费者微信在线随时随地与导购员接触沟通;导购员家信在线时时处处为消费者提供各种资讯、商品、咨询、导购服务,辅助消费者决策,促进消费购买,提升服务体验。

使用到的第三方组件

Thanks Developer

我家App的主程Aevit提供了技术支持,他的github地址,点击我家App下载安装,如果看到里面有好的效果,可以协商开源。

谢谢微信App给予我鼓励,我参考了很多框架设计问题、也提供了许多素材,但是请网友不要直接使用素材,我不知道是否会引起侵权的问题,所以请自重,我这里只是模仿微信,而不是攻击。使用该开源库所导致的所有侵权关系与我无关,我只是提供学习机会。

警告

请不要拿该工程的所有资源文件用于商业使用,如果不遵守规则,而产生的法律责任,一律与我无关。代码按照上文描述的License 和 Notes来使用。
该工程里面任何一个效果组件都不能擅自使用,如需使用,请告之于我。

Credits

Thanks to jessesquires who created JSMessagesViewController on which my chat list UI work is based.