Реализация размещения лимитного ордера в мобильном приложении биржи

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

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

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

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

Услуги, которые мы предлагаем
Показано 1 из 1Все 1735 услуг
Реализация размещения лимитного ордера в мобильном приложении биржи
Средний
~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

Реализация размещения лимитного ордера в мобильном приложении биржи

Лимитный ордер — это тип заявки, которую биржа исполняет только при достижении указанной цены или лучше. Пользователь вводит цену и объём, нажимает «Купить» — и ордер висит в ордербуке до исполнения, отмены или истечения времени (GTC, IOC, FOK). На первый взгляд это форма с двумя полями. На практике — связанная логика трёх InputField, пересчёт в реальном времени, валидация баланса, подтверждение с актуальной ценой и обработка edge-case на стороне API.

Форма ордера: взаимный пересчёт полей

Три поля — Price, Amount, Total — связаны формулой Total = Price × Amount. Пользователь может менять любое из них, два оставшихся пересчитываются автоматически. Это ломает простую реактивность: если слушать onChange всех трёх полей одновременно, получишь бесконечный цикл.

Решение — источник правды: при изменении Price или Amount пересчитывается Total, при изменении Total пересчитывается Amount (Price остаётся фиксированной). Флаг isUserEditing или debounce 150мс предотвращают зацикливание.

// iOS — взаимный пересчёт полей через Combine
class LimitOrderViewModel: ObservableObject {
    @Published var price: String = ""
    @Published var amount: String = ""
    @Published var total: String = ""

    private var cancellables = Set<AnyCancellable>()
    private var isUpdating = false

    init() {
        Publishers.CombineLatest($price, $amount)
            .debounce(for: .milliseconds(100), scheduler: RunLoop.main)
            .sink { [weak self] p, a in
                guard let self, !self.isUpdating else { return }
                guard let price = Decimal(string: p), let amount = Decimal(string: a) else { return }
                self.isUpdating = true
                self.total = "\(price * amount)"
                self.isUpdating = false
            }
            .store(in: &cancellables)
    }
}

На Android — TextWatcher или Flow с distinctUntilChanged() в ViewModel. MutableStateFlow для каждого поля, combine в CoroutineScope.

Слайдер процента от баланса

Стандартный UX: кнопки 25% / 50% / 75% / 100% под полем Amount. При нажатии на 50% — Amount устанавливается как доступный баланс / 2 / текущая цена. Если Price пустая — кнопки неактивны. Если баланс меньше минимального лота биржи — показываем предупреждение, не блокируем кнопку.

Валидация перед отправкой

Минимальный набор проверок на клиенте:

  • Price > 0 и Price в допустимом диапазоне (биржа возвращает minPrice, maxPrice, tickSize в exchangeInfo)
  • Amount >= minQty, Amount кратен stepSize
  • Total >= minNotional (минимальная сумма сделки, например 10 USDT)
  • Доступный баланс >= Total (при покупке) или >= Amount (при продаже)

tickSize и stepSize — важнее, чем кажется. Binance API вернёт ошибку -1013 LOT_SIZE, если Amount не кратен stepSize. Округление через floor(amount / stepSize) * stepSize с BigDecimal (не float!) предотвращает эту ошибку.

// Android — округление с учётом stepSize
fun roundToStep(value: BigDecimal, step: BigDecimal): BigDecimal {
    return (value.divide(step, 0, RoundingMode.FLOOR)).multiply(step)
        .setScale(step.scale(), RoundingMode.FLOOR)
}

Подтверждение ордера

Перед отправкой на API — диалог подтверждения с итоговыми параметрами. Цена в этот момент может измениться — показывай актуальную рыночную цену рядом с лимитной, чтобы пользователь видел расстояние до рынка. Кнопка подтверждения — с haptic feedback (UIImpactFeedbackGenerator / HapticFeedback в Jetpack Compose).

После успешного ответа API — обновить список открытых ордеров. Это либо WebSocket-событие executionReport (Binance), либо polling через 1–2 секунды.

Обработка ошибок API

Типичные коды ошибок Binance REST API при размещении ордера:

Код Причина Решение в UI
-1013 LOT_SIZE Amount не кратен stepSize Округлить автоматически
-1013 MIN_NOTIONAL Total < minNotional Показать минимальную сумму
-2010 Account has insufficient balance Недостаточно средств Подсветить поле Amount красным
-1021 Timestamp for this request Рассинхрон времени Синхронизировать timestamp с сервером

Ошибку -1021 клиент не должен показывать пользователю — нужно повторить запрос с скорректированным recvWindow или синхронизировать время через /api/v3/time.

Сроки: 2–3 дня: взаимный пересчёт полей, слайдер процента, валидация по правилам биржи, диалог подтверждения, обработка ошибок API.