[英]Change right icon image UITextField
I am trying to change between rightView UIImages that are added as a subView to my UITextfield. 我试图在rightView UIImage之间进行切换,这些UIImage作为SubView添加到我的UITextfield中。 When a user taps the icon it should show or hide the inserted password and change the UIImage depending on the state.
当用户点击图标时,它应该显示或隐藏所插入的密码,并根据状态更改UIImage。
How am I able to edit the code below to achieve this? 我如何编辑下面的代码来实现这一目标?
Code: 码:
// Show eye icon to show the password
func textFieldDidChange() {
if passwordField.text != "" {
let leftImageView = UIImageView()
leftImageView.image = UIImage(named: "view_password")
leftImageView.contentMode = .scaleAspectFit
let leftView = UIView()
leftView.addSubview(leftImageView)
leftView.frame = CGRect(x: 0, y: 0, width: 40, height: 30)
leftImageView.frame = CGRect(x: 10, y: 10, width: 20, height: 12)
passwordField.rightViewMode = .whileEditing
passwordField.rightView = leftView
let tapgesture = UITapGestureRecognizer(target: self, action: #selector(ViewController.togglePasswordSecurity))
leftImageView.isUserInteractionEnabled = true
leftImageView.addGestureRecognizer(tapgesture)
}else{
passwordField.rightViewMode = .never
}
}
func togglePasswordSecurity(imageView: UIImageView) {
if passwordField.isSecureTextEntry == false {
// change left UIImage to hide_password
passwordField.isSecureTextEntry = true
}else{
// change left UIImage to view_password
passwordField.isSecureTextEntry = false
}
}
Thanks a lot! 非常感谢!
Have you tried adding a tag to each of your images? 您是否尝试过为每个图像添加标签? For example:
例如:
let leftImageView = UIImageView()
leftImageView.image = UIImage(named: "view_password")
leftImageView.contentMode = .scaleAspectFit
leftImageView.tag = 1
Then, to change that image you can write: 然后,要更改该图像,您可以编写:
let myImage = UIView(withTag: 1) as! UIImageView
myImage.image = ...
EDIT: To toggle between 2 images, just change this: func togglePasswordSecurity(imageView: UIImageView) { 编辑:要在2张图像之间切换,只需更改以下内容即可:func togglePasswordSecurity(imageView:UIImageView){
if passwordField.isSecureTextEntry == false {
let myImage = UIView(withTag: 1) as! UIImageView
myImage.image = YOUR_IMAGE_1
// change left UIImage to hide_password
passwordField.isSecureTextEntry = true
}else{
let myImage = UIView(withTag: 1) as! UIImageView
myImage.image = YOUR_IMAGE_2
// change left UIImage to view_password
passwordField.isSecureTextEntry = false
}
}
Solution: 解:
// Show eye icon to show the password will be triggered once there is a change in data in the UITextField
func textFieldDidChange() {
if passwordField.text != "" {
let leftImageView = UIImageView()
leftImageView.image = passwordImage
leftImageView.contentMode = .scaleAspectFit
leftImageView.tag = 1
let leftView = UIView()
leftView.addSubview(leftImageView)
leftView.frame = CGRect(x: 0, y: 0, width: 40, height: 30)
leftImageView.frame = CGRect(x: 10, y: 10, width: 20, height: 12)
passwordField.rightViewMode = .whileEditing
passwordField.rightView = leftView
let tapgesture = UITapGestureRecognizer(target: self, action: #selector(ViewController.togglePasswordSecurity))
leftImageView.isUserInteractionEnabled = true
leftImageView.addGestureRecognizer(tapgesture)
}else{
passwordField.rightViewMode = .never
}
}
func togglePasswordSecurity() {
if passwordField.isSecureTextEntry == false {
passwordImage = UIImage(named: "view_password")
textFieldDidChange()
// change left UIImage to hide_password
passwordField.isSecureTextEntry = true
}else{
passwordImage = UIImage(named: "heart")
self.textFieldDidChange()
// change left UIImage to view_password
passwordField.isSecureTextEntry = false
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.