ios键盘回收,弹出

例如一个UIScrollView上有多上输入框,为了避免键盘遮盖整理了一下方法,大家可以借鉴一下。

- (void)dealloc

{

[[NSNotificationCenter defaultCenter]removeObserver:self name:UIKeyboardWillShowNotification object:nil];

[[NSNotificationCenter defaultCenter]removeObserver:self name:UIKeyboardWillHideNotification object:nil];

}// 释放

 


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

[[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 *value = [userInfo objectForKey:UIKeyboardFrameEndUserInfoKey];

CGRect keyboardRect = [value CGRectValue];

CGFloat keyboardY = keyboardRect.origin.y;

CGRect frame = self.m_MoneyView.frame;

UIWindow *keyWindow = [[UIApplication sharedApplication] keyWindow];

UIView *first= [keyWindow performSelector:@selector(firstResponder)];

CGFloat firstMaxY = CGRectGetMaxY(first.frame);

// 获取当前控件在Window中的坐标

UIWindow * window=[[[UIApplication sharedApplication] delegate] window];

CGRect firstResponderBounds = [first convertRect:first.bounds toView:window];

CGFloat firstResponderH = CGRectGetHeight(first.bounds);

firstMaxY = firstResponderBounds.origin.y + firstResponderH;

if (firstMaxY > keyboardY) {

frame.origin.y -= (firstMaxY - keyboardY);}

self.m_MoneyView.frame = frame;}

//当键退出时调用

- (void)keyboardWillHide:(NSNotification *)aNotification

{

if (self.m_MoneyView.frame.origin.y != 0) {

self.m_BackView.frame = self.view.bounds;}

}



作者:天下只有一个
链接:https://www.jianshu.com/p/96c829ed78da
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值