iOS 发布了很多关于屏幕上键盘的通知。下面列出了这些通知的简要解释:

UIKeyboardWillShowNotification

当键盘即将要显示的时候将会发出这个通知。这个通知包含了用户信息库,库里面包括了键盘的各种 信息,键盘将以动画的形式显示在屏幕上。

UIKeyboardDidShowNotification

当键盘显示在屏幕上时将发出这个通知。

UIKeyboardWillHideNotification

当键盘将要从屏幕上移除时将会发出此通知。通知里包含了用户信息库,库里包括了各种关于键盘信 息的详细信息,当键盘隐藏时的动画,动画的持续时间,等等。

UIKeyboardDidHideNotification
当键盘完全隐藏后将发出此通知。

正如前面所提到的,只有 UIKeyboardWillShowNotification 和 UIKeyboardWillHideNotification 这两个通知
携带了用户信息。下面是这些信息的关键字,也许这对你有用。

UIKeyboardAnimationCurveUserInfoKey

这个关键字的值指明了动画的类型,用来显示和隐藏键盘。这个关键字包含了一个 NSNumber 类型的值, 此类型包含了一个NSUInteger 类型无符号整数

UIKeyboardAnimationDurationUserInfoKey 这个键值指明了键盘显示或隐藏的动画所用的时间。这个键包含一个 NSNumber 类型的值,此类包

含一个 double 类型的双字节值。

UIKeyboardFrameBeginUserInfoKey

这个键值指明了键盘在动画之前的框架。假如键盘将要显示时,在显示之前将这个框架传递给这个动 画。假如键盘已经显示了并即将要隐藏时,这个框架将会传递给这个隐藏动画,在键盘消失之前。这个键包含 了一个 CGRect 类型的值。

UIKeyboardFrameEndUserInfoKey

这个键值指明了动画完成后的键盘框架。假如键盘即将要显示时,这个框架将会在键盘完全显示后传递给键盘。。假如键盘已经完全显示,而且将要隐藏时,在完全隐藏后这个框架将会传递给键盘。这个键值包 含了一个 CGRect 类型的值。

注:键盘框架

这个框架被作为 iOS 键盘以开始和结束来发布的,它不会考虑设备的方向。我们需要
将 CGRect 值转换成一个关于坐标的值,后面会提到。

iOS5之前,iPhone上的键盘的高度是固定为216.0px高的,中文
汉字的选择框是悬浮的,所以不少应用都将此高度来标注键盘的高度。可是在iOS5中,键盘布局变了,尤其是中文输入时,中文汉字选择框就固定在键盘上方,
这样就使得原本与键盘紧密贴合的界面视图被中文汉字选择框给覆盖住了。一方面影响了界面的美观,另一方面,如果被覆盖的部分就是文本输入框的话,用户就无
法看到输入的内容了。因此这个问题就必须得解决了。

解决方法:

其实在一开始使用216.0px这个固定值来标注键盘的高度就是错误的。因为在iOS3.2以后的系统中,苹果就提供了键盘使用的api以及demo程序----"KeyboardAccessory"。

处理键盘事件的正确方法是这样的。(包括获取键盘的高度以及键盘弹出和消失动画的时间)

1)在要使用键盘的视图控制器中,接收键盘事件的通知:

- (void)viewDidLoad

{

[superviewDidLoad];

//键盘高度变化通知,ios5.0新增

#ifdef __IPHONE_5_0

float version = [[[UIDevicecurrentDevice] systemVersion]
floatValue];

if (version >=5.0)

{

[[NSNotificationCenterdefaultCenter]
addObserver:selfselector:@selector(keyboardWillShow:)
name:UIKeyboardWillChangeFrameNotificationobject:nil];

}

#endif

//键盘将要出现时的触发事件

[[NSNotificationCenterdefaultCenter]addObserver:selfselector:@selector(keyboardWillShow:)name:UIKeyboardWillShowNotificationobject:nil];

//键盘将要消失时的触发事件

[[NSNotificationCenterdefaultCenter]addObserver:selfselector:@selector(keyboardWillBeHidden:)name:UIKeyboardWillHideNotificationobject:nil];

}

获取键盘的动画参数:

