实用小技巧(二十二):键盘遮挡问题

版本记录

版本号 时间
V1.0 2017.08.03

前言

在app中,很多时候都需要在输入框里面输入东西,这个时候键盘弹出,不可避免的就会有遮挡页面的问题,这一篇就讲一下解决键盘遮挡页面的方法。感兴趣的可以看看我写的其他小技巧。
1. 实用小技巧(一):UIScrollView中上下左右滚动方向的判断
2. 实用小技巧(二):屏幕横竖屏的判断和相关逻辑
3.实用小技巧(三):点击手势屏蔽子视图的响应
4.实用小技巧(四):动态的增删标签视图
5.实用小技巧(五):通过相册或者相机更改图标
6.实用小技巧(六):打印ios里所有字体
7. 实用小技巧(七):UITableViewCell自适应行高的计算
8. 实用小技巧(八):数字余额显示的分隔
9.实用小技巧(九):类头条模糊背景的实现
10.实用小技巧(十):晃动手机换后台服务器网络
11.实用小技巧(十一):scrollView及其子类显示的一些异常处理
12.实用小技巧(十二):头像图片缩放以及保存到相册简单功能的实现
13.实用小技巧(十三):一种类酷我音乐盒动画实现
14.实用小技巧(十四):生成跳往applestore指定app的方法
15.实用小技巧(十五):左侧向右滑动返回上一级控制器
16.实用小技巧(十六):获取设备信息
17.实用小技巧(十七):清除缓存目录
18.实用小技巧(十八):取出gif图的每一帧
19.实用小技巧(十九):获取相机和麦克风权限
20.实用小技巧(二十):游客模式的实现
21.实用小技巧(二十一):版本检测的实现

功能要求

在app输入框中,当我们输入东西的时候,就会弹出键盘,有键盘弹出就会有遮挡页面的问题,这一篇我们就讲一下解决键盘遮挡的方法。


功能实现

下面我们就看一下功能的实现,先看代码。

#import "JJKeyBoardVC.h"
#import "Masonry.h"

#define kScreenWidth    [UIScreen mainScreen].bounds.size.width
#define kScreenHeight   [UIScreen mainScreen].bounds.size.height

@interface JJKeyBoardVC ()

@property (nonatomic, strong) UITextField *textField;
@property (nonatomic, strong) UIView *bottomView;

@end

@implementation JJKeyBoardVC

#pragma mark - Override Base Function

- (void)viewDidLoad
{
    [super viewDidLoad];
    
    self.title = @"键盘遮挡";
    
    self.view.backgroundColor = [UIColor whiteColor];
    
    UITapGestureRecognizer *tapGesture = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tapDidTapped)];
    [self.view addGestureRecognizer:tapGesture];
    
    [self setupUI];
    
    //监听键盘弹出和收回
    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardDidAppear:) name:UIKeyboardWillShowNotification object:nil];
    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardDidDisappear:) name:UIKeyboardWillHideNotification object:nil];
}

#pragma mark - Object Private Function

- (void)setupUI
{
    //输入框
    UITextField *textField = [[UITextField alloc] init];
    textField.placeholder = @"清输入内容";
    textField.layer.borderColor = [UIColor blueColor].CGColor;
    textField.layer.borderWidth = 1.0;
    [self.view addSubview:textField];
    self.textField = textField;
    
    [self.textField mas_makeConstraints:^(MASConstraintMaker *make) {
        make.centerX.equalTo(self.view);
        make.top.equalTo(self.view).offset(100.0);
        make.width.equalTo(@300);
        make.height.equalTo(@40);
    }];
    
    //底部视图
    UIView *bottomView = [[UIView alloc] init];
    bottomView.backgroundColor = [UIColor purpleColor];
    [self.view addSubview:bottomView];
    self.bottomView = bottomView;
    
    [self.bottomView mas_makeConstraints:^(MASConstraintMaker *make) {
        make.left.right.bottom.equalTo(self.view);
        make.height.equalTo(@40);
    }];
}

#pragma mark - Action && Notification

- (void)tapDidTapped
{
    [self.view endEditing:YES];
}

//键盘出现

- (void)keyboardDidAppear:(NSNotification *)noti
{
    //获取键盘的高度
    CGFloat kbHeight = [[noti.userInfo objectForKey:UIKeyboardFrameEndUserInfoKey] CGRectValue].size.height;
    // 取得键盘的动画时间,这样可以在视图上移的时候更连贯
    NSTimeInterval duration = [[noti.userInfo objectForKey:UIKeyboardAnimationDurationUserInfoKey] doubleValue];
    [UIView animateWithDuration:duration animations:^{
        self.view.frame = CGRectMake(0.0, 0.0, kScreenWidth, kScreenHeight - kbHeight);
    } completion:^(BOOL finished) {
        
    }];
}

//键盘收回

- (void)keyboardDidDisappear:(NSNotification *)noti
{
    NSTimeInterval duration = [[noti.userInfo objectForKey:UIKeyboardAnimationDurationUserInfoKey] doubleValue];
    [UIView animateWithDuration:duration animations:^{
        self.view.frame = CGRectMake(0.0, 0.0, kScreenWidth, kScreenHeight);
    } completion:^(BOOL finished) {

    }];
}

@end

这个方法就是监听键盘的弹出和隐藏,获取键盘的高度以及时间,相应的改变父视图的frame,从而解决遮挡的问题。


功能效果

下面就看一下功能效果。

效果1
效果2

可见,键盘不再遮挡视图了。

后记

未完,待续~~~~

山水
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 今天给大家分享的是马苒苒所著《越书写,越明白》一书,它细分的领域还是属于写作疗愈类的,书中通过12堂心零炼金课告诉...
    锦梭阅读 4,741评论 1 3
  • 老屋满目是蛛丝, 丝丝都是老故事。 人去屋空真凄凉, 当年人儿在哪里。
    无知的战栗阅读 1,828评论 0 1
  • 相信大多数职场中人,都会经常碰到:事情有很多、别人催的很紧,时常感觉到手忙脚乱的情况。 工作中如何分清轻重缓急? ...
    老布码字阅读 6,471评论 0 1
  • 昨日,阴雨绵绵,窝在沙发里一上午看完了这本书,我看书比较慢,好在这本书篇幅短,故事简单,又割舍不断。 怎么说呢,看...
    小小闲阅读 4,822评论 0 3

友情链接更多精彩内容