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 UIKit class 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 UIKit class 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 示例 ...
随机推荐
- Android Studio apk 打包流程
1.Build -> Generate Signed APK...,打开如下窗口 2.假设这里没有打过apk包,点击Create new,窗口如下 这里只要输入几个必要项 Key store p ...
- STLport在vc6中的集成
STLport的下载 http://sourceforge.net/projects/stlport/ STLport的编译 * 试验环境 : win7x64sp1 + vc6sp6* 打开控制台窗口 ...
- Jquery学习笔记:操作form表单元素之一(文本框和下拉框)
一.概述 在web页面开发中,经常需要获取和设置表单元素的值(如文本框中的内容),特别是在ajax应用中,更是常态.本文系统的介绍下如何操作. 同操作其它html元素一样,操作的过程差不多. 第一步, ...
- MySQL 修改字段类型或长度
mysql> alter table 表名 modify column 字段名 类型;例如 数据库中address表 city字段是varchar(30) 修改类型可以用(谨慎修改类型,可能会导 ...
- Lucene4.3入门
辞职交接期间无聊看了一下搜索引擎,java社区比较火的当然是Lucene,想写一个简单的小例子,在网上找了些资料,不过都不是4.3的,自己看了一下. 下载地址:http://lucene.apache ...
- MSSQL - Sqlcommand
Command对象:·Command对象也称为数据库连接对象,Command对象主要执行包括添加.删除.修改.查询数据的操作命令.也可以用来执行存储过程. 属性:CommandType属性. 执行存储 ...
- 网盘大全, 邮箱大全 good
网盘推荐 115网盘 注册 百度网盘 注册 微云 注册 360云盘 注册 金山快盘 注册 新浪微盘 注册 和彩云 注册 酷盘 注册 OneDrive 外链 BOX 注册 Dropbox 注册 国内网盘 ...
- QWidget类中默认是忽略inputMethodEvent事件(要获取输入的内容就必须使用这个事件)
因为项目的需要以及主管的要求,准备将工程移植到Qt中,这样就可以比较容易的实现跨平台了.因为之前工程是在windows下开发的,第一个平台又是mobile所以除了底层框架之外其他的都是使用的windo ...
- TImage也有OnClick事件,可以当按钮使用,配上合适的图片(背景透明,效果前凸)更是几乎以假乱真
本质上TImage与TSpeedButton没有什么区别,都是没有句柄的,但都可以执行OnClick事件.有空分析一下.
- 基于visual Studio2013解决C语言竞赛题之1041反向打印
题目 解决代码及点评 /* 功能:将一个整数(最多是10位数)从低位到高位打印出来, 如该数是12345时,输出应是54321(只占一行) 时间:19:18 201 ...