iOS8新特性扩展(Extension)应用之四——自定义键盘控件

简介:

iOS8新特性扩展(Extension)应用之四——自定义键盘控件

        iOS8系统的开放第三方键盘,使得用户在输入法的选择上更加自主灵活,也更加贴近不同语言的输入风格。这篇博客,将介绍如何开发一个第三方的键盘控件。

一、了解UIInputViewController类

        UIInputViewController是系统扩展支持键盘扩展的一个类,通过这个类,我们可以自定义一款我们自己的键盘提供给系统使用。

        首先,我们先来看一下这个类中的一些属性和方法:

@property (nonatomic, retain) UIInputView *inputView;

键盘的输入视图,我们可以自定义这个视图。

@property (nonatomic, readonly) NSObject <UITextDocumentProxy> *textDocumentProxy;

实现了UITextDocumentProxy协议的一个对象,后面会介绍这个协议。

@property (nonatomic, copy) NSString *primaryLanguage;

系统为我们准备了一些本地化的语言字符串

- (void)dismissKeyboard;

收键盘的方法

- (void)advanceToNextInputMode;

切换到下一输入法的方法

UITextDocumentProxy协议内容如下:

?
1
2
3
4
5
6
7
8
9
@protocol UITextDocumentProxy <UIKeyInput>
//输入的上一个字符
@property (nonatomic, readonly) NSString *documentContextBeforeInput;
//即将输入的一个字符
@property (nonatomic, readonly) NSString *documentContextAfterInput;
//将输入的字符移动到某一位置
- ( void )adjustTextPositionByCharacterOffset:(NSInteger)offset;
 
@end

UITextDocumentProxy这个协议继承与UIKeyInput协议,UIKeyInput协议中提供的两个方法用于输入字符和删除字符:

- (void)insertText:(NSString *)text;
- (void)deleteBackward;

二、创建一款最简单的数字输入键盘

        创建一个项目,作为宿主APP,接着我们File->new->target->customKeyBoard:

系统要求我们对键盘的布局要使用autolayout,并且只可以采用代码布局的方式,我们这里为了简单演示,将坐标写死:

?
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
- ( void )viewDidLoad {
     [super viewDidLoad];
     
     // 设置数字键盘的UI
     //数字按钮布局
     for  ( int  i=0; i<10; i++) {
         UIButton * btn = [UIButton buttonWithType:UIButtonTypeSystem];
         btn.frame=CGRectMake(20+45*(i%3), 20+45*(i/3), 40, 40);
         btn.backgroundColor=[UIColor greenColor];
         [btn setTitle:[NSString stringWithFormat:@ "%d" ,i] forState:UIControlStateNormal];
         btn.tag=101+i;
         [btn addTarget:self action:@selector(click:) forControlEvents:UIControlEventTouchUpInside];
         [self.view addSubview:btn];
     }
     //创建切换键盘按钮
     UIButton * change = [UIButton buttonWithType:UIButtonTypeSystem];
     change.frame=CGRectMake(200,20, 80, 40) ;
     NSLog(@ "%f,%f" ,self.view.frame.size.height,self.view.frame.size.width);
     [change setBackgroundColor:[UIColor blueColor]];
     [change setTitle:@ "切换键盘"  forState:UIControlStateNormal];
     [change addTarget:self action:@selector(change) forControlEvents:UIControlEventTouchUpInside];
     [self.view addSubview:change];
     //创建删除按钮
     UIButton *  delete  = [UIButton buttonWithType:UIButtonTypeSystem];
     delete .frame=CGRectMake(200, 120, 80, 40);
     [ delete  setTitle:@ "delete"  forState:UIControlStateNormal];
     [ delete  setBackgroundColor:[UIColor redColor]];
     [ delete  addTarget:self action:@selector( delete ) forControlEvents:UIControlEventTouchUpInside];
     [self.view addSubview: delete ];
}
//删除方法
-( void ) delete {
     if  (self.textDocumentProxy.documentContextBeforeInput) {
         [self.textDocumentProxy deleteBackward];
     }
}
//切换键盘方法
-( void )change{
     [self advanceToNextInputMode];
}
//点击数字按钮 将相应数字输入
-( void )click:(UIButton *)btn{
     [self.textDocumentProxy insertText:[NSString stringWithFormat:@ "%ld" ,btn.tag-101]];
}