NSDictionary *info = [notification userInfo];

NSTimeInterval duration = 0;

UIViewAnimationCurve curve;

[[info objectForKey:UIKeyboardAnimationDurationUserInfoKey] getValue:&duration];

[[info objectForKey:UIKeyboardAnimationCurveUserInfoKey] getValue:&curve];

2)然后添加键盘事件的处理代码:获取到当前keyboard的高度以及动画时间,然后对视图进行对应的操作即可。

-(void)keyboardWillShow:(NSNotification *)notification

{

NSDictionary *info = [notification
userInfo];

NSValue *value = [info
objectForKey:@"UIKeyboardFrameEndUserInfoKey"];

CGSize keyboardSize = [value
CGRectValue].size;//获取键盘的size值

NSLog(@"value %@ %f",value,keyboardSize.height);

//获取键盘出现的动画时间

NSValue *animationDurationValue = [info
objectForKey:UIKeyboardAnimationDurationUserInfoKey];

NSTimeInterval animationDuration;

[animationDurationValue
getValue:&animationDuration];

- keyboardSize.;

NSLog(@"height = %f",height);

NSTimeInterval animation = animationDuration;

//视图移动的动画开始

[UIViewbeginAnimations:nilcontext:nil];

[UIViewsetAnimationDuration:animation];

CGRect frame =CGRectMake(self.view.frame.origin.x,
height, self.view.frame.size.width,self.view.frame.size.height);

self.view.frame = frame;

[UIViewcommitAnimations];

}

-(void)keyboardWillBeHidden:(NSNotification *)aNotification

{

NSDictionary *info = [aNotification
userInfo];

NSValue *animationDurationValue = [info
objectForKey:UIKeyboardAnimationDurationUserInfoKey];

NSTimeInterval animationDuration;

[animationDurationValue
getValue:&animationDuration];

NSTimeInterval animation = animationDuration;

[UIViewbeginAnimations:@"animal"context:nil];

[UIViewsetAnimationDuration:animation];

self.view.frame = [[UIScreenmainScreen]
bounds];

[UIViewcommitAnimations];

}

duration在默认【中文拼音输入法】弹出时,不能正确获取duration,需要加一行代码修正:

duration = (duration > 0 ? duration: 0.25);//已知,IOS5.0.1里面键盘弹出动画的0.25S的,瑕疵:如果这里动画时间不是0.25就有可能动画不同步了

键盘处于显示状态的UIViewController被UINavigationController pop出去时,也会发出 UIKeyboardWillHideNotification通知,只不过这个键盘隐藏的轨迹是【从左到右的滑动】而不是从上到下的收起。所以,如果想在这个通知的响应代码里去调整UI(比如恢复底部工具条的origin.y使其始终居于底部),应该避免横向滑动键盘消失这种情况。可以通过以下响应代码来鉴别是否横向滑动导致键盘消失:

NSDictionary *info = [notification userInfo];

CGPoint kbEndOrigin = [[info objectForKey:UIKeyboardFrameEndUserInfoKey] CGRectValue].origin;

if(kbEndOrigtin.x > 0) {//横向滑动导致了键盘消失,不必调整UI

return;

}

//恢复UI显示

3)在dealloc方法里,移除键盘事件的通知:

-(void)dealloc

{

[[NSNotificationCenter defaultCenter] removeObserver:self];

[super dealloc];

}

