事件处理之nextResponder

一,通过分类向上传递信息

参考链接:http://www.jianshu.com/p/eb775f5d9032

这里通过给UIResponder添加分类方法:

- (void)routerInfo:(id)info;
- (void)routerInfo:(id)info sender:(UIResponder *)sender; //带有发送者的方法

省去了向上传递数据的代理方法和block调用。作者通过一个在cell上传递数据到控制器中的例子展示了nextResonder来处理事件信息处理的简便性。这里有个注意点需要提一下:如果tableView是自定义的并且实现了- (void)routerInfo:(id)info方法,接收了数据。那么控制器中就不能响应- (void)routerInfo:(id)info方法的事件了。如果控制器还需要处理,在tableView中继续调用该方法。

cell中的实现:

@implementation OKTestTableViewCell
- (void)awakeFromNib {
    [super awakeFromNib];
    // Initialization code
}
- (IBAction)btnClick:(id)sender {
    [self.nextResponder routerInfo:self.label.text];
}
@end

tableView中的实现:

@implementation OKTestTableView
//如果tableView中不实现,cell的事件就会向上抛给Controller处理。
- (void)routerInfo:(id)info {
    NSLog(@"tableView中的routerInfo");
    id tableViewData = nil;
    //如果需要向上抛,那么就继续调用
    [self.nextResponder routerInfo:tableViewData];
}
@end

如果tableView中没有实现- (void)routerInfo:(id)info 方法,而控制器中实现了,那么控制器会直接获取到cell中传递的信息。

控制器中:

- (void)routerInfo:(id)info {
    //如果tableView中没有实现,控制器就直接获取cell传递的info信息
    NSLog(@"控制器的routerInfo:%@",info);
}

二,长按显示UIMenuController时,防止键盘退出

参考:http://www.jianshu.com/p/b64a57538f74

实现长按弹出UIMenu的功能,需要在长按方法中设置控件(UILabel,UITextField)成为第一响应者,并且在canBecome:

- (void)longClick:(UILongPressGestureRecognizer *)longGesture {

    if (longGesture.state == UIGestureRecognizerStateBegan) {
        // 菜单已经打开不需重复操作
        UIMenuController *menu=[UIMenuController sharedMenuController];
        if (menu.isMenuVisible)return;
        //如果要不收起键盘还需要复写nextResponder方法
        //        if ([textField isFirstResponder]) {
        //            textField.inputNextResponder = self;//关键代码
        //        }else{
        //            [self becomeFirstResponder];
        //        }
          //注意要设置为第一响应者
          [self becomeFirstResponder];
        UIMenuItem *copy = [[UIMenuItem alloc] initWithTitle:@"复制"action:@selector(copyItem:)];
        UIMenuItem *paste = [[UIMenuItem alloc] initWithTitle:@"粘贴" action:@selector(pasteItem:)];
        [menu setMenuItems:@[copy,paste]];

        [menu setTargetRect:self.bounds inView:self];
        [menu setMenuVisible:YES animated:YES];
       //如果复写nextResponder方法,还要在menu隐藏时,移除inputNextResponder
       // [[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(menuWillHidden) name:UIMenuControllerWillHideMenuNotification object:nil];

    }
}

如果是可以输入的控件需要在键盘弹起时还能复制等长按操作,那么就要增加一个变量来保持自己的第一响应者身份:

MATextView.h
@interface MATextView : UITextView
@property (nonatomic, weak) UIResponder *inputNextResponder;
@end

MATextView.m

@implementation MATextView
- (UIResponder *)nextResponder {
 if (_inputNextResponder != nil)
   return _inputNextResponder;
  else
    return [super nextResponder];
}
 
//在设置外部的responder后,就不能执行方法
- (BOOL)canPerformAction:(SEL)action withSender:(id)sender {
if (self.inputNextResponder != nil) {
    return NO;
}
else {
    return [super canPerformAction:action withSender:sender];
}
}
@end

需要拷贝的自定义控件里,必须设置为YES才能添加UIMenu

- (BOOL)canBecomeFirstResponder {
    return YES;
}

如果没有实现本方法就只有自定义的item,如果实现了,就是实现中的item

- (BOOL)canPerformAction:(SEL)action withSender:(id)sender
{
    NSLog(@"%@", NSStringFromSelector(action));
    if (action == @selector(cut:)
        || action == @selector(copy:)
        || action == @selector(paste:) || action == @selector(copyItem:)|| action ==     @selector(pasteItem:)) {
        return YES; // YES ->  代表我们只监听 cut: / copy: / paste:方法
    }
    return NO; // 除了上面的操作,都不支持
}

如下是照搬代码供参考,如果添加了inputNextResponder还要将其置空:

- (void)copyBtnWillHidden{
    UIView *superView =  self.superview.superview.superview;
    KFChatToolView *toolView = [superView viewWithTag:kKF5ChatToolViewTag];
    if ([toolView isKindOfClass:[KFChatToolView class]]) {
            toolView.textView.inputNextResponder = nil;
    }
    self.chatMessageBackgroundView.highlighted = NO;
    [[NSNotificationCenter defaultCenter]removeObserver:self];
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,902评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,037评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,978评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,867评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,763评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,104评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,565评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,236评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,379评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,313评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,363评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,034评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,637评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,719评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,952评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,371评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,948评论 2 341

推荐阅读更多精彩内容