iOS- UITextView与键盘回收与键盘遮挡输入框

一、UITextView

可以实现多行输入的文本框,基本属性与UITextField相似,可以输入多行,可以滚动。
UITextView还有个代理方式
- (BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text

可以控制输入文字的数量,较为常用

 #pragma mark UITextView的代理方法  

//是否可以开始编辑
- (BOOL)textViewShouldBeginEditing:(UITextView *)textView
{
    NSLog(@"%s",__func__);
    return YES;
}  

//是否可以结束编辑
- (BOOL)textViewShouldEndEditing:(UITextView *)textView
{
    NSLog(@"%s",__func__);
    return YES;
}  

//已经开始编辑
- (void)textViewDidBeginEditing:(UITextView *)textView
{
    NSLog(@"%s",__func__);
}
//已经结束编辑
- (void)textViewDidEndEditing:(UITextView *)textView
{
    NSLog(@"%s",__func__);
}  

//内容变化
- (void)textViewDidChange:(UITextView *)textView
{
    NSLog(@"%s",__func__);
}
//光标变化
- (void)textViewDidChangeSelection:(UITextView *)textView
{
    NSLog(@"%s",__func__);
}  

//当前输入的位置,当前输入的文字,是否可以继续输入
- (BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text
{
    NSLog(@"length = %ld,location = %ld",range.length,range.location);
    NSLog(@"text = %@",text);
    return YES;
}
  //下面这俩不好理解,大概是验证url和文件名后缀的
//Asks the delegate if the specified text view should allow user interaction with the given URL in the given range of text.
- (BOOL)textView:(UITextView *)textView shouldInteractWithURL:(NSURL *)URL inRange:(NSRange)characterRange NS_AVAILABLE_IOS(7_0)
{
    NSLog(@"url= %@",URL.host);
    NSLog(@"url touch");
    return YES;
}
- (BOOL)textView:(UITextView *)textView shouldInteractWithTextAttachment:(NSTextAttachment *)textAttachment inRange:(NSRange)characterRange NS_AVAILABLE_IOS(7_0)
{
    return YES;
}

二、键盘回收与键盘遮挡输入框

使用输入文本框时,经常出现一个问题,弹出的键盘挡住了文本框,这时可以通过移动输入框的位置来避免这样的情况。
思路比较简单,注册通知来监听键盘的弹出和消失事件,再实现对应的方法,在键盘弹出或者消失的时候,改变原本视图的frame
使视图向上或者向下移动一个键盘的高度,键盘就不会遮挡住视图了

首先注册通知简体键盘弹出事件

//注册通知,监听键盘弹出事件
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardDidShow:)
   name:UIKeyboardWillShowNotification object:nil];  

//注册通知,监听键盘消失事件
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardDidHidden)
   name:UIKeyboardDidHideNotification object:nil];

键盘一旦弹出或者消失就触发方法对输入框进行移动

// 键盘弹出时调用方法
-(void)keyboardDidShow:(NSNotification *)notification  

//键盘消失时调用
-(void)keyboardDidHidden

再设置一个触摸事件,触摸空白处可以收回键盘

