IOS开发之keyboard弹出遮盖输入框

研究ios开发有段时间了,但是一直没有时间把所积累下的东西写出来分享,现在打算抽些时间把所学到的东西跟大家一一分享出来,让那些像我一样自学ios的童鞋们也少走些弯路。
开发中很多时候会遇到一些情况,很小的细节往往会弄的人不知道改怎么去处理。


在很多时候,当你在View上面点击一个UITextFiled的时候,弹出键盘会遮挡住输入框,你根本不知道自己在输入些什么,以前做这方面的处理的时候,是这样写的

-(void) viewUp:(UIVIew *) view
{
	UIView beginAnimations:nil context:nil];
            [UIView setAnimationDuration:0.3];
            [UIView setAnimationCurve:UIViewAnimationCurveEaseInOut];
            CGPoint center = contentViewCenter;
            center.y -= 50;
            contentView.center = center;
            [UIView commitAnimations];
}

只是将UITextFiled往上移动,输入完成之后,再将UITextFiled移动回来,但是当键盘出现中英文切换的时候,出现候选文字的时候,仍会造成遮挡,这该怎么解决呢?
以前在面试工作的时候,也碰到过类似的问题,当时我回答的就只是上面一个方法,结果面试官一笑置之,呵呵。

后来查了查文档,Apple早就做过像出现这种情况的时候的处理方法,就是在View加载的时候,注册2个NSNotification,这两个NSNotification分别为:KeyboardWillShow 和 KeyboardWillHide
注册方法如下:

 [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardWillShow:) name:UIKeyboardWillShowNotification object:nil];
    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardWillHide:) name:UIKeyboardWillHideNotification object:nil];

还需要在定义2个接收Notification的方法来响应事件:
- (void) keyboardWillShow:(NSNotification *) notification
{
    NSDictionary *userInfo = [notification userInfo];
    
    NSValue *aValue = [userInfo objectForKey:UIKeyboardFrameEndUserInfoKey];
  
    CGRect keyboardRect = [aValue CGRectValue];
    keyboardRect = [self.view convertRect:keyboardRect fromView:nil];
    CGFloat keyboardTop = keyboardRect.origin.y;
    CGRect newTextViewFrame =CGRectMake(0, keyboardTop-30, self.view.bounds.size.width, 30);
    NSValue *animationDurationValue = [userInfo objectForKey:UIKeyboardAnimationDurationUserInfoKey];
    NSTimeInterval animationDuration;
    [animationDurationValue getValue:&animationDuration];
    [UIView beginAnimations:nil context:NULL];
    [UIView setAnimationDuration:animationDuration];
    self.textView.frame = newTextViewFrame;
    [UIView commitAnimations];

}

-(void)keyboardWillHidden:(NSNotification *) notification
{
//这里的操作跟Willshow一样,只需要将ViewFrame变下就OK
self.textView.frame = newTextViewFrame;
}


上面从notification里面读出来的信息中都包含有当前键盘弹出所涉及到的各种数据
NSDictionary *userInfo = [notification userInfo];
打印出来的结果如下:

 {
    UIKeyboardAnimationCurveUserInfoKey = 0;
    UIKeyboardAnimationDurationUserInfoKey = "0.25";
    UIKeyboardBoundsUserInfoKey = "NSRect: {{0, 0}, {320, 216}}";
    UIKeyboardCenterBeginUserInfoKey = "NSPoint: {160, 588}";
    UIKeyboardCenterEndUserInfoKey = "NSPoint: {160, 372}";
    UIKeyboardFrameBeginUserInfoKey = "NSRect: {{0, 480}, {320, 216}}";
    UIKeyboardFrameChangedByUserInteraction = 0;
    UIKeyboardFrameEndUserInfoKey = "NSRect: {{0, 264}, {320, 216}}";
}

从这个NSDictionary的键就能很容易的知道这些数据所代表的意思,也能很块的找到你所需要的数据


其次还要为UITextFiled定义一个Delegate,执行resignFirstResponder操作,他会自动去调用Notification的操作,这个简单,就不必写了哦




微信公众平台已开通,加个关注呗。我们一起学习,一起进步
微信号:ios开发总汇
百度知道群:开发者俱乐部

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在微信小程序开发中,如果在iOS手机上遇到了键盘弹起时会遮挡上面内容的问题,可以通过以下方法解决。 首先,我们需要获取键盘的高度。在小程序中,可以使用wx.getSystemInfoSync()方法来获取系统信息,其中包括键盘的高度。 接下来,我们需要监听键盘的弹起和隐藏事件。可以通过监听页面的focus和blur事件来实现。当input框被选中时(focus事件),我们可以将页面整体上移一个键盘高度的距离,以保证输入框不被键盘遮挡。当input框失去焦点时(blur事件),我们将页面恢复到原始位置。 具体实现时,可以在页面的onLoad生命周期函数中调用wx.getSystemInfoSync()方法获取系统信息,并存储键盘的高度。然后在页面的focus和blur事件中分别设置页面的上下边距,以达到上移和恢复的效果。 示例代码如下: ``` // 在页面的onLoad生命周期函数中获取系统信息 onLoad: function() { var that = this; wx.getSystemInfoSync({ success: function(res) { that.setData({ keyboardHeight: res.windowHeight * 0.75 // 假设键盘高度占屏幕高度的3/4 }); } }); }, // input框获取焦点时的事件处理函数 onFocus: function() { this.setData({ marginTop: -this.data.keyboardHeight }); }, // input框失去焦点时的事件处理函数 onBlur: function() { this.setData({ marginTop: 0 }); } ``` 需要注意的是,根据不同手机型号和键盘设置的不同,键盘的高度可能会有所差异,因此上述代码中获取到的键盘高度是一个近似值,可以根据实际情况进行调整。 以上是解决微信小程序开发iOS手机键盘弹起时会遮挡上面内容的一种方法,希望能对你有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值