Swift控件--UILabel、UIButton、UIText

2016-10-18  本文已影响0人  KallyKello

UILabel的属性

//创建一个文本标签并设置它的frame
letlabel =UILabel(frame:CGRect(x: 100, y: 50, width: 200, height: 200))
//设置文本标签的字体颜色
label.textColor= .black
//设置文本标签的文字
label.text="ni hao a"
//设置文本标签的文本显示位置
label.textAlignment= .center
//自适应字体大小
label.adjustsFontSizeToFitWidth=true
//设置字体大小
label.font= .boldSystemFont(ofSize: 22)
//文本的行数
label.numberOfLines= 0
label.lineBreakMode= .byCharWrapping
//用户是否可以交互
label.isUserInteractionEnabled=true
//文字是否可变
label.isEnabled=true
//设置阴影颜色和偏移量
label.shadowColor= .blue
label.shadowOffset=CGSize(width: 0.5, height: 0.5)
//设置是否高亮和高亮颜色
label.isHighlighted=true
label.highlightedTextColor= .red

UIButton的部分属性

//创建一个button
letbutton:UIButton=UIButton(type:UIButtonType.custom)
button.frame=CGRect(x: 100, y: 100, width: 200, height: 50)
//设置按钮的背景颜色
button.backgroundColor=UIColor.white
//设置按钮文字
button.setTitle("I'm button", for: .normal)
//设置按钮文字颜色
button.setTitleColor(.blue, for: .normal)
//设置按钮文字大小
button.titleLabel?.font=UIFont.boldSystemFont(ofSize: 18)
button.addTarget(self, action:#selector(buttonClick(_:)), for: .touchUpInside)
self.view.addSubview(button)

UITextField文本编辑框

let textField = UITextField(frame: CGRect(x: 100, y: 150, width: 200, height: 44))
//设置文本输入框的边框样式,设置背景图片要先去除边框样式
textField.borderStyle = .line
//设置文本输入框的提示文字
textField.placeholder ="这里是文本输入框"
//设置不是密码输入框
textField.isSecureTextEntry =false
//设置文本框的背景颜色
textField.backgroundColor = .white
//设置文字居中
textField.textAlignment = .center
//设置右边的清除按钮
textField.clearButtonMode = .whileEditing
//设置键盘的按钮
textField.keyboardType = .default//默认
/*
textField.keyboardType = .asciiCapable//显示音文字吗的虚拟键盘
textField.keyboardType = .numbersAndPunctuation //显示数字和标点的虚拟键盘
textField.keyboardType = .URL//显示便于输入网址的虚拟键盘
textField.keyboardType = .numberPad//显示便与输入数字的虚拟键盘
textField.keyboardType = .phonePad//显示便于拨号呼叫的虚拟键盘
textField.keyboardType = .namePhonePad//显示便于聊天拨号的虚拟键盘
textField.keyboardType = .emailAddress//显示便于输入Email的虚拟键盘
textField.keyboardType = .decimalPad//显示便于输入数字和小数点的虚拟键盘
textField.keyboardType = .twitter//显示便于输入Twitter的虚拟键盘
textField.keyboardType = .webSearch//显示便于在网页上书写的虚拟键盘
*/
//使文本框获得焦点,弹出键盘
textField.becomeFirstResponder()
//是文本框失去焦点,回收键盘
//textField.resignFirstResponder()
//设置键盘return键的样式
textField.returnKeyType = .done//完成输入回收键盘
/*
textField.returnKeyType = .go//输入完成,跳转到下一页
textField.returnKeyType = .search//搜索
textField.returnKeyType = .join//注册用户或添加数据
textField.returnKeyType = .next//继续下一步
textField.returnKeyType = .send//发送
*/
//设置代理
textField.delegate =self
self.view.addSubview(textField)

UITextField代理方法

    func textFieldShouldReturn(_ textField: UITextField) -> Bool {
        //收回键盘
        textField.resignFirstResponder()
        //设置文本的值
        myLabel?.text = textField.text
        myLabel?.sizeToFit()
        return true
    }
    
    func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange, replacementString string: String) -> Bool {
        myLabel?.text = string
        return true
    }
    
    func textFieldShouldBeginEditing(_ textField: UITextField) -> Bool {
        myLabel?.text = "开始编辑"
        return true
    }
    func textFieldShouldEndEditing(_ textField: UITextField) -> Bool {
        print("输入结束")
        return true
    }
    func textFieldDidBeginEditing(_ textField: UITextField) {
        print("已经开始编辑了")
    }
    func textFieldDidEndEditing(_ textField: UITextField, reason: UITextFieldDidEndEditingReason) {
        print("已经结束编辑了")
    }
    func textFieldShouldClear(_ textField: UITextField) -> Bool {
        print("清除内容")
        return true
    }
上一篇 下一篇

猜你喜欢

热点阅读