//点击屏幕空白处
-(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
{
    //回收键盘,两者方式
    //UITextView *textView = (UITextView*)[self.view viewWithTag:1001];
    //[textView resignFirstResponder];
    [self.view endEditing:YES];
    NSLog(@"touch");
}

完整代码:

#import "FirstViewController.h"  

@implementation FirstViewController  

-(void)viewDidLoad
{
    [super viewDidLoad];  

#pragma mark UITextView  

    //    UITextField:
    //    继承UIControl,只能输入一行,不可以滚动,可以设置提醒文字。
    //    有return代理方法和clearButtonMode  

    //    UITextView:
    //    能输入多行,可以滚动,不可以设置提醒文字。  

    UITextView *textView = [[UITextView alloc] initWithFrame:CGRectMake(10, 10, 280, 80)];//初始化  

    textView.backgroundColor=[UIColor colorWithRed:0.21 green:0.71 blue:0.51 alpha:0.5]; //背景色  

    textView.scrollEnabled = YES;    //当文字超过视图的边框时是否允许滑动,默认为“YES”  

    textView.editable = YES;        //是否允许编辑内容,默认为“YES”        

    textView.font=[UIFont fontWithName:@"Arial" size:18.0]; //设置字体名字和字体大小;  

    textView.returnKeyType = UIReturnKeyDefault;//return键的类型  

    textView.keyboardType = UIKeyboardTypeDefault;//键盘类型  

    textView.textAlignment = NSTextAlignmentLeft; //文本显示的位置默认为居左  

    textView.dataDetectorTypes = UIDataDetectorTypeAll; //显示数据类型的连接模式(如电话号码、网址、地址等)  

    textView.textColor = [UIColor blackColor];  

    textView.delegate = self;    //设置代理方法的实现类  

    textView.text = @"UITextView";//设置显示的文本内容  

    [textView.layer setCornerRadius:10]; //设置圆角  

    textView.tag = 1001; //设置tag值  

    //添加键盘的监听事件  

    //注册通知,监听键盘弹出事件
    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardDidShow:)
       name:UIKeyboardDidShowNotification object:nil];  

    //注册通知,监听键盘消失事件
    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardDidHidden)
       name:UIKeyboardDidHideNotification object:nil];  

    //在view中添加一个子view,设置此子view的tag值为1000,在此view上添加一个textView和一个发送按钮,
    //如下图;我们要达到textView的键盘弹出时,整个View往上平移,键盘消失,view往下平移的效果,模拟发送短信的界面。
    UIView *keyView = [[UIView alloc]initWithFrame:CGRectMake(0, 567, 375, 100)];
    keyView.backgroundColor = [UIColor colorWithRed:0.2 green:0.3 blue:0.6 alpha:0.5];
    keyView.tag = 1000;  

    [keyView addSubview:textView];  

    [self.view addSubview:keyView];  

}  

#pragma mark 实现监听到键盘变化时的触发的方法  

// 键盘弹出时
-(void)keyboardDidShow:(NSNotification *)notification
{
    //获取键盘高度
    NSValue *keyboardObject = [[notification userInfo] objectForKey:UIKeyboardFrameEndUserInfoKey];  

    NSLog(@"%@",keyboardObject);  

    CGRect keyboardRect;  

    [keyboardObject getValue:&keyboardRect];   

     //得到键盘的高度
    //CGRect keyboardRect = [[notification.userInfo objectForKey:UIKeyboardFrameEndUserInfoKey]CGRectValue];  

    // 取得键盘的动画时间,这样可以在视图上移的时候更连贯
    double duration = [[notification.userInfo objectForKey:UIKeyboardAnimationDurationUserInfoKey] doubleValue];
    NSLog(@"%f",duration);
    //调整放置有textView的view的位置  

    //设置动画
    [UIView beginAnimations:nil context:nil];  

    //定义动画时间
    [UIView setAnimationDuration:duration];
    [UIView setAnimationDelay:0];  

    //设置view的frame,往上平移
    [(UIView *)[self.view viewWithTag:1000] setFrame:CGRectMake(0, self.view.frame.size.height-keyboardRect.size.height-100, 375, 100)];  

    //提交动画
    [UIView commitAnimations];  

}  

//键盘消失时
-(void)keyboardDidHidden
{
    //定义动画
    //[UIView beginAnimations:nil context:nil];
   // [UIView setAnimationDuration:0.25];  

    //设置view的frame,往下平移
    [(UIView *)[self.view viewWithTag:1000] setFrame:CGRectMake(0, 567, 375, 100)];
   // [UIView commitAnimations];
}  

