保持iOS上键盘出现时输入框不被覆盖
如果屏幕中的内容项目比较多,键盘就可能覆盖住文本输入框之类的对象。你必须调整你的内容,使得输入框保持可见。
你会想到哪些处理方法呢?
第一种,
临时调整窗口中各个视图的大小,使得键盘从下向上占领的区域空白。键盘的高度( keyboard.size.height )是一定的,将视图中所有内容所在区域的 y 值减小到 y-keyboard.size.height 。
该方法有个局限,如果所有内容之和大于窗口减去键盘高度的话,该方法将不能用。
第二种,
将窗口中所有视图嵌入进一个滚动视图对象( UIScrollView )中。在键盘出现时,你将输入框滚动到合适的位置,调整一下滚动视图的内容区域。
这些操作通过一个通知 UIKeyboardDidShowNotification 去实现的,逻辑过程如下:
1 、根据通知的字典信息 userInfo 得到键盘的 size 。
2 、根据键盘的 size 中的 height 值,调整滚动视图内容底部的 inset 。
3 、滚动目标视图即文件输入框进入视图中。
简要的代码如下:
1 、实现两个委托方法,用于指定输入框对象。
|
- (void)textFieldDidBeginEditing:(UITextField *)textField |
|
{ |
|
activeField = textField; |
|
} |
|
- (void)textFieldDidEndEditing:(UITextField *)textField |
|
{ |
|
activeField = nil; |
|
} |
2 、注册通知的观察者
|
- (void)registerForKeyboardNotifications |
|
{ |
|
[[NSNotificationCenter defaultCenter] addObserver:self |
|
selector:@selector(keyboardWasShown:) |
|
name:UIKeyboardDidShowNotification object:nil]; |
|
[[NSNotificationCenter defaultCenter] addObserver:self |
|
selector:@selector(keyboardWillBeHidden:) |
|
name:UIKeyboardWillHideNotification object:nil]; |
|
} |
将这个方法放在 viewDidAppear 中调用。
同时也要写一个 removeObserver 放在 viewWillDisappear 中调用。
3 、实现键盘显示通知的 selector 中的方法
|
// Called when the UIKeyboardDidShowNotification is sent. |
|
- (void)keyboardWasShown:(NSNotification*)aNotification |
|
{ |
|
NSDictionary* info = [aNotification userInfo]; |
|
CGSize kbSize = [[info objectForKey:UIKeyboardFrameBeginUserInfoKey] CGRectValue].size; |
|
UIEdgeInsets contentInsets = UIEdgeInsetsMake(0.0, 0.0, kbSize.height, 0.0); |
|
scrollView.contentInset = contentInsets; |
|
scrollView.scrollIndicatorInsets = contentInsets; |
|
// If active text field is hidden by keyboard, scroll it so it's visible |
|
// Your application might not need or want this behavior. |
|
CGRect aRect = self.view.frame; |
|
aRect.size.height -= kbSize.height; |
|
if (!CGRectContainsPoint(aRect, activeField.frame.origin) ) { |
|
CGPoint scrollPoint = CGPointMake(0.0, activeField.frame.origin.y-kbSize.height); |
|
[scrollView setContentOffset:scrollPoint animated:YES]; |
|
} |
|
} |
4 、实现键盘消失通知的方法
|
// Called when the UIKeyboardWillHideNotification is sent |
|
- (void)keyboardWillBeHidden:(NSNotification*)aNotification |
|
{ |
|
UIEdgeInsets contentInsets = UIEdgeInsetsZero; |
|
scrollView.contentInset = contentInsets; |
|
scrollView.scrollIndicatorInsets = contentInsets; |
|
} |
这个方法调整内容底部的 inset 的值使得输入框不被键盘区域屏蔽的。还可以换种方法实现。
第三种,
扩展内容视图的高度,滚动文本输入框对象进内容视图。
将 keyboardWasShown: 重写。
|
- (void)keyboardWasShown:(NSNotification*)aNotification { |
|
NSDictionary* info = [aNotification userInfo]; |
|
CGSize kbSize = [[info objectForKey:UIKeyboardFrameBeginUserInfoKey] CGRectValue].size; |
|
CGRect bkgndRect = activeField.superview.frame; |
|
bkgndRect.size.height += kbSize.height; |
|
[activeField.superview setFrame:bkgndRect]; |
|
[scrollView setContentOffset:CGPointMake(0.0, activeField.frame.origin.y-kbSize.height) animated:YES]; |
|
} |
保持iOS上键盘出现时输入框不被覆盖的更多相关文章
- 如何保持iOS上键盘出现时输入框不被覆盖
在 iOS5 上请求显示键盘时,系统从屏幕底部将键盘滑入上来,位于应用的内容之上. (墙内:http://mikixiyou.iteye.com/blog/1488302) 如果屏幕中的内容项目比较多 ...
- iOS之按钮出现时加一个动画效果
//按钮出现时的动画效果 + (void)buttonAnimation:(UIButton *)sender { CAKeyframeAnimation *animation = [CAKeyfra ...
- 手机端上点击input框软键盘出现时把input框不被覆盖,显示在屏幕中间(转)
转载地址:https://www.cnblogs.com/xzzzys/p/7526761.html 1 用定位为题来解决var oHeight = $(document).height(); // ...
- iOS键盘出现时界面跟着往上推
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyBoardWillShow:) name:UI ...
- ios-利用键盘通知处理键盘出现时遮挡控件问题
-(void)viewDidLoad { NSNotificationCenter *center = [NSNotificationCenter defaultCenter]; //注册键盘显示通知 ...
- ios 避免navigationcontroller出现时scrollview内容被resize
viewDidLoad中设置以下属性 self.automaticallyAdjustsScrollViewInsets = NO;
- iOS 监听键盘高度,输入框上升
//设置输入框 ---<因为输入框用了get方法,所以第一次调用输入框要用self 调用>: self.textlab.frame=CGRectMake(, , , ); _textlab ...
- iOS UIWebView键盘处理
让UIWebView弹出键盘上的按钮显示中文 http://www.cr173.com/html/19440_1.html 如果你有下面的问题,此文也许会帮到你. 键盘遮盖了UIWebView. ...
- iOS UIWebView键盘操控
+-------------------------+ 假设你有以下的问题,也许这篇文章将帮助你. 键盘遮盖了UIWebView. 怎样拖动UIWebView来移除键盘. 键盘出现时UIWebView ...
随机推荐
- Win10环境下使用VS2015编译PJProject
一.pjproject源码下载 下载地址:http://www.pjsip.org/ 二.编译之前 1.pj配置,通常直接复制并重命名config_site_simple.h为config_site. ...
- 为Asp.Net Web Api添加Http基本认证
Asp.net Web Api提供了RESTFul web服务的编程接口.默认RESTFul 服务没有提供任何验证或者基于角色的验证,这显然不适合Put.Post.Delete这些操作.Aps.net ...
- jQuery图片提示和文字提示
图片提示: 效果如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http:/ ...
- codeforces 680B B. Bear and Finding Criminals(水题)
题目链接: B. Bear and Finding Criminals //#include <bits/stdc++.h> #include <vector> #includ ...
- android 开源库集合的链接列表
1. 内容挺多的 https://github.com/Trinea/android-open-project
- 编译项目报错: Ignoring file / xxx , missing required architecture i386 in file / xxx (2 slices)
.lib 或者 .a需用于真机版本,也就是ARM7的,如果你编译的是模拟器就会出现这个错误: 选择真机调试即可 .
- ES6:JavaScript 新特性
我相信,在ECMAScript.next到来的时候,我们现在每天都在写的JavaScript代码将会发生巨大的变化.接下来的一年将会是令JavaScript开发者们兴奋的一年,越来越多的特性提案将被最 ...
- Windows命令行中使用SSH连接Linux
转自 http://www.linuxidc.com/Linux/2014-02/96625.htm 1.下载: openssh for Winodws: 免费下载地址在 http://linux.l ...
- JSON介绍与JavaScript解析
首先什么是JSON? JSON 指的是 JavaScript 对象表示法(JavaScript Object Notation) JSON 是轻量级的文本数据交换格式 JSON 独立于语言 JSON ...
- highcharts 图表库的简单使用
Highcharts简介: Highcharts是一款纯javascript编写的图表库,能够很简单便捷的在Web网站或Web应用中添加交互性的图表,Highcharts目前支持直线图.曲线图.面积图 ...