iOS开发之监听键盘高度的变化 分类: ios技术 2015-04-21 12:04 233人阅读 评论(0) 收藏

时间:2024-01-02 23:50:08

最近做的项目中,有一个类似微博中的评论转发功能,屏幕底端有一个输入框用textView来做,当textView成为第一响应者的时候它的Y值随着键盘高度的改变而改变,保证textView紧贴着键盘,但又不会被键盘挡住。

下面是我实现的方法:(利用通知)

1
2
3
4
5
6
7
8
9
10
11
12
//
键盘通知
    //
键盘的frame发生改变时发出的通知(位置和尺寸)
    //   
UIKeyboardWillChangeFrameNotification
    //   
UIKeyboardDidChangeFrameNotification
    //
键盘显示时发出的通知
    //   
UIKeyboardWillShowNotification
    //   
UIKeyboardDidShowNotification
    //
键盘隐藏时发出的通知
    //   
UIKeyboardWillHideNotification
    //   
UIKeyboardDidHideNotification
     
    [[NSNotificationCenter
defaultCenter] addObserver:self selector:
@selector(keyboardWillChangeFrame:)
name:UIKeyboardWillChangeFrameNotification object:nil];
//在这里注册通知

下面是监听通知:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
#pragma
mark - 监听方法
/**
 *
键盘的frame发生改变时调用(显示、隐藏等)
 */
-
(
void)keyboardWillChangeFrame:(NSNotification
*)notification
{
    //   
if (self.picking) return;
    /**
     notification.userInfo
= @{
     //
键盘弹出\隐藏后的frame
     UIKeyboardFrameEndUserInfoKey
= NSRect: {{0, 352}, {320, 216}},
     //
键盘弹出\隐藏所耗费的时间
     UIKeyboardAnimationDurationUserInfoKey
= 0.25,
     //
键盘弹出\隐藏动画的执行节奏(先快后慢,匀速)
     UIKeyboardAnimationCurveUserInfoKey
= 7
     }
     */
     
    NSDictionary
*userInfo = notification.userInfo;
     
    //
动画的持续时间
    doubleduration
= [userInfo[UIKeyboardAnimationDurationUserInfoKey] doubleValue];
     
    //
键盘的frame
    CGRect
keyboardF = [userInfo[UIKeyboardFrameEndUserInfoKey] CGRectValue];
     
    //
执行动画
    [UIView
animateWithDuration:duration animations:^{
        //
工具条的Y值 == 键盘的Y值 - 工具条的高度
        if(keyboardF.origin.y
> self.view.height) {
//
键盘的Y值已经远远超过了控制器view的高度
            self.toolbar.y
= self.view.height - self.toolbar.height;
//这里的<span
style="background-color: rgb(240, 240, 240);">self.toolbar就是我的输入框。</span>
        }else{
            self.toolbar.y
= keyboardF.origin.y - self.toolbar.height;
        }
    }];
}

当然,这里我为UIView写了一个类别,实现如下:

.h文件中声明

1
2
3
4
5
6
7
8
9
10
@interfaceUIView
(Extension)
@property(nonatomic,
assign) CGFloat x;
@property(nonatomic,
assign) CGFloat y;
@property(nonatomic,
assign) CGFloat width;
@property(nonatomic,
assign) CGFloat height;
@property(nonatomic,
assign) CGFloat centerX;
@property(nonatomic,
assign) CGFloat centerY;
@property(nonatomic,
assign) CGSize size;
@property(nonatomic,
assign) CGPoint origin;
@end

.m文件中实现(重写setter 和 getter)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
@implementationUIView
(Extension)
-
(
void)setX:(CGFloat)x
{
    CGRect
frame = self.frame;
    frame.origin.x
= x;
    self.frame
= frame;
}
-
(
void)setY:(CGFloat)y
{
    CGRect
frame = self.frame;
    frame.origin.y
= y;
    self.frame
= frame;
}
-
(CGFloat)x
{
    returnself.frame.origin.x;
}
-
(CGFloat)y
{
    returnself.frame.origin.y;
}
-
(
void)setCenterX:(CGFloat)centerX
{
    CGPoint
center = self.center;
    center.x
= centerX;
    self.center
= center;
}
-
(CGFloat)centerX
{
    returnself.center.x;
}
-
(
void)setCenterY:(CGFloat)centerY
{
    CGPoint
center = self.center;
    center.y
= centerY;
    self.center
= center;
}
-
(CGFloat)centerY
{
    returnself.center.y;
}
-
(
void)setWidth:(CGFloat)width
{
    CGRect
frame = self.frame;
    frame.size.width
= width;
    self.frame
= frame;
}
-
(
void)setHeight:(CGFloat)height
{
    CGRect
frame = self.frame;
    frame.size.height
= height;
    self.frame
= frame;
}
-
(CGFloat)height
{
    returnself.frame.size.height;
}
-
(CGFloat)width
{
    returnself.frame.size.width;
}
-
(
void)setSize:(CGSize)size
{
    CGRect
frame = self.frame;
    frame.size
= size;
    self.frame
= frame;
}
-
(CGSize)size
{
    returnself.frame.size;
}
-
(
void)setOrigin:(CGPoint)origin
{
    CGRect
frame = self.frame;
    frame.origin
= origin;
    self.frame
= frame;
}
-
(CGPoint)origin
{
    returnself.frame.origin;
}
@end

有需要的朋友可以直接用

版权声明:本文为博主原创文章,未经博主允许不得转载。