融云頭像昵稱設(shè)置-給你最帥的解答

項目中涉及到即時通訊模塊、使用了融云的框架阀趴、前兩天開始做到頭像昵稱設(shè)置碌尔、起初按照文檔去做但是就是顯示不正常、后來仔細研究才發(fā)現(xiàn)又走到坑里了朋魔、今天就系統(tǒng)的說一下其中遇到的問題吧岖研。

首先我們來看看融云的開發(fā)文檔中的描述


屏幕快照 2016-12-26 10.20.14.png
// RCIM Class

    /*!
     用戶信息提供者

     @discussion SDK需要通過您實現(xiàn)的用戶信息提供者,獲取用戶信息并顯示警检。
     */
    @protocol RCIMUserInfoDataSource <NSObject>

    /*!
     獲取用戶信息

     @param userId                  用戶ID
     @param completion              獲取用戶信息完成之后需要執(zhí)行的Block
     @param userInfo(in completion) 該用戶ID對應的用戶信息

     @discussion SDK通過此方法獲取用戶信息并顯示孙援,請在completion中返回該用戶ID對應的用戶信息。
     在您設(shè)置了用戶信息提供者之后扇雕,SDK在需要顯示用戶信息的時候拓售,會調(diào)用此方法,向您請求用戶信息用于顯示镶奉。
     */
    - (void)getUserInfoWithUserId:(NSString *)userId
                       completion:(void (^)(RCUserInfo *userInfo))completion;

    @end

    /*!
     群組信息提供者

     @discussion SDK需要通過您實現(xiàn)的群組信息提供者础淤,獲取群組信息并顯示。
     */
    @protocol RCIMGroupInfoDataSource <NSObject>

    /*!
     獲取群組信息

     @param groupId                     群組ID
     @param completion                  獲取群組信息完成之后需要執(zhí)行的Block
     @param groupInfo(in completion)    該群組ID對應的群組信息

     @discussion SDK通過此方法獲取用戶信息并顯示腮鞍,請在completion的block中返回該用戶ID對應的用戶信息。
     在您設(shè)置了用戶信息提供者之后莹菱,SDK在需要顯示用戶信息的時候移国,會調(diào)用此方法,向您請求用戶信息用于顯示道伟。
     */
    - (void)getGroupInfoWithGroupId:(NSString *)groupId
                         completion:(void (^)(RCGroup *groupInfo))completion;

    @end

    /*!
     用戶信息提供者

     @discussion SDK需要通過您實現(xiàn)的用戶信息提供者迹缀,獲取用戶信息并顯示使碾。
     */
    @property(nonatomic, weak) id<RCIMUserInfoDataSource> userInfoDataSource;

    /*!
     群組信息提供者

     @discussion SDK需要通過您實現(xiàn)的群組信息提供者,獲取群組信息并顯示祝懂。
     */
    @property(nonatomic, weak) id<RCIMGroupInfoDataSource> groupInfoDataSource;
屏幕快照 2016-12-26 10.19.57.png

是不是覺得自己已經(jīng)秒懂票摇、OK、來自己動手做一做砚蓬、有沒有感覺有坑了矢门、哈哈、有坑就對了

接下來說說具體的做法:
實際上融云在針對頭像昵稱設(shè)置這塊有兩種處理方法灰蛙、當然祟剔、也正是因為有兩種方法、才會讓我們一不小心就被自己坑摩梧、好了物延、我們分別來具體的看看到底有什么區(qū)別吧

PlanA:使用消息攜帶用戶信息
這種方式會在每條發(fā)送的消息里都攜帶當前登陸用戶的信息,增加消息的長度仅父。

iOS端:
// 設(shè)置當前用戶信息
[RCIM sharedRCIM].currentUserInfo = [[RCUserInfo alloc] initWithUserId:@"當前登錄用戶的融云id" name:@"當前登錄用戶的用戶名" portrait:@"用戶頭像的url"];
// 設(shè)置消息體內(nèi)是否攜帶用戶信息
[RCIM sharedRCIM].enableMessageAttachUserInfo = YES;

