iOS获取键盘弹出高度,监听键盘弹出退出

    //增加监听,当键盘出现或改变时收出消息

    [[NSNotificationCenter defaultCenter] addObserver:self

                                             selector:@selector(keyboardWillShow:)

                                                 name:UIKeyboardWillShowNotification

                                               object:nil];

    //增加监听,当键退出时收出消息

    [[NSNotificationCenter defaultCenter] addObserver:self

                                             selector:@selector(keyboardWillHide:)

                                                 name:UIKeyboardWillHideNotification

                                               object:nil];


//当键盘出现或改变时调用

- (void)keyboardWillShow:(NSNotification *)aNotification

{

    //获取键盘的高度

    NSDictionary *userInfo = [aNotification userInfo];

    NSValue *aValue = [userInfo objectForKey:UIKeyboardFrameEndUserInfoKey];

    CGRect keyboardRect = [aValue CGRectValue];

    int height = keyboardRect.size.height;


    [self.view bringSubviewToFront:self.chatSessionInputBarControl];

    

        [UIView animateWithDuration:0.4 animations:^{

            self.midView.frame = CGRectMake(0, 64, VIEW_WIDTH, 42);

            self.scrollView.frame = CGRectMake(0, 64+42, self.view.frame.size.width, VIEW_HEIGHT-height-64-42-50);

            self.conversationMessageCollectionView.contentOffset = CGPointMake(0, 820);

        }];

}


//当键退出时调用

- (void)keyboardWillHide:(NSNotification *)aNotification {

    [UIView animateWithDuration:0.4 animations:^{

        self.midView.frame = CGRectMake(0, 160, VIEW_WIDTH, 42);

        self.scrollView.frame = CGRectMake(0, 160+42, self.view.frame.size.width, self.view.frame.size.height-160-50-42);

        self.conversationMessageCollectionView.contentOffset = CGPointMake(0, 660);

    }];

}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值