//点击屏幕空白处
-(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
{
    //回收键盘,两种方式
    //UITextView *textView = (UITextView*)[self.view viewWithTag:1001];
    //[textView resignFirstResponder];
    [self.view endEditing:YES];
    NSLog(@"touch");
}  

@end

效果图

后面又一次要在tableView里面加textView,不好找的textView去resignKeyBoard,就使用一个可以得到的textView 去becomeFirst,然后再resignFirst

还有直接获得第一响应者的方法
UIWindow keyWindow = [[UIApplication sharedApplication] keyWindow];
UIView 
firstResponder = [keyWindow performSelector:@selector(firstResponder)];
[firstResponder resignFirstResponder];

转载:http://www.jianshu.com/p/1bf3407b15f7

时间: 2024-10-29 09:19:16

iOS- UITextView与键盘回收与键盘遮挡输入框的相关文章

iOS键盘遮挡输入框,输入区域自动上移

在iOS开发过程当中,遇到关于键盘遮挡输入框的问题,经过网络参考与实践,总结如下: 登录窗口,上下放置两个UITextField,一个用户名,一个密码,放置的在屏幕下方1/3处,当点击用户名时,自动弹出键盘,正好挡住了输入框 解决思路: 1.BLoginViewController 实现UITextViewDelegate的方法 1 //实现了UITextFieldDelegate中的方法,当对TextField进行编辑即键盘弹出时,自动将输入框上移 2 -(BOOL)textFieldShou

iOS UITextView 高度随文字自动增加,并跟随键盘移动(一)

项目中遇到这样一个需求 ,有个文本框,需要随着用户输入的文字多少高度自动增加. 比如说,当用户输入的文字不足一行的时候textview的高度为初始高度, 当输入的文字超过一行,不足两行的时候,我们将textView 的高度调整为显示两行文字的高度. 此处,我们要实现一个评论的功能,还需要输入框跟随键盘移动. 开始代码 首先,我们新建一个类,专门管理输入框,我们起名:CommentView 继承 UIView 为他创建一个UITextView (我们的输入框) #import <UIKit/UIK

iOS自定义键盘和系统键盘切换且文本输入框一直获得焦点

UITextView用来进行文本输入.方法becomeFirstResponder和resignFirstResponder可以用来进行弹出系统键盘和收下系统键盘. 弹出系统键盘,文本输入框获得焦点.收下系统键盘,文本输入框失去焦点.那么,问题来了. 某个条件下,如点击界面上的某个按钮,展示自定义键盘.再次点击,切换到系统键盘.先收下系统键盘,再展示自定义键盘.比如移动自定义键盘View的Frame.Y.但这时因为收下系统键盘,本文输入框失去焦点.虽然展示了自定义键盘.但用户体验很不好.光标没有

LinearLayout详解四:彻底解决软键盘遮挡输入框的问题

之前把预备知识都介绍完了,话说学以致用,接下来我们要通过重载LinearLayout类来解决软键盘覆盖的问题. 首先阐述一下这个问题,如下图所示: 然后看挡住输入框的情况 然后我们给出xml的源代码: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:lay

IOS: iPhone键盘通知与键盘定制

一.键盘通知 当文本View(如UITextField,UITextView,UIWebView内的输入框)进入编辑模式成为first responder时,系统会自动显示键盘.成为firstresponder可能由用户点击触发,也可向文本View发送becomeFirstResponder消息触发.当文本视图退出first responder时,键盘会消失.文本View退出first responder可能由用户点击键盘上的Done或Return键结束输入触发,也可向文本View发送resig

react-native 键盘遮挡输入框

Android上已经自动对键盘遮挡输入框做了处理,所以我们只需要关注ios. 1.首先引入 KeyboardAvoidingView import { KeyboardAvoidingView } from 'react-native'; 2.然后在页面的最外层加上 KeyboardAvoidingView render(){ return <KeyboardAvoidingView behavior={'padding'} style={{flex: 1}}> {/*具体页面内容*/} &l

Android 输入法键盘和activity页面遮挡问题解决

本文主要介绍Android中如何解决输入法键盘和activity页面遮挡的问题. 总结: 不希望遮挡设置activity属性android:windowSoftInputMode="adjustPan" 希望动态调整高度android:windowSoftInputMode="adjustResize" 问题: 我原来的问题是,对于腾讯微博的OAuth验证webView,弹出软键盘后,输入框上移就看不到输入框了,后发现Webview放到了ScrollView中,将S

IOS开发学习笔记-(2)键盘控制,键盘类型设置,alert 对话框

一.关闭键盘,放弃第一响应者,处理思路有两种 ① 使用文本框的 Did End on Exit 绑定事件 ② UIControl on Touch 事件 都去操作 sender 的  resignFirstResponder #import <UIKit/UIKit.h> @interface ViewController : UIViewController @property (weak, nonatomic) IBOutlet UITextField *txtUserName; @pro

IOS开发-点击View取消键盘输入

要想在一个TextField等输入框中取消输入,有几个办法,第一个是在键盘添加按钮,第二个就是通过判断然后取消键盘的输入了. 下面讲第二个 写一个方法并实现 // .h文件 - (IBAction)cancelInput:(id)sender; // .m文件 - (void)cancelInput:(id)sender { [TextField1 resignFirstResponder]; [TextField2 resignFirstResponder]; [TextView resign