自定义实现@someone 的功能思路(三)

接上节:自定义实现@someone 的功能思路(二)

接下来咱们开始把选来的 Person 加到textView上 ,肯定不能直接用NSString 的 ,因为我们需要他具有特性并且本身携带信息,可以独一无二区分。由于我们公司的项目里的Person这个自定义类型,就是独一无二的。所以Person是需要携带的必然信息。经过各种百度,我终于找到了,

NSTextAttachment

于是我继承NSTextAttachment 写了一个自己的,代码如下

#import <UIKit/UIKit.h>

NS_ASSUME_NONNULL_BEGIN

//.m 什么也没写 
@interface DD_Media_Atment : NSTextAttachment
@property (nonatomic, assign) CGSize imageSize;
@property (nonatomic, strong) Person *person;
@property (nonatomic) BOOL isPerson; //不是人的时候 就是用来存字符串的
@property (nonatomic, strong) NSString * needPushStr;
@end

NS_ASSUME_NONNULL_END

好了现在我们有一个携带容器了,接着就是写了,

- (void)atStringAppendingWithArray:(NSArray *)arr
{
    NSMutableAttributedString *addMutableAttributeStr = [[NSMutableAttributedString alloc] initWithAttributedString:self.discussView.attributedText];

    for (int i = 0; i < arr.count; i++) {
        DD_Media_Atment *attach = [[DD_Media_Atment alloc] init];
        attach.person = [arr objectAtIndex:i];
        attach.isPerson = YES;
        NSString *name = [NSString stringWithFormat:@"@%@ ", attach.person.name];
        attach.needPushStr = name;
        if (![attach.person.name isEmpty]) {
            [_staticALLNameArray addObject:attach.person];
        }

        //这个颜色需要 换成黑的 现在留着好识别
        attach.image = [self imageWithString:name font:[UIFont systemFontOfSize:17] color:[UIColor colorWithHexString:@"#2DC4B9"]];
        //attach.image = [self imageWithString:name font:[UIFont systemFontOfSize:17] color:[UIColor blackColor]];
        CGSize size = [name sizeWithFont:[UIFont systemFontOfSize:17] constrainedToSize:CGSizeMake(CGFLOAT_MAX, 30) lineBreakMode:NSLineBreakByWordWrapping];
       //这里因为是生成的图片 所以大小需要自己微调 
        attach.imageSize = CGSizeMake(size.width - 5, self.discussView.font.pointSize + 3);
        NSAttributedString *imagestr = [NSAttributedString attributedStringWithAttachment:attach];
        NSMutableAttributedString *mutablImageStr = [[NSMutableAttributedString alloc] initWithAttributedString:imagestr];
        NSDictionary *attributes = @{NSFontAttributeName : [UIFont systemFontOfSize:self.discussView.font.pointSize]};
        [mutablImageStr addAttributes:attributes range:NSMakeRange(0, imagestr.length)];
        [addMutableAttributeStr appendAttributedString:mutablImageStr];
    }
    if (addMutableAttributeStr.length > 0) {
        [self.discussView.textStorage insertAttributedString:addMutableAttributeStr atIndex:self.discussView.selectedRange.location];
    }
    self.discussView.attributedText = [[NSAttributedString alloc] initWithAttributedString:addMutableAttributeStr];
    self.discussView.selectedRange = NSMakeRange(self.discussView.attributedText.length, 0);
    NSLog(@"%@", self.discussView.text);

    [self reloadTextViewFrame:self.discussView];
}

这个生成图片的方法:

 attach.image = [self imageWithString:name font:[UIFont systemFontOfSize:17] color:[UIColor colorWithHexString:@"#2DC4B9"]];

见:把文字转换成图片
上面的思路就是 把 DD_Media_Atment 变成图片 加入 self.discussView.attributedText

于是我们的效果如下


8.jpeg

好了,显示似乎没有问题了,
那么接下来就是发送私信了:

//Content 需要处理 因为文中掺杂了表情和文字 还有抽象图片 
    DDMediaAtCustomMessage *message = [DDMediaAtCustomMessage messageWithContent:Content title:self.transmitleftTitleLabel.text articleid:@"这里需要接口穿过来" imageUrl:_infoModel.pushimageurl];
    Person *mine = [DDTool getMySelf];
    RCUserInfo *user = [[RCUserInfo alloc] initWithUserId:mine.uid name:mine.name portrait:mine.avatar];
    for (int i = 0; i < _aLLNameArray.count; i++) {
        Person *person = [_aLLNameArray objectAtIndex:i];
        message.senderUserInfo = user;
        [[RCIM sharedRCIM] sendMessage:ConversationType_PRIVATE
            targetId:person.uid
            content:message
            pushContent:[NSString stringWithFormat:@"%@:%@", mine.name, Content]
            pushData:nil
            success:^(long messageId) {
            }
            error:^(RCErrorCode nErrorCode, long messageId){
            }];
    }

DDMediaAtCustomMessage 是我自定义的融云消息,融云的内容不在本文范畴,不再那啥了,嘿嘿。
点击发送:biubiu~

9.jpeg

似乎可以了,结束了,但是我们有以下问题 :
1. 输入文字以后,再输入表情键盘的表情,前面的文字丢失
2.输入表情以后,后面的文字失去了自己的颜色和大小,变成了系统默认的。
3.怎么拼接表情 和文字 以及抽象的图片 到 融云消息 Content
4.咱们好想没写表情键盘里自带的删除的功能

image.png

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

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,079评论 4 62
  • 应该是这样的 我打碎存钱罐 买来你的诗 读整个初春的愁 可是趴在商店柜台上 那只毛绒熊捂住眼睛 灯闪一下就一颗泪 ...
    花点原创阅读 151评论 0 2
  • “老师,我不愿当寝室长了,我想搬出我们寝室” ,看着412寝室长愁眉苦脸的向我请求 , 我微笑着说:“呀...
    一帆风顺都社平阅读 190评论 1 0
  • 我不爱你是一个模样 我爱你是另一个模样 你渴求我爱你 却只爱我不爱你的样子 我举棋不定 怕爱了,你便不想要了
    TinaFu阅读 237评论 0 0
  • 袁绍死了。真是空招俊杰三千客。
    亚瑟王666阅读 430评论 0 0