最近做一个搜索用户的功能,这里使用了uisearchbar。由于搜索的方式只有手机号码,所以这里的键盘要限制为数字输入,可以这么做:
self.searchbar.keyboardtype = uikeyboardtypenumberpad;如果使用的不是搜索框而是textfield输入框,可以设置textfield的键盘属性来展示 self.textfield.keyboardtype = uikeyboardtypenumberpad;监听事件如下所示即可。
但是这里有个问题,就是数字键盘上面没有“搜索”按钮,这样子用户在输入完手机号码后无法搜索。所以这个时候我们需要自己添加一个自定义的搜索按钮,然后加到键盘上面。
解决思路如下所示:
1.自定义搜索button
2.监听键盘出现的事件
3.遍历搜索的windows窗体,找到键盘的窗体,然后遍历其子视图,找到我们真正需要的键盘视图
4.把我们自定义的按钮加到上面找到的视图里
这里要注意的一点,随着ios sdk的不断发展,keyboard的视图名称也不断在更新变化,当你调试以下代码无法得到期待的效果时,请重新遍历一次窗台,然后慢慢调试,找到真正需要的视图名称。
解决代码
1.自定义搜索按钮
1
2
3
4
5
6
|
// 搜索按钮
_searchbutton = [uibutton buttonwithtype:uibuttontypecustom];
_searchbutton.frame = cgrectmake(0, 163, 106, 53);
[_searchbutton settitle:@ "搜索" forstate:uicontrolstatenormal];
[_searchbutton settitlecolor:[uicolor blackcolor] forstate:uicontrolstatenormal];
[_searchbutton addtarget:self action:@selector(searchbuttondidtouch:) forcontrolevents:uicontroleventtouchupinside];
|
2.监听键盘出现的事件
1
2
3
4
|
[[nsnotificationcenter defaultcenter] addobserver:self selector:@selector(keyboardwillshowondelay:) name:uikeyboardwillshownotification object:nil];
- ( void )keyboardwillshowondelay:(nsnotification *)notification {
[self performselector:@selector(keyboardwillshow:) withobject:nil afterdelay:0];
}
|
这里面监听通知后的执行函数并非立马执行查找窗体的函数,是因为在ios4后,键盘添加到窗体的事件放到了下一个eventloop,所以我们采用了延迟的方法。
3. 遍历视图,并添加按钮
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
|
- ( void )keyboardwillshow:(nsnotification *)notification {
uiview *foundkeyboard = nil;
uiwindow *keyboardwindow = nil;
for (uiwindow *testwindow in [[uiapplication sharedapplication] windows]) {
if (![[testwindow class ] isequal:[uiwindow class ]]) {
keyboardwindow = testwindow;
break ;
}
}
if (!keyboardwindow) return ;
for (__strong uiview *possiblekeyboard in [keyboardwindow subviews]) {
if ([[possiblekeyboard description] hasprefix:@ "<uiinputsetcontainerview" ]) {
for (__strong uiview *possiblekeyboard_2 in possiblekeyboard.subviews) {
if ([possiblekeyboard_2.description hasprefix:@ "<uiinputsethostview" ]) {
foundkeyboard = possiblekeyboard_2;
}
}
}
}
if (foundkeyboard) {
if ([[foundkeyboard subviews] indexofobject:_searchbutton] == nsnotfound) {
[foundkeyboard addsubview:_searchbutton];
} else {
[foundkeyboard bringsubviewtofront:_searchbutton];
}
}
}
|
以上所述是小编给大家介绍的ios开发之uikeyboardtypenumberpad数字键盘自定义按键,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
原文链接:http://www.cnblogs.com/MasterPeng/archive/2016/08/24/5802340.html