Как изменить цвет текста в UIPickerView под iOS 7?


117

Я знаю о pickerView:viewForRow:forComponent:reusingViewметоде, но при использовании viewона проходит в reusingView:том , как я могу изменить его использовать другой цвет текста? Если я использую, view.backgroundColor = [UIColor whiteColor];ни одно из представлений больше не появится.



2
@AaronBrager. Que Не дубликат, ссылка, предоставленная u, запрашивается после этой очереди.
Gajendra K Chauhan

Ответы:


323

В методе делегата есть более элегантная функция:

Objective-C:

- (NSAttributedString *)pickerView:(UIPickerView *)pickerView attributedTitleForRow:(NSInteger)row forComponent:(NSInteger)component
{
    NSString *title = @"sample title";
    NSAttributedString *attString = 
        [[NSAttributedString alloc] initWithString:title attributes:@{NSForegroundColorAttributeName:[UIColor whiteColor]}];

    return attString;
}

Если вы хотите также изменить цвета панели выбора, я обнаружил, что мне пришлось добавить 2 отдельных элемента UIViewsк представлению, содержащему UIPickerViewэлементы, разделенные на 35 пунктов для высоты средства выбора 180.

Swift 3:

func pickerView(_ pickerView: UIPickerView, attributedTitleForRow row: Int, forComponent component: Int) -> NSAttributedString? {

    let string = "myString"
    return NSAttributedString(string: string, attributes: [NSForegroundColorAttributeName:UIColor.white])
}

Swift 4:

func pickerView(_ pickerView: UIPickerView, attributedTitleForRow row: Int, forComponent component: Int) -> NSAttributedString? {

    let string = "myString"
    return NSAttributedString(string: string, attributes: [NSAttributedStringKey.foregroundColor: UIColor.white])
}

Swift 4.2:

func pickerView(_ pickerView: UIPickerView, attributedTitleForRow row: Int, forComponent component: Int) -> NSAttributedString? {

    let string = "myString"
    return NSAttributedString(string: string, attributes: [NSAttributedString.Key.foregroundColor: UIColor.white])
}

Помните, когда вы используете метод: вам не нужно реализовывать, titleForRowInComponent()поскольку он никогда не вызывается при использовании attributedTitleForRow().


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

29

Исходный пост здесь: могу ли я изменить цвет шрифта datePicker в iOS7?

- (UIView *)pickerView:(UIPickerView *)pickerView viewForRow:(NSInteger)row forComponent:(NSInteger)component reusingView:(UIView *)view
{
    UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(0, 0, pickerView.frame.size.width, 44)];
    label.backgroundColor = [UIColor grayColor];
    label.textColor = [UIColor whiteColor];
    label.font = [UIFont fontWithName:@"HelveticaNeue-Bold" size:18];
    label.text = [NSString stringWithFormat:@" %d", row+1];
    return label;
}

// number Of Components
- (NSInteger)numberOfComponentsInPickerView:(UIPickerView *)pickerView
{
    return 1;
}

// number Of Rows In Component
- (NSInteger)pickerView:(UIPickerView *)pickerView numberOfRowsInComponent:   (NSInteger)component
{
    return 6;
}

Это решение отлично работает для окна выбора, содержащего один компонент. Если у вас их больше 1, ярлыки будут перекрываться, как я вижу.
PKCLsoft

23
  1. Перейти к раскадровке
  2. Выберите PickerView
  3. Перейдите в Инспектор идентичности (3-я вкладка)
  4. Добавить определяемый пользователем атрибут времени выполнения
  5. KeyPath = textColor
  6. Тип = Цвет
  7. Значение = [цвет на ваш выбор]

Скриншот


Пожалуйста, объясните свой ответ
Gwenc37

11
это работа наполовину, текст cus черный, но когда вы прокручиваете его в сборщике, он меняется на белый
Шиал

4
Работает, только если вы прокручиваете
Крис Ван Бускерк

Привет, @ chris-van-buskirk. Проверьте мой аддон [_thePrettyPicker selectRow: prettyIndex inComponent: 0 animated: YES];
WINSergey

7

в Xamarin переопределите метод UIPickerModelView GetAttributedTitle

public override NSAttributedString GetAttributedTitle(UIPickerView picker, nint row, nint component)
{
    // change text white
    string title = GetTitle (picker, row, component); // get current text from UIPickerViewModel::GetTitle
    NSAttributedString ns = new NSAttributedString (title, null, UIColor.White); // null = font, use current font
    return ns;
}


2

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

- (UIView *)pickerView:(UIPickerView *)pickerView viewForRow:(NSInteger)row forComponent:(NSInteger)component reusingView:(UIView *)view{

    UILabel *label = [[UILabel alloc] init];
    label.backgroundColor = [UIColor blueColor];
    label.textColor = [UIColor whiteColor];
    label.font = [UIFont fontWithName:@"HelveticaNeue-Bold" size:18];

    //WithFrame:CGRectMake(0, 0, pickerView.frame.size.width, 60)];

    if(component == 0)
    {
        label.text = [countryArray objectAtIndex:row];
    }
    else
    {
        label.text = [cityArray objectAtIndex:row];
    }
    return label;
}

2

Swift 4 (обновить принятый ответ)

extension MyViewController: UIPickerViewDelegate{
    }

    func pickerView(_ pickerView: UIPickerView, attributedTitleForRow row: Int, forComponent component: Int) -> NSAttributedString? {
        return NSAttributedString(string: "your-title-goes-here", attributes: [NSAttributedStringKey.foregroundColor: UIColor.white])
    }
}

1
- (UIView *)pickerView:(UIPickerView *)pickerView viewForRow:(NSInteger)row forComponent:(NSInteger)component reusingView:(UIView *)view {
        UILabel* pickerLabel = [[UILabel alloc] initWithFrame:CGRectMake(0, 0, pickerView.frame.size.width, 37)];
        pickerLabel.text = @"text";
        pickerLabel.textColor = [UIColor redColor];
        return pickerLabel;
}
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.