zoukankan      html  css  js  c++  java
  • ios键盘输入屏幕上移

    在IOS开法中经常会遇到键盘遮挡屏幕的事情(比如输入账号密码验证码等等),就使得原本都不大的屏幕直接占了一半甚至更多的位置,这倒无所谓,关键是挡住了下面的按钮。这样的话按钮的事件也就触发不了,最好的解决办法就是当输入这些信息的时候让整个屏幕上移一个键盘的位置,或者上移到指定的位置。

    首先一般输入的话都用的是UITextField,所以要监听用户什么时候开始输入和什么时候结束输入,直接设置代理代理就行了,要遵受

    UITextFieldDelegate协议。

    //遵循协议

    @interface ViewController ()<UITextFieldDelegate>

    //设置属性

    @property(nonatomic,strong)UITextField* UITF;

    //设置代理

     UITF.delegate=self;

    //代理方法

    //键盘弹出时屏幕上移

    -( void )textFieldDidBeginEditing:(UITextField *)textField

    {

      //假如多个输入,比如注册和登录,就可以根据不同的输入框来上移不同的位置,从而更加人性化

        //键盘高度216

        //滑动效果(动画)

        NSTimeInterval animationDuration = 0.30f;

        [UIView beginAnimations:@ "ResizeForKeyboard"  context:nil];

        [UIView setAnimationDuration:animationDuration];

        //将视图的Y坐标向上移动,以使下面腾出地方用于软键盘的显示

        self.view.frame = CGRectMake(0.0f, -100.0f/*屏幕上移的高度,可以自己定*/self.view.frame.size.widthself.view.frame.size.height); 

        [UIView commitAnimations];

    }

    //取消第一响应,也就是输入完毕,屏幕恢复原状

    -( void )textFieldDidEndEditing:(UITextField *)textField

    {

        //滑动效果

        NSTimeInterval animationDuration = 0.30f;

        [UIView beginAnimations:@ "ResizeForKeyboard"  context:nil];

        [UIView setAnimationDuration:animationDuration];

        //恢复屏幕

        self.view.frame = CGRectMake(0.0f0.0fself.view.frame.size.widthself.view.frame.size.height); 

        [UIView commitAnimations];

    }

    接下来说一下取消第一响应。

    一般都是在当前View上添加一个点击手势即可,这样的话就可以取消键盘的第一响应,但是这样的话有一个弊端,比如:因为注册登录页面当屏幕上移时,

    就会显示注册或登录的页面,如果添加点击手势的话那么就会覆盖掉按钮的点击事件,也就是明明看到了按钮,但是点击却没反应,那么怎么办呢?

    如何实现注册登录的按钮事件都在,点击其他的地方还能取消键盘的第一响应。

    其实很简单,我的解决办法是这样的

    创建一个按钮,和屏幕一样大,所有的控件全部都放到这个按钮上,而这个按钮的点击事件就是取消输入框的第一响应。这样就可以了。

  • 相关阅读:
    javascript基础之两种函数的定义方法
    与input有关的一些操作
    SpringMVC(八) RequestMapping HiddenHttpMethodFilter
    SpringMVC(七) RequestMapping 路径中带占位符的URL
    SpringMVC(六) RequestMapping 路径中ant风格的通配符
    SpringMVC(五) RequestMapping 请求参数和请求头
    SpringMVC(四) RequestMapping请求方式
    SpringMVC(三) RequestMapping修饰类
    SpringMVC(二) SpringMVC Hello World
    SpringMVC(一) SpringMVC概述
  • 原文地址:https://www.cnblogs.com/kakaluote123/p/5984011.html
Copyright © 2011-2022 走看看