`

ios5动态获取键盘高度

 
阅读更多

  ios5之前,iphone上的键盘的高度是固定为216.0px高的,中文汉字的选择框是悬浮的,所以不少应用都将此高度来标注键盘的高度(包括米聊也是这么做的)。
  可是在ios5中,键盘布局变了,尤其是中文输入时,中文汉字选择框就固定在键盘上方,这样就使得原本与键盘紧密贴合的界面视图被中文汉字选择框给覆盖住了。一方面影响了界面的美观,另一方面,如果被覆盖的部分就是文本输入框的话,用户就无法看到输入的内容了。因此这个问题就必须得解决了。
解决方法:
  其实在一开始使用216.0px这个固定值来标注键盘的高度就是错误的。因为在ios3.2以后的系统中,苹果就提供了键盘使用的api以及demo程序——“KeyboardAccessory”。
  处理键盘事件的正确方法是这样的:(包括获取键盘的高度以及键盘弹出和消失动画的时间)
  1)在要使用键盘的视图控制器中,接收键盘事件的通知:
        [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardWillShow:) name:UIKeyboardWillShowNotification object:nil];
        [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardWillHide:) name:UIKeyboardWillHideNotification object:nil];

        // 键盘高度变化通知,ios5.0新增的 
#ifdef __IPHONE_5_0
        float version = [[[UIDevice currentDevice] systemVersion] floatValue];
        if (version >= 5.0) {
            [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardWillShow:) name:UIKeyboardWillChangeFrameNotification object:nil];
        }
#endif

  2)然后添加键盘事件的处理代码:
    获取到当前keyboard的高度以及动画时间,然后对视图进行对应的操作即可。
#pragma mark -
#pragma mark Responding to keyboard events
- (void)keyboardWillShow:(NSNotification *)notification {
   
    /*
     Reduce the size of the text view so that it's not obscured by the keyboard.
     Animate the resize so that it's in sync with the appearance of the keyboard.
     */
   
    NSDictionary *userInfo = [notification userInfo];
   
    // Get the origin of the keyboard when it's displayed.
    NSValue* aValue = [userInfo objectForKey:UIKeyboardFrameEndUserInfoKey];
   
    // Get the top of the keyboard as the y coordinate of its origin in self's view's coordinate system. The bottom of the text view's frame should align with the top of the keyboard's final position.
    CGRect keyboardRect = [aValue CGRectValue];
   
    // Get the duration of the animation.
    NSValue *animationDurationValue = [userInfo objectForKey:UIKeyboardAnimationDurationUserInfoKey];
    NSTimeInterval animationDuration;
    [animationDurationValue getValue:&animationDuration];
   
    // Animate the resize of the text view's frame in sync with the keyboard's appearance.
    [self moveInputBarWithKeyboardHeight:keyboardRect.size.height withDuration:animationDuration];
}


- (void)keyboardWillHide:(NSNotification *)notification {
   
    NSDictionary* userInfo = [notification userInfo];
   
    /*
     Restore the size of the text view (fill self's view).
     Animate the resize so that it's in sync with the disappearance of the keyboard.
     */
    NSValue *animationDurationValue = [userInfo objectForKey:UIKeyboardAnimationDurationUserInfoKey];
    NSTimeInterval animationDuration;
    [animationDurationValue getValue:&animationDuration];
   
    [self moveInputBarWithKeyboardHeight:0.0 withDuration:animationDuration];
}
  3)在视图控制器消除时,移除键盘事件的通知:
[[NSNotificationCenter defaultCenter] removeObserver:self];

//原文:http://www.cnblogs.com/zhulin/archive/2011/10/15/2213687.html
分享到:
评论

相关推荐

    弹出键盘,监听键盘高度

    在iOS应用开发中,特别是在构建用户交互界面时,"弹出键盘,监听键盘高度"是一个常见且重要的需求。当用户需要在屏幕上输入信息,如评论、搜索或填写表单时,软键盘的弹出会影响到屏幕上的其他元素,尤其是那些位于...

    ios-监听键盘高度(包括第三发键盘).zip

    这个“ios-监听键盘高度(包括第三方键盘)”的压缩包文件提供了一个解决方案,它通过将代码封装成一个`NSObject`的分类来实现对键盘高度变化的监听,包括第三方键盘。 首先,我们来理解为什么需要监听键盘高度。当...

    iOS_输入栏自适应键盘的高度

    通过以上步骤,我们可以实现输入栏自适应键盘高度的功能,提供一个更加友好的用户界面。这种技术尤其适用于聊天应用、表单填写等场景,确保用户在输入时始终能看到他们正在操作的内容。在iOS开发中,关注用户体验的...

    获取键盘高度

    总结,动态获取键盘高度在iOS应用开发中是一个常见的需求,通过监听键盘的通知并解析其中的信息,我们可以准确地得知键盘的高度变化,进而优化用户体验。在Objective-C中,这一过程主要通过`NSNotificationCenter`和...

    iOS 获取系键盘

    1. **键盘高度**:获取键盘高度通常通过`UIKeyboardWillShowNotification`和`UIKeyboardWillHideNotification`通知来实现。当键盘将要显示或隐藏时,系统会发送这些通知。我们可以在通知的回调中获取到一个`...

    ios-键盘高度自适应.zip

    在iOS开发中,处理键盘高度自适应是一项常见的需求,特别是在设计具有输入框的界面时,为了提供良好的用户体验,我们需要确保键盘弹出时,输入框不会被遮挡。"ios-键盘高度自适应.zip"这个压缩包文件很可能包含了...

    jQuery苹果IOS虚拟键盘

    本项目“jQuery苹果IOS虚拟键盘”旨在为iOS设备提供一个模拟的虚拟键盘,它基于jQuery 1.11.3版本进行开发,这个版本是jQuery的一个稳定版,具有良好的浏览器兼容性和性能。 1. **jQuery基础知识**:jQuery的核心...

    ios-完全自定义键盘.zip

    通过这个项目,我们可以学习到如何获取到系统键盘的视图,并对其进行高度定制,以适应我们的特定需求。 首先,我们需要了解在iOS中如何获取键盘的视图。系统键盘是通过UIInputViewController类来管理的,它提供了一...

    IOS聊天软键盘处理

    为解决这个问题,你需要监听`UIKeyboardDidChangeFrameNotification`通知,获取新的键盘高度并相应地调整布局。 在项目中,`iosChat1`可能是一个示例代码或资源文件,包含了处理这些问题的具体实现。通过查看和学习...

    ios7隐藏虚拟键盘,解决键盘挡住UITextField问题

    在iOS开发中,特别是在iOS 7及更高版本中,用户界面设计的一个常见问题是虚拟键盘弹出时会遮挡UITextField或UITextView,导致用户无法看到正在输入的文本。本篇文章将详细探讨如何解决这一问题,主要关注如何在iOS 7...

    iOS textField弹出自定义键盘(日期时间、省市、国家)

    2. 键盘高度:根据需要调整自定义键盘的高度,以适应不同屏幕尺寸的设备。 3. 键盘布局:根据不同的输入场景,灵活调整键盘的布局和功能键。 4. 键盘记忆:保存用户上次选择的键盘类型,下次打开时自动加载。 5. ...

    ios-可以上升的键盘如 有信键盘 触宝键盘 优壳键盘.zip

    在iOS平台上,用户可以选择各种第三方键盘来替换系统默认的键盘,以满足个性化需求或提高输入效率。本资源包“ios-可以上升的键盘如 有信键盘 触宝键盘 优壳键盘.zip”可能包含了一些可以提升用户体验的键盘应用,如...

    ios-仿QQ、微信辅助输入视图动态自适应高度.zip

    本文将深入探讨如何实现这样一个功能,即辅助输入视图(InputView)动态自适应键盘高度。 首先,我们需要了解iOS中的InputView。InputView是苹果提供的一个特性,它允许开发者自定义输入控件,替代系统的默认键盘。...

    动态获取字符串高度

    标题"动态获取字符串高度"和描述"根据文本内容,设定字体大小,文本宽度,动态获取键盘高度!"涉及到的关键知识点主要包括:UILabel的使用、文本布局计算、以及可能与键盘高度相关的交互。 首先,我们来看`+...

    ios-键盘自适应.zip

    // 根据键盘高度调整内容视图的位置 self.contentView.frame.origin.y -= keyboardSize.height } } // 键盘显示完成后的处理,可能需要做额外的动画效果 @objc func keyboardDidShow(_ notification: ...

    iOS 键盘平滑动画.zip

    1. 计算键盘的高度:通过`UIKeyboardFrameEndUserInfoKey`从通知的userInfo字典中获取键盘的高度。 2. 预处理视图布局:根据键盘的高度,可能需要调整输入框或其他视图的位置,以确保它们不被键盘遮挡。 3. 执行动画...

    ios 类似于即时聊天界面的输入发送TextField工具条,可以随键盘的显示和输入法切换导致的键盘高度变化而自动变化TextField的位置。

    通过正确处理键盘通知、计算键盘高度和执行动画,我们可以为用户提供一个无缝且直观的输入体验。`YFInputView`的源代码将提供实现这一功能的具体实现细节,包括布局调整和事件响应。通过学习和理解这个组件,开发者...

    iOS 输入键盘自适应

    1. 使用通知:我们可以监听UIKeyboardWillShowNotification和UIKeyboardWillHideNotification通知,当键盘将要显示或隐藏时,获取键盘的高度并相应地调整输入控件的位置。以下是一个简单的示例: ```swift override...

    ios-UITextView文字和键盘之间的高度计算.zip

    本示例项目"ios-UITextView文字和键盘之间的高度计算.zip"旨在解决这个问题,通过动态计算文字高度来调整`UITextView`的位置,确保文本始终可见。 首先,我们需要理解`UITextView`的基本属性和行为。`UITextView`...

    ios源码之一个完美的键盘控制器Demo.rar

    7. **KVO(Key Value Observing)**:另外,可以通过观察`UIKeyboardFrameEndUserInfoKey`和`UIKeyboardFrameBeginUserInfoKey`来获取键盘的高度变化,以便精确调整界面布局。 这个Demo可能涵盖以上所有或部分知识...

Global site tag (gtag.js) - Google Analytics