/*!
 是否在發(fā)送的所有消息中攜帶當前登錄的用戶信息叛薯,默認值為NO
 
 @discussion 如果設(shè)置為YES,則會在每一條發(fā)送的消息中攜帶當前登錄用戶的用戶信息笙纤。
 收到一條攜帶了用戶信息的消息耗溜,SDK會將其信息加入用戶信息的cache中并顯示;
 若消息中不攜帶用戶信息粪糙,則仍然會通過用戶信息提供者獲取用戶信息進行顯示强霎。
 
 @warning 需要先設(shè)置當前登錄用戶的用戶信息,參考RCIM的currentUserInfo蓉冈。
 */
@property(nonatomic, assign) BOOL enableMessageAttachUserInfo;
Android端:
/**
 * 設(shè)置當前用戶信息城舞,
 *
 * @param userInfo 當前用戶信息
 */
RongIM.getInstance().setCurrentUserInfo(userInfo);
接下來,在 init 之后調(diào)用下面方法設(shè)置消息攜帶用戶信息寞酿。
/**
 * 設(shè)置消息體內(nèi)是否攜帶用戶信息家夺。
 *
 * @param state 是否攜帶用戶信息,true 攜帶伐弹,false 不攜帶拉馋。
 */
RongIM.getInstance().setMessageAttachedUserInfo(true);
接收方在接收到消息后,SDK 會自動從消息中取出用戶信息惨好,并顯示到 UI 上

以上所述為第一種設(shè)置方式煌茴,可以看出其實這種方式比較不好的一點就是會在每條消息中都攜帶用戶的個人信息,造成大量的冗余日川,所以并不是特別推薦的方法蔓腐。
需要注意的是,如果 安卓端 使用這種方式跟 iOS 互通時龄句,需要 iOS 側(cè)也在消息里攜帶用戶信息回论,這樣才能在兩側(cè)都正常顯示昵稱和頭像散罕。
另外,在測試過程中發(fā)現(xiàn)傀蓉,iOS中使用這種方式時會出現(xiàn)一個問題就是:如果你給朋友發(fā)消息欧漱,發(fā)完以后在會話列表頁面,對方如果沒有回復的話葬燎,是顯示不出來對方的頭像和昵稱的误甚,只有對方看到消息回復后才會正常顯示,所以說這個也算是一個bug吧萨蚕。

因此靶草,現(xiàn)在我們來看看第二種方案吧。

PlanB:設(shè)置用戶信息提供者

iOS端:

首先遵守協(xié)議:RCIMUserInfoDataSource岳遥,RCIMGroupInfoDataSource

在- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions方法中 設(shè)置代理:
[[RCIM sharedRCIM] setUserInfoDataSource:self];
[[RCIM sharedRCIM] setGroupInfoDataSource:self];

實現(xiàn)代理方法奕翔,以個人信息為例:
- (void)getUserInfoWithUserId:(NSString *)userId
                   completion:(void (^)(RCUserInfo *userInfo))completion
{
    if ([userId isEqualToString:@"當前登錄用戶的融云id"]) {
        return completion([[RCUserInfo alloc] initWithUserId:userId name:@"當前登錄用戶的用戶名" portrait:@"當前登錄用戶頭像的url"]);
    }else
    {
        根據(jù)存儲聯(lián)系人信息的模型,通過 userId 來取得對應的name和頭像url浩蓉,進行以下設(shè)置(此處因為項目接口尚未實現(xiàn)派继,所以就只能這樣給大家說說,請見諒)
        return completion([[RCUserInfo alloc] initWithUserId:userId name:@"name" portrait:@"http://pic32.nipic.com/20130827/12906030_123121414000_2.png"]);
    }
}

// 從 2.6.0 開始 IMKit 可以緩存用戶信息到數(shù)據(jù)庫里捻艳,開發(fā)者可以開啟 RCIM.h 里的enablePersistentUserInfoCache (當然也可以不用寫這個驾窟,個人感覺沒有什么顯著的用處)
[RCIM sharedRCIM].enablePersistentUserInfoCache = YES;

 /*!
     獲取群組信息

     @param groupId                     群組ID
     @param completion                  獲取群組信息完成之后需要執(zhí)行的Block
     @param groupInfo(in completion)    該群組ID對應的群組信息

     @discussion SDK通過此方法獲取用戶信息并顯示,請在completion的block中返回該用戶ID對應的用戶信息认轨。
     在您設(shè)置了用戶信息提供者之后绅络,SDK在需要顯示用戶信息的時候,會調(diào)用此方法嘁字,向您請求用戶信息用于顯示恩急。
     */