IOS - 键盘处理的更多相关文章

  1. iOS开发小技巧--iOS键盘 inputView 和 inputAccessoryView

    iOS键盘 inputView 和 inputAccessoryView 1.inputAccessoryView UITextFields和UITextViews有一个inputAccessoryV ...

  2. IOS键盘弹出、隐藏

    IOS键盘 UIKeyboardFrameBeginUserInfoKey:动画开始前键盘的size UIKeyboardFrameEndUserInfoKey:动画结束后键盘的size - (voi ...

  3. ios键盘弹起 body的高度拉长,页面底部空白问题。ios软键盘将页面抵到上面后,关闭软键盘页面不回弹的问题。

    js 监听ios手机键盘弹起和收起的事件 /* js 监听ios手机键盘弹起和收起的事件 */ document.body.addEventListener('focusin', () => { ...

  4. iOS 键盘自适应(IQKeyboardManager)使用小结

    IQKeyboardManager Github地址 经常在开发一个应用程序,我们遇到了一个问题,iPhone的键盘上滑覆盖的UITextField / UITextView.IQKeyboardMa ...

  5. iOS键盘中英文切换键盘高度获取通知方法

    iOS键盘中英文切换键盘高度获取通知方法, 有需要的朋友可以参考下. 注册通知 - (void)viewWillAppear:(BOOL)animated { [super viewWillAppea ...

  6. iOS 键盘遮挡输入框万能解决方案(多个输入框)

    效果图如下: 思路分析: 代码: 知识点: 问题: 效果图如下: 思路分析: 当我们有很多输入框时,有时候键盘弹出来会遮挡着输入框.我们需要获取输入框和键盘相对于最外层视图的位置来判断是否遮挡,如果遮 ...

  7. h5页面ios键盘弹出收起后页面底部留白问题

    <input placeholder="验证码" type="tel" v-model="verify" maxlength=&quo ...

  8. iOS键盘输入屏幕上移

    在iOS开法中经常会遇到键盘遮挡屏幕的事情(比如输入账号密码验证码等等),就使得原本都不大的屏幕直接占了一半甚至更多的位置,这倒无所谓,关键是挡住了下面的按钮.这样的话按钮的事件也就触发不了,最好的解 ...

  9. iOS 键盘类型

    版权声明:本文为博主原创文章.请尊重作者劳动成果,转载请注明出处. UIKeyboardTypeDefault: UIKeyboardTypeASCIICapable: UIKeyboardTypeN ...

随机推荐

  1. glusterFS分布式文件系统的搭建

    准备工作 1.安装IBA yum install libradmacm librdmacm-devel libmlx4 infiniband-diags 2.配置IPOIB /etc/sysconfi ...

  2. 系列文章:老项目的#iPhone6与iPhone6Plus适配#(持续更新中,更新日期2014年10月12日 星期日 )

    本文永久地址为http://www.cnblogs.com/ChenYilong/p/4020399.html ,转载请注明出处. ********************************** ...

  3. 扁平化设计五大原则(转自CSDN翻译)

    Cousins表示他虽然对扁平化设计的感觉非常强烈,但并没有特别热爱或者特别讨厌扁平化设计.他认为好的设计不应当局限于某种设计风格,而需要更注重可用性.有用性.如果因为时尚的缘故,那就顺其自然吧.但该 ...

  4. 教你如何删除tomcat服务器的stdout.log文件

    用Tomcat做WEB服务器的人都知道,有个很让人头痛的问题,就是stdout.log日志文件会自动增长,而且增长得很快. 先来看看我的痛处吧,公司有个WEB应用,就是用Tomcat作为服务器的,由于 ...

  5. 各大互联网公司前端面试题(js)

    对于巩固复习js更是大有裨益.    初级Javascript: 1.JavaScript是一门什么样的语言,它有哪些特点? 没有标准答案. 2.JavaScript的数据类型都有什么? 基本数据类型 ...

  6. fullpage.js小技巧

    创造一个自适应的section: 在 section 类旁边加上类 fp-auto-height 例如:<div class="section fp-auto-height" ...

  7. Unity手游之路<十二>手游资源热更新策略探讨

    http://blog.csdn.net/janeky/article/details/17666409 上一次我们学习了如何将资源进行打包.这次就可以用上场了,我们来探讨一下手游资源的增量更新策略. ...

  8. tomcat管理端的页面安全措施

    由于公司的项目并未启用nginx负载均衡,所以自然也没用到tomcat与web应用一对一的安全操作,经常会遇到 重启单个应用又不想重启tomcat的情况.同时,又出于安全考虑,将tomcat的默认管理 ...

  9. 使用srvany.exe将任何程序作为Windows服务运行

    使用srvany.exe将任何程序作为Windows服务运行 2011 年 3 月 7 日 !本文可能 超过1年没有更新,今后内容也许不会被维护或者支持,部分内容可能具有时效性,涉及技术细节或者软件使 ...

  10. div元素抓取

    var files = $(".button").find("input[type='image']"); files.each(function() { $( ...