Реализация AI-рерайтинга текста в мобильном приложении

TRUETECH занимается разработкой, поддержкой и обслуживанием мобильных приложений iOS, Android, PWA. Имеем большой опыт и экспертизу для публикации мобильных приложений в популярные маркеты Google Play, App Store, Amazon, AppGallery и другие.

Разработка и поддержка любых видов мобильных приложений:

Информационные и развлекательные мобильные приложения
Новостные приложения, игры, справочники, онлайн-каталоги, погодные, фитнес и здоровье, туристические, образовательные, социальные сети и мессенджеры, квиз, блоги и подкасты, форумы, агрегаторы
Мобильные приложения электронной коммерции
Интернет-магазины, B2B-приложения, маркетплейсы, онлайн-обменники, кэшбэк-сервисы, биржи, дропшиппинг-платформы, программы лояльности, доставка еды и товаров, платежные системы
Мобильные приложения для управления бизнес-процессами
CRM-системы, ERP-системы, управление проектами, инструменты для команды продаж, учет финансов, управление производством, логистика и доставка, управление персоналом, системы мониторинга данных
Мобильные приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, платформы предоставления электронных услуг, платформы кешбека, видеохостинги, тематические порталы, платформы онлайн-бронирования и записи, платформы онлайн-торговли

Это лишь некоторые из типы мобильных приложений, с которыми мы работаем, и каждый из них может иметь свои специфические особенности и функциональность, а также быть адаптированным под конкретные потребности и цели клиента.

Услуги, которые мы предлагаем
Показано 1 из 1Все 1735 услуг
Реализация AI-рерайтинга текста в мобильном приложении
Простой
~2-3 дня
Часто задаваемые вопросы

Наши компетенции:

Этапы разработки

Последние работы

  • image_mobile-applications_feedme_467_0.webp
    Разработка мобильного приложения для компании FEEDME
    792
  • image_mobile-applications_xoomer_471_0.webp
    Разработка мобильного приложения для компании XOOMER
    671
  • image_mobile-applications_rhl_428_0.webp
    Разработка мобильного приложения для компании RHL
    1097
  • image_mobile-applications_zippy_411_0.webp
    Разработка мобильного приложения для компании ZIPPY
    969
  • image_mobile-applications_affhome_429_0.webp
    Разработка мобильного приложения для компании Affhome
    914
  • image_mobile-applications_flavors_409_0.webp
    Разработка мобильного приложения для компании FLAVORS
    495

Реализация AI-рерайтинга текста в мобильном приложении

Рерайтинг в мобильном приложении — узкая задача: пользователь выделил фрагмент, нажал кнопку, получил переписанную версию. Простая идея, но реализаций-граблей здесь больше, чем кажется.

Работа с выделением текста

Самое трудное — не AI-часть, а корректная работа с selectedRange при замене текста. Если заменить NSRange неправильно, курсор прыгает в начало, выделение слетает, история undo ломается.

// iOS: безопасная замена выделенного текста с сохранением undo
func replaceSelection(with newText: String) {
    guard let textView = self.textView,
          let selectedRange = Range(textView.selectedRange, in: textView.text) else { return }

    // Регистрируем undo перед изменением
    textView.undoManager?.registerUndo(withTarget: self) { [oldText = textView.text, oldRange = textView.selectedRange] target in
        target.restoreText(oldText, cursorAt: oldRange)
    }

    textView.textStorage.beginEditing()
    textView.textStorage.replaceCharacters(
        in: textView.selectedRange,
        with: NSAttributedString(string: newText, attributes: textView.typingAttributes)
    )
    textView.textStorage.endEditing()

    // Устанавливаем курсор в конец вставленного текста
    let newCursorPos = textView.selectedRange.location + newText.utf16.count
    textView.selectedRange = NSRange(location: newCursorPos, length: 0)
}

На Android с EditText аналог через Editable.replace() + Selection.setSelection(). В Compose — через TextFieldState в новом API (доступен с Compose BOM 2024.06).

Промпты для разных сценариев рерайтинга

Универсального промпта нет. У каждого режима свой:

enum RewriteMode {
    case simplify, formalize, casual, shorten, expand, fix

    var systemPrompt: String {
        switch self {
        case .simplify:
            return "Rewrite the text using simpler words and shorter sentences. Preserve all meaning. Same language as input."
        case .formalize:
            return "Rewrite in formal business style. Remove colloquialisms. Preserve all key information."
        case .casual:
            return "Rewrite in a friendly, conversational tone. Natural language, not stiff."
        case .shorten:
            return "Shorten by 40-60%. Keep only essential information. No filler."
        case .expand:
            return "Expand with relevant details and examples. Add 50-100% more content. Stay on topic."
        case .fix:
            return "Fix grammar, spelling, and awkward phrasing. Minimal changes to preserve the original voice."
        }
    }
}

Ключевая строка во всех промптах: «Same language as input». Без неё GPT иногда переключается на английский, особенно если в тексте есть технические термины.

UI паттерн: «до/после»

Пользователь должен видеть оригинал рядом с рерайтом и легко откатиться. Не прячьте исходник.

@Composable
fun RewriteResultView(
    original: String,
    rewritten: String,
    onAccept: () -> Unit,
    onDiscard: () -> Unit,
    onRetry: () -> Unit
) {
    Column(modifier = Modifier.fillMaxWidth()) {
        Text("Оригинал", style = MaterialTheme.typography.labelSmall, color = MaterialTheme.colorScheme.onSurfaceVariant)
        Text(
            text = original,
            modifier = Modifier
                .fillMaxWidth()
                .background(MaterialTheme.colorScheme.surfaceVariant, RoundedCornerShape(8.dp))
                .padding(12.dp),
            style = MaterialTheme.typography.bodyMedium.copy(
                color = MaterialTheme.colorScheme.onSurfaceVariant
            )
        )

        Spacer(Modifier.height(8.dp))

        Text("Результат", style = MaterialTheme.typography.labelSmall)
        Text(
            text = rewritten,
            modifier = Modifier
                .fillMaxWidth()
                .background(MaterialTheme.colorScheme.primaryContainer, RoundedCornerShape(8.dp))
                .padding(12.dp)
        )

        Row(modifier = Modifier.fillMaxWidth(), horizontalArrangement = Arrangement.SpaceBetween) {
            TextButton(onClick = onDiscard) { Text("Отмена") }
            TextButton(onClick = onRetry) { Text("Ещё вариант") }
            Button(onClick = onAccept) { Text("Принять") }
        }
    }
}

Кнопка «Ещё вариант» важна — первый рерайт не всегда подходит, но и возиться с промптом пользователь не хочет.

Diff-подсветка изменений

Для режима fix (правка грамматики) полезно показать, что именно изменилось. Простой diff на клиенте без сервера:

// Упрощённый word-level diff
func computeDiff(original: String, rewritten: String) -> [DiffChunk] {
    let origWords = original.split(separator: " ").map(String.init)
    let newWords = rewritten.split(separator: " ").map(String.init)
    // LCS-based diff, реализация через стандартный алгоритм
    return lcs(origWords, newWords)
}

На Android — DiffUtil из androidx.recyclerview работает для списков, для текста нужна собственная реализация LCS или библиотека java-diff-utils.

Ориентиры по срокам

Базовый рерайтинг (один режим, без diff) — 2–4 дня. Полноценная реализация с множеством режимов, diff-подсветкой, корректным undo и историей вариантов — 1.5–2 недели.