I create a simple project: https://github.com/edzio27/textFieldExample.git
where I add two UITextField
s, one with login and second one with secure password. I've noticed there strange behaviour:
UITextField
Notice that there is a strange behaviour in password font size. It is only appears in iOS7.
What can be the problem?
Thanks.
As a couple people pointed out, it appears secure text fields don't always play well with custom fonts. I worked around this by using the UITextField's UIControlEventEditingChanged
to monitor for changes to the textfield and set it to the system font (with the normal looking bullet points) when anything is entered, else use my custom font.
This allows me to keep using my custom font for the textfield placeholder and still look good when the password is entered. The characters that show one-at-a-time while being entered will be the system font, but I'm okay with that.
In viewDidLoad:
[self.passwordTextField addTarget:self action:@selector(textFieldDidChange:) forControlEvents:UIControlEventEditingChanged];
Now add a textFieldDidChange method:
- (void)textFieldDidChange:(id)sender
{
UITextField *textField = (UITextField *)sender;
if (textField == self.passwordTextField) {
// Set to custom font if the textfield is cleared, else set it to system font
// This is a workaround because secure text fields don't play well with custom fonts
if (textField.text.length == 0) {
textField.font = [UIFont fontWithName:@"OpenSans" size:textField.font.pointSize];
}
else {
textField.font = [UIFont systemFontOfSize:textField.font.pointSize];
}
}
}
Toggling secure/insecure state with a custom font: to show 'secure' text (blob characters), a font containing the blob character is set by iOS. This is the font you're later seeing render text when you switch to insecure mode.
Though the textfield keeps your assigned custom font, the field's content is an attributed string which references the blob-containing font.
The simple solution: write to the attributed string field, and your correct, custom font is re-applied.
To turn off secure entry & keep a custom font:
passwordTextField.secureTextEntry = false
// We have to remove iOS' secure font by setting attributedText.
let pwd = passwordTextField.text!
passwordTextField.attributedText = NSAttributedString(string: pwd)
If you turn off "Adjust to Fit" in the password field it will stop doing that resize when you resign the responder.
Set your delegate of your TextField and add this;
- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string {
if (!textField.secureTextEntry) {
return YES;
}
textField.text = [textField.text stringByReplacingCharactersInRange:range withString:string];
if (textField.text.length > 0) {
textField.font = [UIFont systemFontOfSize:18.0f];
} else {
textField.font = [UIFont fontWithName:@"YourFont" size:18.0f];
}
return NO;
}
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With