- (void)getGroupInfoWithGroupId:(NSString *)groupId
                         completion:(void (^)(RCGroup *groupInfo))completion
{
// 此處做相應的群組設(shè)置即可,獲取群組信息的流程與獲取用戶信息的流程一致
}

刷新 SDK 緩存
當用戶信息或者群組信息發(fā)生變化之后,可以調(diào)用 RCIM 中的 -refreshUserInfoCache:withUserId: 或 -refreshGroupInfoCache:withGroupId: 方法通知 IMKit 更新緩存

//RCIM Class

/*!
 更新SDK中的用戶信息緩存

 @param userInfo     需要更新的用戶信息
 @param userId       需要更新的用戶ID

 @discussion 使用此方法纪蜒,可以更新SDK緩存的用戶信息衷恭。
 但是處于性能和使用場景權(quán)衡,SDK不會在當前View立即自動刷新(會在切換到其他View的時候再刷新該用戶的顯示信息)纯续。
 如果您想立即刷新随珠,您可以在會話列表或者聊天界面reload強制刷新。
 */
- (void)refreshUserInfoCache:(RCUserInfo *)userInfo
                 withUserId:(NSString *)userId;

/*!
 更新SDK中的群組信息緩存

 @param groupInfo   需要更新的群組信息
 @param groupId     需要更新的群組ID

 @discussion 使用此方法猬错,可以更新SDK緩存的群組信息窗看。
 但是處于性能和使用場景權(quán)衡,SDK不會在當前View立即自動刷新(會在切換到其他View的時候再刷新該群組的顯示信息)倦炒。
 如果您想立即刷新显沈,您可以在會話列表或者聊天界面reload強制刷新。
 */
- (void)refreshGroupInfoCache:(RCGroup *)groupInfo
                 withGroupId:(NSString *)groupId;
安卓端:
/**
 * 設(shè)置用戶信息的提供者析校,供 RongIM 調(diào)用獲取用戶名稱和頭像信息构罗。
 *
 * @param userInfoProvider 用戶信息提供者。
 * @param isCacheUserInfo  設(shè)置是否由 IMKit 來緩存用戶信息智玻。<br>
 *                         如果 App 提供的 UserInfoProvider
 *                         每次都需要通過網(wǎng)絡請求用戶數(shù)據(jù)遂唧,而不是將用戶數(shù)據(jù)緩存到本地內(nèi)存,會影響用戶信息的加載速度吊奢;<br>
 *                         此時最好將本參數(shù)設(shè)置為 true盖彭,由 IMKit 將用戶信息緩存到本地內(nèi)存中。
 * @see UserInfoProvider
 */
RongIM.setUserInfoProvider(new RongIM.UserInfoProvider() {

    @Override
    public UserInfo getUserInfo(String userId) {

        return findUserById(userId);//根據(jù) userId 去你的用戶系統(tǒng)里查詢對應的用戶信息返回給融云 SDK页滚。
    }

}, true);

// 開發(fā)者自己重寫 findUserById 方法通過if-else獲取用戶信息即可實現(xiàn).

以上就是第二種方法的設(shè)置召边,其實可以看出我們最好的方法就是使用第二種“設(shè)置用戶信息提供者”來顯示頭像昵稱。

簡而言之裹驰,在iOS端設(shè)置融云頭像和昵稱顯示的時候隧熙,步驟就是:
1-遵守協(xié)議
RCIMUserInfoDataSource,RCIMGroupInfoDataSource
2-設(shè)置代理
[[RCIM sharedRCIM] setUserInfoDataSource:self];
[[RCIM sharedRCIM] setGroupInfoDataSource:self];
3-實現(xiàn)代理方法(if-else判斷是否是當前用戶幻林,進行對應的屬性設(shè)置即可)

- (void)getUserInfoWithUserId:(NSString *)userId
                   completion:(void (^)(RCUserInfo *userInfo))completion;