运行后,在使用之前,我们需要先加入这个键盘:在模拟器系统设置中general->keyboard->keyboards->addNowKeyboard

选中我们自定义的键盘,之后运行浏览器,切换到我们的键盘,效果如下:


        

目录
相关文章
|
27天前
|
开发框架 前端开发 Android开发
Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势
本文深入探讨了 Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势。这对于实现高效的跨平台移动应用开发具有重要指导意义。
107 4
|
23天前
|
数据安全/隐私保护 iOS开发 开发者
iOS 14隐私保护新特性深度解析####
随着数字时代的到来,隐私保护已成为全球用户最为关注的问题之一。苹果在最新的iOS 14系统中引入了一系列创新功能,旨在增强用户的隐私和数据安全。本文将深入探讨iOS 14中的几大隐私保护新特性,包括App跟踪透明度、剪贴板访问通知和智能防追踪功能,分析这些功能如何提升用户隐私保护,并评估它们对开发者和用户体验的影响。 ####
|
29天前
|
安全 Swift iOS开发
Swift 与 UIKit 在 iOS 应用界面开发中的关键技术和实践方法
本文深入探讨了 Swift 与 UIKit 在 iOS 应用界面开发中的关键技术和实践方法。Swift 以其简洁、高效和类型安全的特点,结合 UIKit 丰富的组件和功能,为开发者提供了强大的工具。文章从 Swift 的语法优势、类型安全、编程模型以及与 UIKit 的集成,到 UIKit 的主要组件和功能,再到构建界面的实践技巧和实际案例分析,全面介绍了如何利用这些技术创建高质量的用户界面。
29 2
|
1月前
|
安全 数据处理 Swift
深入探索iOS开发中的Swift语言特性
本文旨在为开发者提供对Swift语言在iOS平台开发的深度理解,涵盖从基础语法到高级特性的全面分析。通过具体案例和代码示例,揭示Swift如何简化编程过程、提高代码效率,并促进iOS应用的创新。文章不仅适合初学者作为入门指南,也适合有经验的开发者深化对Swift语言的认识。
48 9
|
1月前
|
安全 定位技术 数据安全/隐私保护
深入探索iOS 15新特性:用户体验与隐私保护的革新
本文将深入探讨苹果公司最新操作系统iOS 15带来的创新功能,特别是那些对用户日常体验和数据隐私产生重大影响的特性。我们将重点分析FaceTime的新功能、通知管理的改进、以及隐私保护的增强措施,展示这些更新如何提升用户的生活质量和信息安全。
|
1月前
|
JSON 前端开发 API
探索iOS开发之旅:打造你的第一个天气应用
【10月更文挑战第36天】在这篇文章中,我们将踏上一段激动人心的旅程,一起构建属于我们自己的iOS天气应用。通过这个实战项目,你将学习到如何从零开始搭建一个iOS应用,掌握基本的用户界面设计、网络请求处理以及数据解析等核心技能。无论你是编程新手还是希望扩展你的iOS开发技能,这个项目都将为你提供宝贵的实践经验。准备好了吗?让我们开始吧!
|
1月前
|
Swift iOS开发 UED
如何使用Swift和UIKit在iOS应用中实现自定义按钮动画
本文通过一个具体案例,介绍如何使用Swift和UIKit在iOS应用中实现自定义按钮动画。当用户点击按钮时,按钮将从圆形变为椭圆形,颜色从蓝色渐变到绿色;释放按钮时,动画以相反方式恢复。通过UIView的动画方法和弹簧动画效果,实现平滑自然的过渡。
56 1
|
2月前
|
Swift iOS开发 UED
如何使用Swift和UIKit在iOS应用中实现自定义按钮动画
【10月更文挑战第18天】本文通过一个具体案例,介绍如何使用Swift和UIKit在iOS应用中实现自定义按钮动画。当用户按下按钮时,按钮将从圆形变为椭圆形并从蓝色渐变为绿色;释放按钮时,动画恢复原状。通过UIView的动画方法和弹簧动画效果,实现平滑自然的动画过渡。
58 5
|
iOS开发
设计iOS中随系统键盘弹收和内容文字长度自适应高度的文本框
设计iOS中随系统键盘弹收和内容文字长度自适应高度的文本框
214 0
设计iOS中随系统键盘弹收和内容文字长度自适应高度的文本框