it-swarm.com.ru

Как установить положение курсора в UITextView

У меня в приложении для iPhone есть UITextView, который можно редактировать. 

Новая кнопка создается внутри UITextView всякий раз, когда пользователь выбирает определенную функцию. 

Поскольку кнопка всегда расположена слева в текстовом представлении, мне нужно расположить курсор с правой стороны кнопки, чтобы пользователь мог видеть, что они печатают .... Я не могу найти документированный (или недокументированный) метод, чтобы установить местоположение курсора.

У кого-нибудь есть идеи или кто-то еще достиг чего-то подобного?

29
GURU

Я знаю, что ОЧЕНЬ поздно, но я думал, что смогу помочь людям, застрявшим в этом (как я).

performSelector:withObject:afterDelay, кажется, работает нормально (другие ответы просто не будут работать по какой-то странной причине):

- (void)textViewDidBeginEditing:(UITextView *)inView 
{ 
[self performSelector:@selector(setCursorToBeginning:) withObject:inView afterDelay:0.01]; 
} 

- (void)setCursorToBeginning:(UITextView *)inView 
{ 
//you can change first parameter in NSMakeRange to wherever you want the cursor to move
inView.selectedRange = NSMakeRange(3, 0); 
} 

источник: http://puppenspieler.tumblr.com/post/757819650/set-selectedrange-in-a-uitextview

52
Cashew
textView.editable = YES;
textView.selectedRange = NSMakeRange(2, 0);

Установите selectedRange в местоположение с длиной 0, и вы, вероятно, также хотите, чтобы textView был редактируемым, поэтому также установите его в YES.

21
Evan

Попробуйте что-то вроде этого:

dispatch_async(dispatch_get_main_queue(), ^{
    inView.selectedRange = NSMakeRange(3, 0);
});

Это приведет к выполнению selectedRange в главном потоке в начале следующего цикла выполнения.

17
acavanagh

Я использую следующее, чтобы добраться до начала textView, используя Swift 4 :

DispatchQueue.main.async {
    self.selectedTextRange = self.textRange(from: self.beginningOfDocument, to: self.beginningOfDocument)
}
4
blwinters

изменить selectedRange вашего textView. например, чтобы поместить курсор в положение 3: 

[textView setSelectedRange:NSMakeRange(3, 0)];

В вашем случае добавление некоторых пробелов в содержимое textView может помочь. и наблюдатель textview 's textDidChanged event для предотвращения этого пространства будет удален пользователем. 

3
xhan

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

 func textViewDidBeginEditing(textView: UITextView) {
        if textView.text.isEmpty {
          if self.text == "Required" || self.text == "Optional" {
            dispatch_async(dispatch_get_main_queue(), {
              textView.selectedRange = NSMakeRange(0, 0)
            });
          }
        }
      }

      func textViewDidEndEditing(textView: UITextView) {
        if CommonUtils.isEmptyString(textView.text) {
          if required {
            textView.text = "Required"
          } else {
            textView.text = "Optional"
          }
          textView.textColor = grayColor//
        }
      }

      func textViewDidChange(textView: UITextView) {
        if textView.text.isEmpty {
          if required {
            textView.text = "Required"
          } else {
            textView.text = "Optional"
          }
          textView.textColor = grayColor
          textView.selectedRange = NSMakeRange(0, 0)
        } else {
          if required {
            if textView.text.length > "Required".length {
              textView.text = self.text.replace("Required", withString: "")
            }
          } else {
            if textView.text.length > "Optional".length {
              textView.text = self.text.replace("Optional", withString: "")
            }
          }
          textView.textColor = blackColor//
        }
      }

Не забудьте зарегистрировать делегата: UITextViewDelegate

0
Rico Nguyen