Цвет UITextField clearButtonMode

Можно ли изменить цвет clearButtonMode на текстовом поле?

theTextField.clearButtonMode = UITextFieldViewModeWhileEditing

показывает x, который является серым темным цветом для удаления текстового поля,

но могу ли я показать эту кнопку с белым цветом?

спасибо

Ответ 1

В этом случае вам нужно создать свое собственное изображение с четкими кнопками. Я предлагаю сделать снимок экрана с кнопки очистки и редактирования в Photoshop.

Вы можете взять это изображение и создать UIButton с размерами изображения. Оттуда вы можете установить его как правый UITextField. Например:

UIButton *button = [UIButton buttonWithType:UIButtonTypeCustom];
[button setImage:[UIImage imageNamed:@"clear_button.png"] forState:UIControlStateNormal];
[button setFrame:CGRectMake(0.0f, 0.0f, 15.0f, 15.0f)]; // Required for iOS7
theTextField.rightView = button;
theTextField.rightViewMode = UITextFieldViewModeWhileEditing;

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

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

Ответ 2

Более чистым способом является реализация категории на UITextField с помощью этого метода:

- (void)modifyClearButtonWithImage:(UIImage *)image {
    UIButton *button = [UIButton buttonWithType:UIButtonTypeCustom];
    [button setImage:image forState:UIControlStateNormal];
    [button setFrame:CGRectMake(0.0f, 0.0f, 15.0f, 15.0f)];
    [button addTarget:self action:@selector(clear:) forControlEvents:UIControlEventTouchUpInside];
    self.rightView = button;
    self.rightViewMode = UITextFieldViewModeWhileEditing;
}

-(IBAction)clear:(id)sender{
    self.text = @"";
}

Ответ 3

Swift версия:

extension UITextField {

    func modifyClearButtonWithImage(image : UIImage) {
        let clearButton = UIButton(type: .Custom)
        clearButton.setImage(image, forState: .Normal)
        clearButton.frame = CGRectMake(0, 0, 40, 40)
        clearButton.contentMode = .ScaleAspectFit
        clearButton.addTarget(self, action: #selector(UITextField.clear(_:)), forControlEvents: .TouchUpInside)
        self.rightView = clearButton
        self.rightViewMode = .WhileEditing
    }

    func clear(sender : AnyObject) {
        self.text = ""
    }

}

Ответ 4

Версия Swift 4.1

extension UITextField {
    func modifyClearButtonWithImage(image : UIImage) {
        let clearButton = UIButton(type: .custom)
        clearButton.setImage(image, for: .normal)
        clearButton.frame = CGRect(x: 0, y: 0, width: 40, height: 40)
        clearButton.contentMode = .scaleAspectFit
        clearButton.addTarget(self, action: #selector(UITextField.clear(sender:) ), for: .touchUpInside)
        self.rightView = clearButton
        self.rightViewMode = .whileEditing
    }

    @objc func clear(sender : AnyObject) {
        self.text = ""
        sendActions(for: .editingChanged)
    }

}

Ответ 5

В то время, когда вы настраиваете textField, используйте:

let clearButton : UIButton = textField.value(forKey: "_clearButton") as! UIButton
let image = UIImage(named: "ClearWhite")

clearButton.setImage(image, for: .normal)
clearButton.backgroundColor = UIColor.clear