Приложение Маяки Эстонии
24 Марта

На прошлой неделе я, переполняемый гордостью, рапортовал в Инстаграме, что iOS-версия приложения "Маяки Прибалтики" впервые за почти пять месяцев обновилась и получила анимацию моргания. Теперь небольшой рассказ о том, что было до и немного после. К сожалению, Александр, который до этого, по сути, делал всю работу по версии для iOS, сейчас уже не располагает временем на такую помощь. Выход тут был один - покупать самому MacBook и осваивать сборку приложения.

Ранее я вообще никогда и никак с эппловскими устройствами не общался. Единственное исключение - рабочий iPad, на котором сайты тестирую. Учитывая всё это, у меня ушло три дня на установку и настройку Flutter и Xcode, сборку приложения и размещения его в AppStore. Сложнее всего было с сертификатами. Сертификат разработчика Apple, сертификат издателя Apple, сертификат разработчика iOS (а это чё, не Apple???), сертификат издателя iOS и куча каких-то других. Для меня всё это было так: сертификат для того, чтобы проехаться верхом на коне; сертификат для того, чтобы рассказать всем о том, как ты проехался на коне; сертификат для того, чтобы выслушать впечатления коня от этой поездки; сертификат для того, чтобы пересказать впечатления коня и дальше в том же духе. В итоге обновление было выпущено и... Быстро выяснилось: кое-что из того, что работало ранее, сейчас не работает. Александр сделал мне трансфер самого приложения в AppStore на мой аккаунт, но не передал никаких файлов. В итоге всё, что требовало отдельной настройки для iOS, перестало работать. А именно: все внешние ссылки (кнопка "Показать на карте" и кнопка обратной связи) и переведённое название приложения под иконкой.

Ещё когда обновление "Маяков Прибалтики" было на рассмотрении (это занимает примерно сутки), я сразу занялся вторым приложением - "Маяки России". Я узнал, что у Apple есть возможность выпустить приложение как бета-версию для тестирования. Идея мне очень понравилась и я сразу принялся это реализовывать. Разумеется, тут я столкнулся с теми же проблемами со внешними ссылками. За несколько дней я всё это исправил и сделал аналогичные исправления в "Маяках Прибалтики". В итоге, вчера вечером прошло проверку и было выпущено обновление для "прибалтийского" приложения и сейчас там всё работает.

Рабочее место разработчика

Что же до "Маяков России", то и это приложение вышло в открытое плавание. На iOS его можно установить через специальное приложение TestFlight, ссылка здесь. На Android оно вышло в раннем доступе. Через поиск в Play Market его не найти (такое ограничение раннего доступа), качать надо по этой ссылке.

По итогу, тот редкий случай, когда я горд собой. Теперь я прошёл весь путь от создания приложения до его публикации, как в Play Market, так и в AppStore, да ещё и с заходом на тестирование.

Дальнейшие планы по "Маякам России" следующие. Сегодня я добавлю информацию о последнем маяке Белого моря и начну добавлять объекты Баренцева моря. По семейным обстоятельствам, времени в ближайшие пару месяцев у меня будет немного. Когда это сделаю, будет релиз приложения и начну следующий регион - Приморье. Вот он точно займёт много времени.

Крым наш?

Совершенно не знаю, что делать с маяками Крыма. Вопрос не этический, а тупо геополитический. Де факто это территория России, значит и маяки там - маяки России. Но мировые страны упорно не хотят этого признавать и... короче, хрен его знает.

30 Декабря

Отчётная и итоговая для этого года публикация о разработке приложения "Маяки России". Планировал до конца года поработать только над интерфейсом, но тесное общение с помогающим мне дизайнером-волонтёром (Артём, спасибо тебе ещё раз), расширило спектр моих работ. Самым серъёзным нововведением стала страница поиска по всем маякам. Это очень нужная функция для тех, кто хочет найти маяк, но не уверен, в каком регионе он находится. Из более мелких исправлений: фильтр "все маяки/мои маяки" в списке маяков региона, полная переработка логики кнопки "назад", добавление региона в табличку данных о маяке. Последнее сделано для того, чтобы лучше понимать, о каком маяке речь, если пользователь попал на эту страницу из поиска или из "моих маяков". Ещё полностью переработана страница выбора региона. Это первое, что видит пользователь при запуске приложения и она должна выглядеть максимально привлекательно.

Приложение "Маяки России"

Ещё была решена старая проблема с высотой раскрытого верхнего блока на странице списка маяков. В зависимости от ширины экрана устройства и длины названия, текст там может занимать от двух до четырёх строк, при этом, высоту надо чётко задавать в самом начале. Решение в лучших традициях костылестроения нашёл на StackOverflow: ещё до начала отрисовки я создаю блок нужной ширины с текстом заголовка и замеряю его высоту, блок этот нигде не отображается, а высота передаётся дальше и используется при отрисовке.

Приложение "Маяки России"

Ну и немного цифр. Сейчас в приложении 115 маяков и 343 фотографии - отличный результат для четырёх месяцев работы. Я до сих пор не могу определиться с релизом. С одной стороны, всё, что надо, уже готово и можно выпускаться. С другой - пока добавлено около трети запланированного контента, большинство регионов отсутствует. Я опасаюсь, что не все отнесутся к этому с пониманием и приложение нахватает низких оценок, что весьма нежелательно. В общем, надо думать.

Вас же я призываю устанавливать новую версию приложения (если у вас Андроид) и писать свои комментарии и пожелания в Телеграме. Ссылка на канал теперь есть в главном меню приложения. И хороших вам праздников!

