Russian Qt Forum

Qt => Qt Embedded => Тема начата: Гурман от Январь 31, 2017, 16:42



Название: Ministro или как лучше распространять библиотеки Qt
Отправлено: Гурман от Январь 31, 2017, 16:42
Всё время считал, что есть два способа поставить Qt-приложение для Android:
1. сборка с библиотеками Qt, которые включаются в APK и дублируются при каждой установке гомогенных приложений, собранных с одной и той же версией Qt
2. сборка с использованием Ministro, который при установке приложения будет предложено установить чтобы он скачал и установил библиотеки.
Оба способа мне не нравились по ряду причин. Но сегодня заметил абзац в руководстве Qt, который почему-то раньше не отложился в долговременной памяти:
Цитировать
There are some special variables recognized by Qt which can be placed inside the manifest:

    android.app.use_local_qt_libs: If this is set to 1, Qt libraries are expected to be found on the target device. If it is 0, then libraries must be requested from the Ministro service.
    android.app.bundle_local_qt_libs: If set to 1, the Qt libraries are expected to be bundled as part of the APK. If set to 0, they are expected to be found in the /data/local/tmp/qt folder on the target device.
    Note: If use_local_qt_libs is 0, then this variable has no effect, since libraries are then requested through Ministro instead.

Вот это интересно особенно про android.app.bundle_local_qt_libs. То есть, можно по идее собрать одно своё приложение, при установке которого Qt-библиотеки будут заброшены в /data/local/tmp/qt, а при установке другого с такими же библиотеками они уже забрасываться туда не будут. Или будут, но это пофик - главное чтобы оттуда использовались. Для меня это идеальный вариант - и библиотеки будут разделяемые, и с Ministro связываться не надо.

Вопрос только - как сделать, чтобы при установке библиотеки Qt сначала из APK копировались в указанный каталог, затем происходило дальше всё как надо? Идея создать некий отдельный инсталлятор-приложение, которое только библиотеки туда закидывает - плохая идея. Надо чтобы они копировались куда надо при первой же установке.

Кто-нибудь разбирался с установкой APK? Как это можно сделать?


Название: Re: Ministro или как лучше распространять библиотеки Qt
Отправлено: qate от Февраль 01, 2017, 14:35
правильно ли я понял, что если есть 2 программы и они весят со всеми либами пусть 30мб
тогда сейчас пользователь в обоих случаях скачает 30мб
и хочется скачать после установки первой программы только, например, 1 мб самой программы и не качать теже самые либы ?


Название: Re: Ministro или как лучше распространять библиотеки Qt
Отправлено: Гурман от Февраль 01, 2017, 16:22
правильно ли я понял, что если есть 2 программы и они весят со всеми либами пусть 30мб
тогда сейчас пользователь в обоих случаях скачает 30мб
и хочется скачать после установки первой программы только, например, 1 мб самой программы и не качать теже самые либы ?

Не совсем. Чтобы не качать два раза всё то же самое, достаточно использовать Ministro - тогда он будет скачивать нужные библиотеки только один раз. Но кроме скачивания, библиотеки Qt надо ещё хранить. Скачивается всё сжатое до 3-х раз, а вот хранятся библиотеки распакованные. Вот тут мне надо чтобы хранилась только одна копия библиотек Qt, а сколько раз они будут внутри APK скачиваться - по барабану, это доли копеек по стоимости. Сжатое в APK приложение сейчас около 7 МБайт - для скачивания это не существенно, это длина одного анимированного GIF-а с котятами в соцсетях. Сейчас у меня будут 3 приложения с общими библиотеками Qt, позже их станет 5, а в дальнейшем их может быть 10, а потом и 30 или больше. Скачивать их будут не одновременно, но хранить могут все одновременно. Не по 30 МБайт правда, но по 15 МБайт библиотек на каждое приложение - это уже дохрена получится. Ministro это тоже решает, библиотеки Qt хранятся в одной копии, но вот... не хочется связываться со сторонним приложением. Например, если по какому-то недоразумению меня вдруг забанят на Google Play (там сейчас говорят роботы банят за каждый безобидный чих), то не понятно, как будет Ministro оттуда устанавливаться на машины новых клиентов, если само приложение будет распространяться через другой сервис. Поэтому хочется избавиться от Ministro, но библиотеки хранить в одном экземпляре. Qt-приложения на Android умеют так библиотеки использовать, но не ясно как такое приложение инсталлировать.


Название: Re: Ministro или как лучше распространять библиотеки Qt
Отправлено: qate от Февраль 01, 2017, 23:58
т.е. хочется заменить ministro на свой my_ministro ?
наверно смысл есть, как сделать не знаю, также интересно


Название: Re: Ministro или как лучше распространять библиотеки Qt
Отправлено: Гурман от Февраль 02, 2017, 02:53
т.е. хочется заменить ministro на свой my_ministro ?
наверно смысл есть, как сделать не знаю, также интересно

Не, не хочется. Основное назначение Ministro - поддержка связи приложения с библиотеками Qt, включая их обновление при наличии исправлений. И автоматическая загрузка варианта, соответствующего аппаратной платформе. Хранение разделяемых библиотек для всех Qt-приложений - это у Ministro скорее побочный эффект, по необходимости. Иначе Ministro пришлось бы скачивать библиотеки заново для каждого поддерживаемого приложения.

Но мне нужно только и исключительно это, и без скачивания библиотек отдельно. Они у меня в .APK каждого приложения будут. Но я хочу, чтобы они извлекались в один каталог и оттуда работали.

Правда сейчас с удивлением прочёл в одном из обсуждений, что вроде бы можно собирать приложения статически и распространять закрытыми не нарушая GPL, и не предоставляя исходники. Якобы достаточно предоставить только ссылки на свои объектные модули, чтобы их можно было скачать. Надо разобраться, может вообще не потребуется тащить Qt-библиотеки.


Название: Re: Ministro или как лучше распространять библиотеки Qt
Отправлено: qate от Февраль 02, 2017, 10:46
если задача сокращения объема скачивания не актуальна, то я не пойму смысла с отдельным общим каталогом


Название: Re: Ministro или как лучше распространять библиотеки Qt
Отправлено: Day от Февраль 02, 2017, 16:25
Цитировать
вроде бы можно собирать приложения статически
Они будут огромными. Сравнимо с объемом библиотек. Совсем чуток (в несколько раз) меньше.


Название: Re: Ministro или как лучше распространять библиотеки Qt
Отправлено: Гурман от Февраль 02, 2017, 17:00
если задача сокращения объема скачивания не актуальна, то я не пойму смысла с отдельным общим каталогом

Ещё раз - скачивается каждое приложение по 7 МБайт по одному разу, а хранится в APK по 15 МБайт на каждое приложение постоянно. На 5 приложений будет храниться 45 МБайт. Но если библиотеки Qt в одном каталоге будут лежать, то будет храниться только 15 МБайт.


Название: Re: Ministro или как лучше распространять библиотеки Qt
Отправлено: Гурман от Февраль 02, 2017, 17:03
Цитировать
вроде бы можно собирать приложения статически
Они будут огромными. Сравнимо с объемом библиотек. Совсем чуток (в несколько раз) меньше.

Я делал статические приложения на десктопе - разница в 2-3 раза была. То есть, вместо 15 МБайт библиотек получалось 5-7 МБайт бинарник. Правда пока не ясно, можно ли вообще сделать статическое приложение для Android - для него даже основной модуль с main() собирается в .so библиотеку, то есть динамически связывается при запуске.