ios-swift 中自定义控件的实现

先讲一下思路

我们继承UIView写一个LTView,用UILabel和UITextField作为LTView的子View.

1.首先创建一个新文件,选择xcode菜单,File -> New -> File



2.得到文件LTView.swift,我们给LTView创建两个属性,并对其初始化法


3.这时会出现一个系统能够自动修改的 错误,所以我们利用系统的错误修正功能对其自行修正,会自动补上下列代码

required init?(coder aDecoder: NSCoder) {

fatalError("init(coder:) has not been implemented")

}

4.下面我们写布局一个子视图的方法setupSubView,初始化label和textField

func setupSubView(){

//初始化这两个属性label和textField

self.label = UILabel(frame: CGRect(x: 0, y: 0, width: self.frame.size.width*0.2, height: self.frame.size.height))

self.label.backgroundColor = #colorLiteral(red: 0.8039215803, green: 0.8039215803, blue: 0.8039215803, alpha: 1)

//设置文字居中

self.label.textAlignment = .center

//切圆角

self.label.layer.cornerRadius = 5

self.label.clipsToBounds = true

self.addSubview(label)//添加到LTView上

self.textField = UITextField(frame: CGRect(x: self.frame.size.width*0.2+10, y: 0, width: self.frame.size.width*0.8-10, height: self.frame.size.height))

//定义圆角模式

self.textField.borderStyle = .roundedRect

//设置密闻输入

self.textField.isSecureTextEntry = true

self.textField.backgroundColor = #colorLiteral(red: 1, green: 1, blue: 1, alpha: 1)

self.addSubview(textField)

}

4.回到 初始化方法中,对新定义的setupSubView方法进行调用

override init(frame: CGRect) {

//调用父类对这个方法的实现

super.init(frame: frame)

self.setupSubView() //调用子视图方法

}

5.进入AppDelegate.swift中

class AppDelegate: UIResponder, UIApplicationDelegate ,UITextFieldDelegate{

//UITextFieldDelegate代理需要遵守的协议

var window: UIWindow?

//定义为全局的变量

var textField:UITextField!

var textField2:UITextField!

func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {

self.window = UIWindow(frame: UIScreen.main.bounds)

self.window?.backgroundColor = #colorLiteral(red: 0.9098039269, green: 0.4784313738, blue: 0.6431372762, alpha: 1)

self.window?.makeKeyAndVisible()

self.window?.rootViewController = ViewController()

let image = UIImageView(image: UIImage(named: "girl2.jpg"))

image.frame = CGRect(x: 100, y: 50, width: 200, height: 200)

//对图片进行切圆角处理

image.layer.cornerRadius = 100;

image.clipsToBounds = true

self.window?.addSubview(image)

let aLTView = LTView(frame: CGRect(x: 7, y: 300, width: 400, height: 50))

aLTView.label.text = "用户名"

//文本对齐格式,textAlignment是一个枚举,所以可以省略类型名

//aLTView.label.textAlignment = NSTextAlignment.center

aLTView.label.textAlignment = .center

aLTView.textField.placeholder = "请输入用户名"

aLTView.textField.delegate = self

self.window?.addSubview(aLTView)

let bLTView = LTView(frame: CGRect(x: 7, y: 370, width: 400, height: 50))

bLTView.label.text = "密码"

//提示字符

bLTView.textField.placeholder = "请输入密码"

//设置代理

bLTView.textField.delegate = self

self.window?.addSubview(bLTView)

let registerButton = UIButton(frame: CGRect(x: 80, y: 500, width: 100, height: 50))

registerButton.backgroundColor = UIColor.gray

registerButton.setTitle("登录", for: .normal)

self.window?.addSubview(registerButton)

let cancelButton = UIButton(frame: CGRect(x: 220, y: 500, width: 100, height: 50))

cancelButton.backgroundColor = UIColor.gray

cancelButton.setTitle("取消", for: .normal)

self.window?.addSubview(cancelButton)

textField = aLTView.textField

textField2 = bLTView.textField

return true

}

//点击return收起键盘    

func textFieldShouldReturn(_ textField: UITextField) -> Bool {       

 //第一响应事件       

 textField.resignFirstResponder()      

 return true    }    

//点击空白处收起键盘    

override func touchesBegan(_ touches: Set, with event: UIEvent?) {

textField.resignFirstResponder()

textField2.resignFirstResponder()

}

func applicationWillResignActive(_ application: UIApplication) {

}

func applicationDidEnterBackground(_ application: UIApplication) {

}

func applicationWillEnterForeground(_ application: UIApplication) {

}

func applicationDidBecomeActive(_ application: UIApplication) {

}

func applicationWillTerminate(_ application: UIApplication) {

}

}

最终效果

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,519评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,842评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,544评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,742评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,646评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,027评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,513评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,169评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,324评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,268评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,299评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,996评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,591评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,667评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,911评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,288评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,871评论 2 341

推荐阅读更多精彩内容