记录于2013/6/26:
一.点击键盘上的“Done”按钮关闭键盘
1.视图控制器实现UITextFieldDelegate协议
2.设置文本框属性
textField.returnKeyType = UIReturnKeyDone;
textField.delegate=self;
3. 重写协议方法
- (BOOL)textFieldShouldReturn:(UITextField *)textField
{
[textFieldresignFirstResponder];
// the user pressed the "Done" button, so dismiss the keyboard
returnYES;
}
二.点击键盘上的“Next”按钮实现文本框焦点跳转
1.视图控制器实现UITextFieldDelegate协议
2.设置文本框属性
tx_username.returnKeyType = UIReturnKeyNext;
tx_username.delegate =self;
3.重写协议方法
- (BOOL)textFieldShouldReturn:(UITextField *)textField
{
if([tx_username isFirstResponder]) {
[tx_email becomeFirstResponder];
}elseif([tx_email isFirstResponder]) {
[tx_password becomeFirstResponder];
} elseif([tx_password isFirstResponder]) {
[tx_conPassword becomeFirstResponder];
} elseif([tx_conPassword isFirstResponder]) {
[self performSelector:@selector(userRegister)];//tx_conPassword指定了<span style="font-family: Menlo; font-size: 11px;">UIReturnKeyJoin类型后调用的方法</span></span>
}
returnYES;
}
UIScrollView页面下点击TextField键盘事件:
不能改变scrollView的frame,得改变contentOffSet调整。
(1)
#pragma mark
#pragma mark - Textfield delegate
//增加手势 点击输入框以外区域降下键盘
-(void)RegisterViewAddGest:(UIImageView *)view {
view.userInteractionEnabled = YES;
//单击事件
UITapGestureRecognizer *taprecognizer;
taprecognizer = [[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(RegisterKeyDown:)];
taprecognizer.numberOfTapsRequired = 1;
[view addGestureRecognizer:taprecognizer];
[taprecognizer release];
}
//键盘下降的时候
-(void)RegisterKeyDown:(UITapGestureRecognizer *)taprecognizer{
DebugLog(@"点击背景键盘下降");
if (taprecognizer.numberOfTapsRequired == 1) {
[self.nameTextField resignFirstResponder];
[self.phoneTextField resignFirstResponder];
[self.addressTextField resignFirstResponder];
[self.goodsTextField resignFirstResponder];
[self.numberTextField resignFirstResponder];
[self.timeTextField resignFirstResponder];
[self.attendTextField resignFirstResponder];
NSTimeInterval animationDuration = 0.30f;
[UIView beginAnimations:@"ResizeForKeyboard"context:nil];
[UIView setAnimationDuration:animationDuration];
if (self.buyNowScrollView.contentOffset.y >= self.buyNowScrollView.contentSize.height - self.buyNowScrollView.frame.size.height) {
self.buyNowScrollView.contentOffset = CGPointMake(0, self.buyNowScrollView.contentSize.height - self.buyNowScrollView.frame.size.height);
}
[UIViewcommitAnimations];
}
}
//输入框return的时候
-(BOOL)textFieldShouldReturn:(UITextField *)textField
{
if ([textField isEqual:self.nameTextField]) {
[self.phoneTextFieldbecomeFirstResponder];
}elseif ([textField isEqual:self.phoneTextField]) {
[self.addressTextFieldbecomeFirstResponder];
}elseif ([textField isEqual:self.addressTextField]) {
[self.goodsTextFieldbecomeFirstResponder];
}elseif ([textField isEqual:self.goodsTextField]) {
[self.numberTextFieldbecomeFirstResponder];
}elseif ([textField isEqual:self.numberTextField]) {
[self.timeTextFieldbecomeFirstResponder];
}elseif ([textField isEqual:self.timeTextField]) {
[self.attendTextFieldbecomeFirstResponder];
}else {
DebugLog(@"输入框return的时候");
[textField resignFirstResponder];
NSTimeInterval animationDuration = 0.30f;
[UIViewbeginAnimations:@"ResizeForKeyboard"context:nil];
[UIViewsetAnimationDuration:animationDuration];
self.buyNowScrollView.contentOffset = CGPointMake(0, self.buyNowScrollView.contentSize.height - self.buyNowScrollView.frame.size.height);
[UIViewcommitAnimations];
}
returnYES;
}
//输入框弹出的时候
- (void)textFieldDidBeginEditing:(UITextField *)textField
{
DebugLog(@"键盘弹出");
CGRect frame = textField.frame;
int offset = frame.origin.y + 70 - (self.view.frame.size.height - 216.0);//键盘高度216
NSTimeInterval animationDuration = 0.30f;
[UIView beginAnimations:@"ResizeForKeyBoard"context:nil];
[UIView setAnimationDuration:animationDuration];
if(offset > 0)
{
self.buyNowScrollView.contentOffset = CGPointMake(0, offset + 10);
}else{
self.buyNowScrollView.contentOffset = CGPointMake(0, 0);
}
[UIView commitAnimations];
}
(2)改写(1)的,更加稳定适用了 暂时还是很完美的
里面的都是textField嵌入在scroll里面的使用
#pragma mark - UITextFieldDelegate
- (BOOL)textFieldShouldReturn:(UITextField *)textField{
//401为普通会员账号 402为普通会员密码 403为普通会员密码确认 404为普通会员昵称
//411为发型师会员账号 412为发型师会员密码 413为发型师会员密码确认 414为发型师会员姓名 415为发型师会员手机
//键盘高度216
if(textField.tag <= 404){
if ([textField isEqual:self.commonUserText]) {
[self.commonPassTextbecomeFirstResponder];
}elseif ([textField isEqual:self.commonPassText]){
[self.commonRepeatPassTextbecomeFirstResponder];
}elseif ([textField isEqual:self.commonRepeatPassText]){
[self.commonNickTextbecomeFirstResponder];
}else{
for (UIView *subView inself.commonScrollView.subviews) {
if ([subView isKindOfClass:[UITextFieldclass]]) {
[subView resignFirstResponder];
}
}
if (self.commonScrollView.contentSize.height - self.commonScrollView.contentOffset.y < self.commonScrollView.frame.size.height) {
[self.commonScrollViewsetContentOffset:CGPointMake(0, self.commonScrollView.contentSize.height - self.commonScrollView.frame.size.height) animated:YES];
}
}
}else{
if ([textField isEqual:self.barberUserText]) {
[self.barberPassTextbecomeFirstResponder];
}elseif ([textField isEqual:self.barberPassText]){
[self.barberRepeatPassTextbecomeFirstResponder];
}elseif ([textField isEqual:self.barberRepeatPassText]){
[self.barberNickTextbecomeFirstResponder];
}elseif ([textField isEqual:self.barberNickText]){
[self.barberTelphoneTextbecomeFirstResponder];
}else{
for (UIView *subView inself.barberScrollView.subviews) {
if ([subView isKindOfClass:[UITextFieldclass]]) {
[subView resignFirstResponder];
}
}
//scroll的内容高度 - scroll的contentOffSet高度 < scroll的frane高度
if (self.barberScrollView.contentSize.height - self.barberScrollView.contentOffset.y < self.barberScrollView.frame.size.height) {
[self.barberScrollViewsetContentOffset:CGPointMake(0, self.barberScrollView.contentSize.height - self.barberScrollView.frame.size.height) animated:YES];
}
}
}
returnYES;
}
- (void)textFieldDidBeginEditing:(UITextField *)textField{
//401为普通会员账号 402为普通会员密码 403为普通会员密码确认 404为普通会员昵称
//411为发型师会员账号 412为发型师会员密码 413为发型师会员密码确认 414为发型师会员姓名 415为发型师会员手机
//键盘高度216
CGRect frame = textField.frame;
int offset;
if(textField.tag <= 404){
//scroll的y坐标 + textField在Scroll上的y坐标 + textField高度 - 除键盘高度外屏幕高度
offset = frame.origin.y + 110 + 30 + 6 - (SCREEN_HEIGHT - 252);
NSTimeInterval animationDuration = 0.30f;
[UIViewbeginAnimations:@"ResizeForKeyBoard"context:nil];
[UIViewsetAnimationDuration:animationDuration];
if(offset > 0)
{
[self.commonScrollViewsetContentOffset:CGPointMake(0, offset) animated:YES];
}else{
[self.commonScrollViewsetContentOffset:CGPointMake(0, 0) animated:YES];
}
[UIViewcommitAnimations];
}else {
NSLog(@"%f",SCREEN_HEIGHT);
offset = frame.origin.y + 146 - (SCREEN_HEIGHT - 252);
if(offset > 0)
{
[self.barberScrollViewsetContentOffset:CGPointMake(0, frame.origin.y + 146 - (SCREEN_HEIGHT - 252)) animated:YES];
}else{
[self.barberScrollViewsetContentOffset:CGPointMake(0, 0) animated:YES];
}
}
}
- (void)textFieldDidEndEditing:(UITextField *)textField{
//scroll的内容高度 - scroll的contentOffSet高度 < scroll的frane高度
if (self.commonScrollView.contentSize.height - self.commonScrollView.contentOffset.y < self.commonScrollView.frame.size.height) {
[self.commonScrollViewsetContentOffset:CGPointMake(0, self.commonScrollView.contentSize.height - self.commonScrollView.frame.size.height) animated:YES];
}
if (self.barberScrollView.contentSize.height - self.barberScrollView.contentOffset.y < self.barberScrollView.frame.size.height) {
[self.barberScrollViewsetContentOffset:CGPointMake(0, self.barberScrollView.contentSize.height - self.barberScrollView.frame.size.height) animated:YES];
}
}
- (void)keyboardWillShow:(NSNotification *)noti
{
//键盘输入的界面调整
//键盘的高度
float height = 216.0;
CGRect frame = self.view.frame;
frame.size = CGSizeMake(frame.size.width, frame.size.height - height);
[UIView beginAnimations:@"Curl"context:nil];//动画开始
[UIView setAnimationDuration:0.30];
[UIView setAnimationDelegate:self];
[self.view setFrame:frame];
[UIView commitAnimations];
}
- (BOOL)textFieldShouldReturn:(UITextField *)textField
{
// When the user presses return, take focus away from the text field so that the keyboard is dismissed.
NSTimeInterval animationDuration = 0.30f;
[UIView beginAnimations:@"ResizeForKeyboard" context:nil];
[UIView setAnimationDuration:animationDuration];
CGRect rect = CGRectMake(0.0f, 0.0f, self.view.frame.size.width, self.view.frame.size.height);
self.view.frame = rect;
[UIView commitAnimations];
[textField resignFirstResponder];
return YES;
}
- (void)textFieldDidBeginEditing:(UITextField *)textField
{
CGRect frame = textField.frame;
int offset = frame.origin.y + 70 - (self.view.frame.size.height - 216.0); //键盘高度216 ,向上提多少在这里改
NSTimeInterval animationDuration = 0.30f;
[UIView beginAnimations:@"ResizeForKeyBoard" context:nil];
[UIView setAnimationDuration:animationDuration];
float width = self.view.frame.size.width;
float height = self.view.frame.size.height;
if(offset > 0)
{
CGRect rect = CGRectMake(0.0f, -offset,width,height);
self.view.frame = rect;
}
[UIView commitAnimations];
}
- js键盘事件全面控制详解
js键盘事件全面控制 主要分四个部分第一部分:浏览器的按键事件第二部分:兼容浏览器第三部分:代码实现和优化第四部分:总结 第一部分:浏览器的按键事件 用js实现键盘记录,要关注浏览器的三种按键事件 ...
- js键盘事件全面控制
js键盘事件全面控制 主要分四个部分第一部分:浏览器的按键事件第二部分:兼容浏览器第三部分:代码实现和优化第四部分:总结 第一部分:浏览器的按键事件 用js实现键盘记录,要关注浏览器的三种按键事件类型 ...
- js键盘事件全面控制详解【转】
js键盘事件全面控制 主要分四个部分第一部分:浏览器的按键事件第二部分:兼容浏览器第三部分:代码实现和优化第四部分:总结 第一部分:浏览器的按键事件 用js实现键盘记录,要关注浏览器的三种按键事件类型 ...
- JavaScript键盘事件全面控制代码
JavaScript键盘事件全面控制,它可以捕获键盘事件的输入状态,可以判断你敲打了键盘的那个键,ctrl.shift,26个字母等等,返回具体键盘值. <html> <head&g ...
- Js键盘事件全面控制,回车按键事件,键盘对应按键码,按键事件兼容各个浏览器。
在网上查询的按键码如下: 一.键盘按键和键盘对应代码表: 字母按键码A <--------> 65 B <--------> 66 C <--------> 6 ...
- js浏览器键盘事件控制(转自新浪微博)
js键盘事件全面控制 主要分四个部分第一部分:浏览器的按键事件第二部分:兼容浏览器第三部分:代码实现和优化第四部分:总结 第一部分:浏览器的按键事件 用js实现键盘记录,要关注浏览器的三种按键事件类型 ...
- iOS自动处理键盘事件的第三方库:IQKeyboardManager
我们写界面要考虑很多用户体验问题,键盘事件的响应就是比较麻烦的一种.我们需要监听键盘事件,考虑点击背景收起键盘.考虑键盘遮挡输入框问题等等,而且每个界面都要做这么一套.这个库帮我们解决了这个事情. 这 ...
- IOS中input键盘事件支持的解决方法
欢迎大家去我的网站详细查看http://genghongshuo.com.cn/ IOS中input键盘事件keyup.keydown.等支持不是很好, 用input监听键盘keyup事件,在安卓手机 ...
- iOS 键盘自适应(IQKeyboardManager)使用小结
IQKeyboardManager Github地址 经常在开发一个应用程序,我们遇到了一个问题,iPhone的键盘上滑覆盖的UITextField / UITextView.IQKeyboardMa ...
随机推荐
- web 框架
一个实际的案例介绍Spring Boot + Vue 前后端分离 https://www.cnblogs.com/nele/p/7858581.html#_caption_7 https://www. ...
- 谈谈JAVA中的安全发布
谈谈JAVA中的安全发布 昨天看到一篇文章阐述技术类资料的"等级",看完之后很有共鸣.再加上最近在工作中越发觉得线程安全性的重要性和难以捉摸,又掏出了<Java并发编程实战& ...
- 一张图11招学会Python网络黑客
全部学起来: 第一招:搭建Python防范环境 第二招:扫描漏洞 第三招:暴力破解的秘密 第四招:防SQL注入 第五招:防命令注入 第六招:看清文件上传木马 第七招:看清Web攻击 第八招:利用Pyt ...
- HTTP高并发调优小记
tomcat服务层 1.修改server.xml <Connector port="8088" protocol="HTTP/1.1" maxThread ...
- 提取 linux 文件目录结构
提取 linux 文件的目录结构 find /home/user1/ -type d |while read line ;do mkdir -p /home/user2/$line;done
- python学习之 getattr vs __get__ vs __getattr __ vs __getattribute__ vs __getitem__
1. getattr.setattr.hasattr getattr比较常用,与setattr和hasattr一起出现,他们也是最容易理解的,下面是他的用法: class Profile(): nam ...
- .Net Core的Excel导入
1.前台代码,layui模板 2.后台代码,后台实现 (1)导入 (2)数据验证 (3)将导入数据存储在数据库中 (4)定义保存导入数据接口 (5)接口的实现调用业务层 (6)业务层接口 (7)业务层 ...
- iOS 单选框
iOS 单选框,可自定义横向和纵向显示,可定义显示的个数和内容,自定义间距,提供block 和代理方法可供使用,欢迎拍砖! github地址: https://github.com/joshuaGen ...
- imageview设置图片时超长超大图片超出限制(OpenGLRenderer: Bitmap too large to be uploaded into a texture (996x9116, max=4096x4096))
问题:遇到超长图片,宽长等比缩放,比如宽度同屏幕同宽,长度等比放大,放到后遇到长度超出OpenGLRenderer的最大限制,导致图片无法显示出来: 解决办法: //图片超出GPU对于openglRe ...
- hihocoder 1176
hihocoder 1176 题意:N,M.分别表示岛屿数量和木桥数量,一笔画 分析:欧拉路问题(给定无孤立结点图G,若存在一条路,经过图中每边一次且仅一次,该条路称为欧拉路) 欧拉路的条件 一个无向 ...