it-roy-ru.com

Прописные символы в UItextfield

У меня есть вопрос о iOS UIKeyboard.

У меня есть UITextField, и я хотел бы иметь keyboard только с заглавными буквами.

Я использую storyboard, и я попытался установить Cpitalization как «All characters» в UITextField properties.

Но это не решит мою проблему ... любое предложение?

42
Safari

Установите тип текстового поля autocapitalizationType в UITextAutocapitalizationTypeAllCharacters в UITextField

self.yourTexField.autocapitalizationType = UITextAutocapitalizationTypeAllCharacters;

После вызова делегата

// метод делегата

- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string
{
    NSRange lowercaseCharRange = [string rangeOfCharacterFromSet:[NSCharacterSet lowercaseLetterCharacterSet]];

    if (lowercaseCharRange.location != NSNotFound) {
        textField.text = [textField.text stringByReplacingCharactersInRange:range
                                                                 withString:[string uppercaseString]];
        return NO;
    }

    return YES;
}
84
codercat

Для тех, кто ищет версию Swift:

func textField(textField: UITextField, shouldChangeCharactersInRange range: NSRange, replacementString string: String) -> Bool {
     textField.text = (textField.text as NSString).stringByReplacingCharactersInRange(range, withString: string.uppercaseString)

     return false
 }

Мне не повезло с изменением свойства Capitalization: All Characters.

Правка: я хотел бы предложить использовать это для Swift 4

textField.text = (textField.text! as NSString).replacingCharacters(in: range, with: string.uppercased())
15
Tim S

Одна из проблем, с которыми я столкнулся в некоторых из приведенных выше ответов, - это если вы попытаетесь установить textfield.text, вы потеряете позицию курсора. Поэтому, если пользователь попытается отредактировать середину текста, курсор переместится в конец .

Вот мое решение Swift, все еще использующее UITextFieldDelegate:

func textField(textField: UITextField, shouldChangeCharactersInRange range: NSRange, replacementString string: String) -> Bool {

    if textField == textFieldToUppercase {
        if string == "" {
            // User presses backspace
            textField.deleteBackward()
        } else {
            // User presses a key or pastes
            textField.insertText(string.uppercaseString)
        }
        // Do not let specified text range to be changed
        return false
    }

    return true
}
14
Dan

Синтаксис сейчас 

Swift 2

textField.autocapitalizationType = UITextAutocapitalizationType.AllCharacters

Свифт 3

textField.autocapitalizationType = .allCharacters
12
Eden

Установите для свойства UITextFieldautocapitalizationType значение UITextAutocapitalizationTypeAllCharacters. Это заставит все символы появляться в верхнем регистре. Также посетите здесь чтобы узнать больше о текстовых полях

4
Adnan Aftab

Версия Swift 4.0:

Сначала установите делегат для текстового поля, которое вы хотите в верхнем регистре, на текущий ViewController (щелкните перетаскивание из текстового поля в currentViewController, чтобы установить делегат).

После добавления расширения:

extension CurrentViewController: UITextFieldDelegate{

func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange, replacementString string: String) -> Bool {

        //refference to the textfield you want to target
        if textField.tag == 5{
            textField.text = (textField.text! as NSString).replacingCharacters(in: range, with: string.uppercased())
            return false
        }
        return true
    }
}
3
Matías Contreras Selman

Это другой подход, который я использовал, когда он делает следующее:

  1. Обеспечивает использование заглавных букв, как только вводится символ 
  2. Ловит ситуации, когда пользователь отключает блокировку заглавных букв, даже если в текстовом поле установлено автоматическое заглавие
  3. Позволяет легко редактировать
  4. Работает со Swift 2.2

