在textView中输入时避免键盘的遮挡

很多时候我们都在为键盘遮挡了原本就不大的屏幕时而烦恼,特别是当用户处于编辑状态时,键盘下面的内容就看不见了,用户只能处于盲打状态了。现在有一种简单的解决办法,基本思路就是,添加通知。一直监听键盘事件,在键盘遮挡时,将编辑器上移键盘的高度,键盘消失时,编辑区回复原来位置,ok,来两段代码吧

[cpp] 
- (void)viewDidLoad { 
    [super viewDidLoad]; 
    // Do any additional setup after loading the view, typically from a nib. 
    self.textView=[[UITextView alloc]initWithFrame:self.view.frame]; 
    self.textView.text=@"请输入文字"; 
    [self.view addSubview:self.textView]; 

 
- (void)didReceiveMemoryWarning 

    [super didReceiveMemoryWarning]; 
    // Dispose of any resources that can be recreated. 

 
- (void)viewWillAppear:(BOOL)animated 

    //注册通知,监听键盘出现 
    [[NSNotificationCenter defaultCenter]addObserver:self 
                                            selector:@selector(handleKeyboardDidShow:) 
                                                name:UIKeyboardDidShowNotification 
                                              object:nil]; 
    //注册通知,监听键盘消失事件 
    [[NSNotificationCenter defaultCenter]addObserver:self 
                                            selector:@selector(handleKeyboardDidHidden) 
                                                name:UIKeyboardDidHideNotification 
                                              object:nil]; 
    [super viewWillAppear:YES]; 

 
//监听事件 
- (void)handleKeyboardDidShow:(NSNotification*)paramNotification 

    //获取键盘高度 
    NSValue *keyboardRectAsObject=[[paramNotification userInfo]objectForKey:UIKeyboardFrameEndUserInfoKey]; 
     
    CGRect keyboardRect; 
    [keyboardRectAsObject getValue:&keyboardRect]; 
     
    self.textView.contentInset=UIEdgeInsetsMake(0, 0,keyboardRect.size.height, 0); 

 
- (void)handleKeyboardDidHidden 

    self.textView.contentInset=UIEdgeInsetsZero; 

 
- (void)viewDidDisappear:(BOOL)animated 

    [[NSNotificationCenter defaultCenter] removeObserver:self]; 

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值