- (void)getGroupInfoWithGroupId:(NSString *)groupId
                         completion:(void (^)(RCGroup *groupInfo))completion;

另外贞盯,最重要的一點就是不要將兩種方法混在一起使用,這樣會造成不必要的bug沪饺。

以上就是關(guān)于融云頭像昵稱設(shè)置的相關(guān)內(nèi)容躏敢,希望可以對大家有所幫助

我是姣爺,我在簡書整葡,和你們一起件余,加油,
康撒哈米噠~~~

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末遭居,一起剝皮案震驚了整個濱河市啼器,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌魏滚,老刑警劉巖镀首,帶你破解...
    沈念sama閱讀 222,681評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異鼠次,居然都是意外死亡更哄,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,205評論 3 399
  • 文/潘曉璐 我一進店門腥寇,熙熙樓的掌柜王于貴愁眉苦臉地迎上來成翩,“玉大人,你說我怎么就攤上這事赦役÷榈校” “怎么了?”我有些...
    開封第一講書人閱讀 169,421評論 0 362
  • 文/不壞的土叔 我叫張陵掂摔,是天一觀的道長术羔。 經(jīng)常有香客問我赢赊,道長,這世上最難降的妖魔是什么级历? 我笑而不...
    開封第一講書人閱讀 60,114評論 1 300
  • 正文 為了忘掉前任释移,我火速辦了婚禮,結(jié)果婚禮上寥殖,老公的妹妹穿的比我還像新娘玩讳。我一直安慰自己,他們只是感情好嚼贡,可當我...
    茶點故事閱讀 69,116評論 6 398
  • 文/花漫 我一把揭開白布熏纯。 她就那樣靜靜地躺著,像睡著了一般粤策。 火紅的嫁衣襯著肌膚如雪樟澜。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,713評論 1 312
  • 那天叮盘,我揣著相機與錄音往扔,去河邊找鬼。 笑死熊户,一個胖子當著我的面吹牛萍膛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播嚷堡,決...
    沈念sama閱讀 41,170評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼蝗罗,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了蝌戒?” 一聲冷哼從身側(cè)響起串塑,我...
    開封第一講書人閱讀 40,116評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎北苟,沒想到半個月后桩匪,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,651評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡友鼻,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,714評論 3 342
  • 正文 我和宋清朗相戀三年傻昙,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片彩扔。...
    茶點故事閱讀 40,865評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡妆档,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出虫碉,到底是詐尸還是另有隱情贾惦,我是刑警寧澤,帶...
    沈念sama閱讀 36,527評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站须板,受9級特大地震影響碰镜,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜习瑰,卻給世界環(huán)境...
    茶點故事閱讀 42,211評論 3 336
  • 文/蒙蒙 一洋措、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧杰刽,春花似錦、人聲如沸王滤。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,699評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽雁乡。三九已至第喳,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間踱稍,已是汗流浹背曲饱。 一陣腳步聲響...
    開封第一講書人閱讀 33,814評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留珠月,地道東北人扩淀。 一個月前我還...
    沈念sama閱讀 49,299評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像啤挎,于是被迫代替她去往敵國和親驻谆。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,870評論 2 361

推薦閱讀更多精彩內(nèi)容

  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫庆聘、插件胜臊、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,124評論 4 61
  • 靠寫作賺錢這件事,是大部分剛開始寫作的人夢寐以求的事情伙判。我也立志如此象对,但如果給我曾經(jīng)的大學同學看到,八成會認為是個...
    木小溪V閱讀 9,102評論 144 417
  • 我發(fā)小媽媽發(fā)的朋友圈 怎么說呢 比起父母接受不了自己孩子平庸 我覺得一個人更接受不了的是自己的平庸 就像你身邊的人...
    當你的提伯斯閱讀 347評論 0 0
  • chy857417 陳遠 . . . . . . . . . 別看啦!9角Aち凇!Q蛲蕖唐全! 減下來就對了!!S世C直ⅰ!延届!
    我是陳遠閱讀 298評論 0 1
  • 你繼承了愛方庭,也繼承了愛的方式 文:Stanley 1 一桌子人在吃飯厕吉,酒過三巡,菜過五味械念,其中一個哥們兒帶點醉意头朱,...
    楊慶瑞閱讀 830評論 6 10