22 Декабря

Продолжаю рассказ о разработке приложения "Маяки России". Вчерашняя публикация носила несколько деструктивный характер: то не прижилось, это реализовать не получилось. Сегодня всё наоборот и первое, с чего надо начать - функционал приложения (каким я его изначально задумывал) готов полностью. А вот с дизайном и UI ещё точно надо поработать.

Большая часть приложения, работу над которой я завершил сегодня - "Мои маяки". Это избранное, где пользователь может сохранять для себя маяки из приложения. На странице каждого маяка есть кнопка, которая позволяет добавить этот маяк в избранное или убрать оттуда. Также это можно сделать долгим нажатием прямо на странице списка маяков. На самой странице "Мои маяки" находится, собственно, список отмеченных маяков. Также там можно по-тиндеровски смахнуть маяк вправо и он будет удалён из списка. Теперь у меня есть железобетонное оправдание перед женой, зачем я ставил Tinder.

На разработку всего этого функционала у меня ушло 8-9 часов, результатом я крайне доволен. Для скачивания данная версия пока не доступна, как писал выше, надо поработать с интерфейсом.

21 Декабря

О приложении "Маяки России" не писал больше полутора месяцев, самое время. Много добавил контента, но об этом напишу отдельно в отчётной публикации, сейчас же именно разработка. Ей в чистом виде я уделял времени куда меньше, чем контенту. На этой неделе переключился на неё и... многое пришлось переделывать.

Чтобы в плане интерфейса не делать клон своего предыдущего приложения, я решил делать меню не привычное, открывающееся по иконке-"гамбургеру", а на специальной плашке внизу. Достаточно быстро я столкнулся с проблемой, когда все кнопки с подписями просто не помещаются. Вышел из положения так: на каждой странице ненужные кнопки скрываются. В последнее время нередко приходится делать так на сайтах и у меня двоякое отношение к этому способу. С одной стороны, удобнее, а с другой - пользователь очень не любит, когда решают за него и может воспринимать это негативно. В случае с приложением и это не помогло - с увеличением функционала кнопки всё равно перестали помещаться. В итоге сегодня пришлось делать меню "по классике".

Приложение "Маяки России"

Ещё одна идея, которая не прижилась, связана с картой. Напомню, карта показывает выбранный регион (общей карты всей России нет и не планируется) и маяки в нём. В какой-то момент мне подумалось, что можно было бы загружать вообще маяки, но показывать карту, как и раньше. То есть пользователь видит выбранный регион и его маяки, но если перемещает карту в любое другое место, маяки там отображаются тоже. На практике всё оказалось не так хорошо. Пользователь нажимает на маркер, не относящийся к выбранному региону и переходит на страницу маяка, затем возвращается назад на карту и переключается на список маяков выбранного региона - только что просмотренного маяка там не будет, так как он относится к другому региону. Другой случай: для регионов "Приморье" и "Сахалин и курильские острова" будет отображаться примерно один участок карты, только в одном случае будут материковые маяки, а в другом - островные. Если показывать все маркеры, то пользователь сразу, не двигая карту будет видеть в два раза больше маяков, чем было в списке. Всё это будет для пользователя непонятным и неочевидным, а значит, опять-таки, приведёт к негативному восприятию.

Короче, что ни строчка кода - то шаг с совершенству.

22 Августа

Трудности картографии

Началось всё с того, что знакомый зарепортил мне ошибку в моём приложении: на iOS не работает кнопка maps.me. Проверил у себя на android - работает, проверил на iPad - не работает. Пошёл гуглить, в чём причина и открылась небольшая табакерка Пандоры. Оказывается, у проекта сейчас переломный момент. Если вкратце, то там новые хозяева, которые имеют видение будущего очень отличное от всей прошлой идеологии проекта. Подробно всё описано тут и тут. Чего в этих статьях не написано, но что обнаружил я:

  • вся информация об API сервиса убрана, есть только инфа двухгодичной давности на GitHub
  • deeplinks (ссылка извне непосредственно в приложение, то, что используется в моём приложении) работают там, где это не сломали
  • официальной информации о deeplinks, опять же, нет

Честно скажу, сам я maps.me никогда не пользовался. На Жужмуе видел у других участников поездки, что тропки и дорожки такого удалённого острова указаны там весьма подробно. Позднее узнал, что там ещё есть возможность экспортировать целые списки маркеров. Очень удобно, но попользоваться уже не судьба. А вот в приложении надо было ошибку как-то исправлять. Первоначальной идеей было просто убрать кнопку на iOS, но не очень она мне нравится. Неизвестно, когда deeplinks и на android сломаются. Разумнее найти альтернативу и заменить maps.me на что-то другое. Я потыкался-помыкался, но ничего хорошего не нашёл. Либо у приложений нет deeplinks, либо популярность их невысока. Когда уже отчаялся, реализовал вариант со скрытием кнопки (обновление пока не вышло) и сегодня утром когда писал этот текст, ища статью на хабре с описанием трудностей maps.me, я нашёл сервис Organic Maps. Это отпочкование от maps.me, но, судя по описанию, весьма продуманное. Сразу же написал в чат поддержки в телеге, получил информацию о deeplinks. Попробовал, всё работает, но карта в приложении не центруется и маркер остаётся где-то за кадром. Потом долгое общение всё в той же телеге, тесты, открытие issue на GitHub, ужин. Короче, я не очень помню как прошёл сегодняшний день. Воскресенье программиста, мля.

Цитировать
в комментарии