Swift - 生成各种控件的工厂类(包含标签,按钮,输入框等)
在iOS开发中,页面里有时会大量的用到一些控件,如果要一个个单独创建再设置样式的话就显得很麻烦。我们可以创建一个生成各种控件的工厂类,这样在需要的时候调用下就可以了。

|
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
|
import UIKitclass ViewFactory{ /** * 控件默认尺寸 */ class func getDefaultFrame() -> CGRect { let defaultFrame = CGRectMake(0, 0, 100, 30) return defaultFrame } class func createControl(type:String, title:[String], action:Selector, sender:AnyObject) -> UIView { switch(type) { case "label": return ViewFactory.createLabel(title[0]) case "button": return ViewFactory.createButton(title[0], action: action, sender: sender as UIViewController) case "text": return ViewFactory.createTextField(title[0], action: action, sender: sender as UITextFieldDelegate) case "segment": return ViewFactory.createSegment(title, action: action, sender: sender as UIViewController) default: return ViewFactory.createLabel(title[0]) } } /** * 创建按钮控件 */ class func createButton(title:String, action:Selector, sender:UIViewController)->UIButton { var button = UIButton(frame:ViewFactory.getDefaultFrame()) button.backgroundColor = UIColor.orangeColor() button.setTitle(title, forState:.Normal) button.titleLabel!.textColor = UIColor.whiteColor() button.titleLabel!.font = UIFont.systemFontOfSize(14) button.addTarget(sender, action:action, forControlEvents:UIControlEvents.TouchUpInside) return button } /** * 创建文本输入框控件 */ class func createTextField(value:String, action:Selector, sender:UITextFieldDelegate) -> UITextField { var textField = UITextField(frame:ViewFactory.getDefaultFrame()) textField.backgroundColor = UIColor.clearColor() textField.textColor = UIColor.blackColor() textField.text = value textField.borderStyle = UITextBorderStyle.RoundedRect textField.adjustsFontSizeToFitWidth = true textField.delegate = sender return textField } /** * 创建分段单选控件 */ class func createSegment(items: [String], action:Selector, sender:UIViewController) ->UISegmentedControl { var segment = UISegmentedControl(items:items) segment.frame = ViewFactory.getDefaultFrame() //segment.segmentedControlStyle = UISegmentedControlStyle.Bordered segment.momentary = false segment.addTarget(sender, action:action, forControlEvents:UIControlEvents.ValueChanged) return segment } /** * 创建文本标签控件 */ class func createLabel(title:String) -> UILabel { let label = UILabel() label.textColor = UIColor.blackColor(); label.backgroundColor = UIColor.whiteColor(); label.text = title; label.frame = ViewFactory.getDefaultFrame() label.font = UIFont(name: "HelveticaNeue-Bold", size: 16) return label }} |
工厂类的使用:
|
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
|
import UIKitclass ViewController: UIViewController,UITextFieldDelegate { var txtNum:UITextField! var segDimension:UISegmentedControl! var btn:UIButton! override func viewDidLoad() { super.viewDidLoad() // Do any additional setup after loading the view, typically from a nib. setupControls() } func setupControls() { //创建文本标签 let labelNum = ViewFactory.createLabel("阈值:") labelNum.frame = CGRect(x: 20, y: 100, width: 60, height: 30) self.view.addSubview(labelNum) let labelDm = ViewFactory.createLabel("维度:") labelDm.frame = CGRect(x: 20, y: 200, width: 60, height: 30) self.view.addSubview(labelDm) //创建文本输入框 txtNum = ViewFactory.createTextField("", action:Selector("numChanged"), sender:self) txtNum.frame = CGRect(x:80,y:100,width:200,height:30) txtNum.returnKeyType = UIReturnKeyType.Done self.view.addSubview(txtNum) //创建分段单选控件 segDimension = ViewFactory.createSegment(["3x3", "4x4", "5x5"], action:"dimensionChanged:", sender:self) segDimension.frame = CGRect(x:80,y: 200,width: 200,height: 30) self.view.addSubview(segDimension) segDimension.selectedSegmentIndex = 1 //创建按钮控件 btn = ViewFactory.createButton("确定", action: nil, sender: self) btn.frame.origin = CGPointMake(80, 300) self.view.addSubview(btn) } override func didReceiveMemoryWarning() { super.didReceiveMemoryWarning() // Dispose of any resources that can be recreated. }} |
Swift - 生成各种控件的工厂类(包含标签,按钮,输入框等)的更多相关文章
- 背水一战 Windows 10 (42) - 控件(导航类): Frame 动画
[源码下载] 背水一战 Windows 10 (42) - 控件(导航类): Frame 动画 作者:webabcd 介绍背水一战 Windows 10 之 控件(导航类) Frame 动画 示例An ...
- 背水一战 Windows 10 (60) - 控件(媒体类): Pointer 涂鸦板, InkCanvas 涂鸦板
[源码下载] 背水一战 Windows 10 (60) - 控件(媒体类): Pointer 涂鸦板, InkCanvas 涂鸦板 作者:webabcd 介绍背水一战 Windows 10 之 控件( ...
- 背水一战 Windows 10 (34) - 控件(进度类): RangeBase, Slider, ProgressBar, ProgressRing
[源码下载] 背水一战 Windows 10 (34) - 控件(进度类): RangeBase, Slider, ProgressBar, ProgressRing 作者:webabcd 介绍背水一 ...
- 背水一战 Windows 10 (33) - 控件(选择类): ListBox, RadioButton, CheckBox, ToggleSwitch
[源码下载] 背水一战 Windows 10 (33) - 控件(选择类): ListBox, RadioButton, CheckBox, ToggleSwitch 作者:webabcd 介绍背水一 ...
- 背水一战 Windows 10 (32) - 控件(选择类): Selector, ComboBox
[源码下载] 背水一战 Windows 10 (32) - 控件(选择类): Selector, ComboBox 作者:webabcd 介绍背水一战 Windows 10 之 控件(选择类) Sel ...
- 背水一战 Windows 10 (30) - 控件(文本类): AutoSuggestBox
[源码下载] 背水一战 Windows 10 (30) - 控件(文本类): AutoSuggestBox 作者:webabcd 介绍背水一战 Windows 10 之 控件(文本类) AutoSug ...
- 背水一战 Windows 10 (29) - 控件(文本类): RichTextBlock, RichTextBlockOverflow, RichEditBox
[源码下载] 背水一战 Windows 10 (29) - 控件(文本类): RichTextBlock, RichTextBlockOverflow, RichEditBox 作者:webabcd ...
- 背水一战 Windows 10 (28) - 控件(文本类): TextBox, PasswordBox
[源码下载] 背水一战 Windows 10 (28) - 控件(文本类): TextBox, PasswordBox 作者:webabcd 介绍背水一战 Windows 10 之 控件(文本类) T ...
- 背水一战 Windows 10 (27) - 控件(文本类): TextBlock
[源码下载] 背水一战 Windows 10 (27) - 控件(文本类): TextBlock 作者:webabcd 介绍背水一战 Windows 10 之 控件(文本类) TextBlock 示例 ...
随机推荐
- 17.1.1.5 Creating a Data Snapshot Using mysqldump 创建一个快照使用mysqldump:
17.1.1.5 Creating a Data Snapshot Using mysqldump 创建一个快照使用mysqldump: 创建一个数据快照的方式是使用mysqldump 工具来备份所有 ...
- android之IntentFilter的用法_Intent.ACTION_TIME_TICK在manifest.xml不起作用
在模仿一个天气预报的widget时候,用到了IntentFilter,感觉在manifest.xml注册的receiver跟用代码写registerReceiver()的效果应该是相同的,于是想证明一 ...
- C Tips:显示点阵汉字的小样例
非常简陋的一段小程序,演示怎样显示点阵字库.有时间的时候再详解. #include <stdio.h> #include <stdlib.h> struct HzkInfoSt ...
- A2DP和AVRCP蓝牙音频传输协议的应用解释
A2DP全名是Advenced Audio Distribution Profile 蓝牙音频传输模型拹定.A2DP 规定了使用蓝牙非同步传输信道方式,传输高质量音乐文件数据的拹议堆栈软件和使用方法, ...
- CAN总线基础
can总线协议: 涵盖了OSI规定的传输层.数据链路层.物理层 物理层: 决定了位编码方式(NRZ编码,6个位插入填充位),位时序(位时序.位的采样).同步方式(根据同步段ss实现同步,并具有再同步功 ...
- java 泛型详解(普通泛型、 通配符、 泛型接口)
java 泛型详解(普通泛型. 通配符. 泛型接口) JDK1.5 令我们期待很久,可是当他发布的时候却更换版本号为5.0.这说明Java已经有大幅度的变化.本文将讲解JDK5.0支持的新功能---- ...
- iOS开发RunTime之函数调用
文章来自小笨狼的iOS博客,一直认为csdn的博客UI不太好看,看博客不太爽.所以自己搭建了一个博客. 欢迎各位去链接中看我的博客.也欢迎大家加QQ群讨论iOS技术问题 经过两个多月的面试,工作最终尘 ...
- 查询PO的预付款剩余金额
FUNCTION zrfc_mm016. *"---------------------------------------------------------------------- * ...
- How to install vim on linux
前几日了解到 vim 文本编辑器,据说很强大,使用起来效率很高,今天怀着很好奇的心理,学习了一下vim编辑器的下载安装方法,在此详细介绍一下安装vim编辑器的几种常用方法: 第一种方法就是在 Ubun ...
- __sleep和__wakeup
魔术方法__sleep和__wakeup 串行化serialize可以把变量包括对象,转化成连续bytes数据. 你可以将串行化后的变量存在一个文件里或在网络上传输. 然后再反串行化还原为原来的数据. ...