Сначала зарегистрируйте уведомление, которое будет обновляться при любых изменениях в текстовом поле.

    textField.addTarget(self, action: #selector(YourClassName.textFieldDidChange(_:)), forControlEvents: UIControlEvents.EditingChanged)

Затем внедрите textFieldDidChange.

func textFieldDidChange(textField: UITextField) {
    textField.text = textField.text?.uppercaseString
}

Я выбрал это, чтобы избежать ситуации, когда пользователь видит неравномерное использование некоторых заглавных букв, но затем изменяется, когда они переходят к следующему символу.

3
CodeBender

Простейшим способом было бы реализовать метод редактирования измененного текстового поля и установить текстовое значение текстового поля в верхнем регистре представления введенного текста.

@property (nonatomic, strong) IBOutlet UITextField *yourTextfield

// add target in code or use interface builder
[self.yourTextField addTarget:self 
                       action:@selector(uppercaseTextField)
             forControlEvents:UIControlEventEditingChanged];

- (IBAction)uppercaseTextField:(UITextField*)textField
{
    textField.text = [textField.text uppercaseString];
}
1
Omkar Guhilot

Вы также можете использовать этот код.

-(BOOL) textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range     replacementString:(NSString *)string{

    // Uppercase for string which you need 
    textField.text = [textField.text stringByReplacingCharactersInRange:range 
                                 withString:[string uppercaseString]];

    // return NO because You have already done it in above code
    return NO;
}
1
Linh Nguyen
/**
 We take full control of the text entered so that lowercase cannot be inserted
 we replace lowercase to uppercase
*/
func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange, replacementString string: String) -> Bool {

    // No spaces allowed
    if string == " " {
        return false
    }

    // delete key pressed
    if string == "" {
        textField.deleteBackward()
        return false
    }

    // We only allow alphabet and numbers
    let numbersAndLettersSet = CharacterSet.alphanumerics
    if string.lowercased().rangeOfCharacter(from: numbersAndLettersSet) == nil {
        return false
    }

    // Add the entered text
    textField.insertText(string.uppercased())

    // Return false as we are doing full control
    return false
}
0
Chris

Может быть, здесь уже слишком поздно для ответа, но, поскольку у меня есть рабочее решение, кто-то может найти его полезным.

Хорошо, в следующем методе делегата текстового поля проверьте, содержит ли новая строка какие-либо строчные буквы. Если так, то:

  • Добавьте только что введенный символ к тексту текстового поля.
  • Сделать весь текстовый текст в верхнем регистре.
  • Убедитесь, что метод false возвращается.

В противном случае просто верните true и позвольте методу работать как положено.

Вот его реализация:

func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange, replacementString string: String) -> Bool {
    var returnValue = true
    let lowercaseRange = string.rangeOfCharacter(from: CharacterSet.lowercaseLetters)
    if let _ = lowercaseRange?.isEmpty {
        returnValue = false
    }

    if !returnValue {
        textField.text = (textField.text! + string).uppercased()
    }

    return returnValue
}

Вышеописанное отлично работает для меня, и аналогичная реализация работает и для текстовых представлений, после внесения необходимых корректировок в первую очередь.

Надеюсь, поможет!

0
Gabriel T.

Наконец, я нашел способ, который учитывает также редактирование текста в середине строки в UITextField

Проблема заключается в том, что если вы замените весь текст свойством UITextFiled.text, фактический курсор переместится в конец текста. Поэтому вам нужно использовать метод .replace(), чтобы точно указать, какие символы вы хотите обновить в upperCase. 

Последнее, что нужно вернуть string.isEmpty как возвращаемое значение функции - в противном случае вы не разрешите удаление текста.

func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange, replacementString string: String) -> Bool {
    if let text = textField.text, let textRange = Range(range, in: text) {
        let uppercasedString = string.uppercased()
        let updatedText = text.replacingCharacters(in: textRange, with: uppercasedString)
        if let selectedTextRange = textField.selectedTextRange {
            textField.replace(selectedTextRange, withText: uppercasedString)
            approveButtonState(vin: updatedText)
        }
        return string.isEmpty
    }
    return false
}
0
Marek Staňa