Сборка телефонной заставки, не отображающая заставку
Этот вопрос задавали в прошлом, но ни один из ответов, которые я нашел, не разрешил проблему для меня.
Я пытаюсь сделать очень простое приложение для телефонных разговоров, чтобы показать заставку и объявить, когда она будет готова. Это просто тестовое приложение, чтобы разобраться, как использовать заставку.
- Я использую функцию phonegap через телефонную таблицу cli.
- телефонная версия 3.5.0
- проверено только на Android.
У меня есть папка www, где находится config.xml
. Все заставки находятся в пределах www/res/screen/<platform>/filename.png
Мой конфигурационный файл
<?xml version='1.0' encoding='utf-8'?>
<widget id="uk.co.workshop14.splashscreen-example-app" version="0.1.0" xmlns="http://www.w3.org/ns/widgets" xmlns:gap="http://phonegap.com/ns/1.0">
<name>splashscreen-example-app</name>
<description>
Hello World sample application that responds to the deviceready event.
</description>
<author email="[email protected]" href="#" onclick="location.href='http://phonegap.com'; return false;">
Peter
</author>
<preference name="permissions" value="none" />
<preference name="phonegap-version" value="3.5.0" />
<preference name="orientation" value="default" />
<preference name="target-device" value="universal" />
<preference name="fullscreen" value="true" />
<preference name="webviewbounce" value="true" />
<preference name="prerendered-icon" value="true" />
<preference name="stay-in-webview" value="false" />
<preference name="ios-statusbarstyle" value="black-opaque" />
<preference name="detect-data-types" value="true" />
<preference name="exit-on-suspend" value="false" />
<preference name="show-splash-screen-spinner" value="true" />
<preference name="auto-hide-splash-screen" value="false" />
<preference name="SplashScreenDelay" value="10000" />
<preference name="disable-cursor" value="false" />
<preference name="android-minSdkVersion" value="7" />
<preference name="android-installLocation" value="auto" />
<gap:plugin name="org.apache.cordova.device" />
<gap:plugin name="org.apache.cordova.splashscreen" />
<icon src="icon.png" />
<icon gap:platform="android" gap:qualifier="ldpi" src="res/icon/android/icon-36-ldpi.png" />
<icon gap:platform="android" gap:qualifier="mdpi" src="res/icon/android/icon-48-mdpi.png" />
<icon gap:platform="android" gap:qualifier="hdpi" src="res/icon/android/icon-72-hdpi.png" />
<icon gap:platform="android" gap:qualifier="xhdpi" src="res/icon/android/icon-96-xhdpi.png" />
<icon gap:platform="blackberry" src="res/icon/blackberry/icon-80.png" />
<icon gap:platform="blackberry" gap:state="hover" src="res/icon/blackberry/icon-80.png" />
<icon gap:platform="ios" height="57" src="res/icon/ios/icon-57.png" width="57" />
<icon gap:platform="ios" height="72" src="res/icon/ios/icon-72.png" width="72" />
<icon gap:platform="ios" height="114" src="res/icon/ios/icon-57-2x.png" width="114" />
<icon gap:platform="ios" height="144" src="res/icon/ios/icon-72-2x.png" width="144" />
<icon gap:platform="webos" src="res/icon/webos/icon-64.png" />
<icon gap:platform="winphone" src="res/icon/windows-phone/icon-48.png" />
<icon gap:platform="winphone" gap:role="background" src="res/icon/windows-phone/icon-173.png" />
<gap:splash gap:platform="android" gap:qualifier="port-ldpi" src="res/screen/android/screen-ldpi-portrait.png" />
<gap:splash gap:platform="android" gap:qualifier="port-mdpi" src="res/screen/android/screen-mdpi-portrait.png" />
<gap:splash gap:platform="android" gap:qualifier="port-hdpi" src="res/screen/android/screen-hdpi-portrait.png" />
<gap:splash gap:platform="android" gap:qualifier="port-xhdpi" src="res/screen/android/screen-xhdpi-portrait.png" />
<gap:splash gap:platform="blackberry" src="res/screen/blackberry/screen-225.png" />
<gap:splash gap:platform="ios" height="480" src="res/screen/ios/screen-iphone-portrait.png" width="320" />
<gap:splash gap:platform="ios" height="960" src="res/screen/ios/screen-iphone-portrait-2x.png" width="640" />
<gap:splash gap:platform="ios" height="1136" src="res/screen/ios/screen-iphone-portrait-568h-2x.png" width="640" />
<gap:splash gap:platform="ios" height="1024" src="res/screen/ios/screen-ipad-portrait.png" width="768" />
<gap:splash gap:platform="ios" height="768" src="res/screen/ios/screen-ipad-landscape.png" width="1024" />
<gap:splash gap:platform="winphone" src="res/screen/windows-phone/screen-portrait.jpg" />
<access origin="*" />
</widget>
Ответы
Ответ 1
У вас нет тега splash по умолчанию, который
<splash src="splash.png" />
В документации:
http://docs.phonegap.com/phonegap-build/configuring/icons-and-splash/
Update
Если вы используете версию phonegap cli-5.1.1 или выше, вам нужен новый плагин splashscreen от npm.
Здесь новый плагин на github, там вы можете найти, как его использовать:
https://github.com/apache/cordova-plugin-splashscreen
Ответ 2
Я решил проблему, добавив
<preference name="SplashScreen" value="splash" />
Это дополнительное предпочтение тем, которые генерируются при создании phonegap. Я также не могу найти хорошую документацию по этому вопросу.
Кроме того, мне не требуется заставку по умолчанию, как описано в некоторых вопросах, когда я добавляю это предпочтение
Ответ 3
После долгих исследований и попыток, наконец, это сработало для меня:
Добавьте это к вашим предпочтениям:
<preference name="SplashScreen" value="splash" />
и добавьте это перед вашей первой записью src изображения заставки:
<splash src="splash.png" />
Возможно, важно упомянуть, потому что я этого не знал:
Если вы используете онлайн-конвертер apk phonegap с включенной гидратацией для своего приложения, вам придется полностью восстановить приложение, а не просто обновлять его. Это поможет вам также с настройками, такими как "ориентация" или "полноэкранный режим"!
Ответ 4
Кордова реализует API-интерфейсы уровня устройства в качестве плагинов. Используйте команду плагина CLI, описанную в интерфейсе командной строки, чтобы добавить эту функцию для проекта: Пожалуйста, используйте следующую ссылку для получения дополнительной информации
http://docs.phonegap.com/en/3.3.0/cordova_splashscreen_splashscreen.md.html
Ответ 5
У меня была та же проблема, и я решил ее, преобразовывая изображение всплеска в .png вместо .jpg.
Ответ 6
Вы должны (как в случае необходимости) разместить splash.png
-s внутри www/res/drawable-*/splash.png
и icon.png
-s внутри www/res/drawable-*/icon.png
, чтобы иметь эту структуру в папке www
res
├── drawable-hdpi
│ └── icon.png
├── drawable-land-hdpi
│ └── splash.png
├── drawable-land-ldpi
│ └── splash.png
├── drawable-land-mdpi
│ └── splash.png
├── drawable-land-xhdpi
│ └── splash.png
├── drawable-land-xxhdpi
│ └── splash.png
├── drawable-land-xxxhdpi
│ └── splash.png
├── drawable-ldpi
│ └── icon.png
├── drawable-mdpi
│ └── icon.png
├── drawable-port-hdpi
│ └── splash.png
├── drawable-port-ldpi
│ └── splash.png
├── drawable-port-mdpi
│ └── splash.png
├── drawable-port-xhdpi
│ └── splash.png
├── drawable-port-xxhdpi
│ └── splash.png
├── drawable-port-xxxhdpi
│ └── splash.png
├── drawable-xhdpi
│ └── icon.png
├── drawable-xxhdpi
│ └── icon.png
└── drawable-xxxhdpi
└── icon.png
И ваш config.xml
должен содержать эти строки
<splash qualifier="land-hdpi" src="res/drawable-land-hdpi/splash.png" />
<splash qualifier="land-ldpi" src="res/drawable-land-ldpi/splash.png" />
<splash qualifier="land-mdpi" src="res/drawable-land-mdpi/splash.png" />
<splash qualifier="land-xhdpi" src="res/drawable-land-xhdpi/splash.png" />
<splash qualifier="land-xxhdpi" src="res/drawable-land-xxhdpi/splash.png" />
<splash qualifier="land-xxxhdpi" src="res/drawable-land-xxxhdpi/splash.png" />
<splash qualifier="port-hdpi" src="res/drawable-port-hdpi/splash.png" />
<splash qualifier="port-ldpi" src="res/drawable-port-ldpi/splash.png" />
<splash qualifier="port-mdpi" src="res/drawable-port-mdpi/splash.png" />
<splash qualifier="port-xhdpi" src="res/drawable-port-xhdpi/splash.png" />
<splash qualifier="port-xxhdpi" src="res/drawable-port-xxhdpi/splash.png" />
<splash qualifier="port-xxxhdpi" src="res/drawable-port-xxxhdpi/splash.png" />
<icon qualifier="hdpi" src="res/drawable-hdpi/icon.png" />
<icon qualifier="ldpi" src="res/drawable-ldpi/icon.png" />
<icon qualifier="mdpi" src="res/drawable-mdpi/icon.png" />
<icon qualifier="xhdpi" src="res/drawable-xhdpi/icon.png" />
<icon qualifier="xxhdpi" src="res/drawable-xxhdpi/icon.png" />
<icon qualifier="xxxhdpi" src="res/drawable-xxxhdpi/icon.png" />
Для полного изображения, вот раздел андроида моего config.xml
<platform name="android">
<allow-intent href="market:*" />
<preference name="android-minSdkVersion" value="14" />
<preference name="android-targetSdkVersion" value="22" />
<preference name="SplashScreen" value="splash" />
<preference name="SplashScreenDelay" value="3000" />
<preference name="ShowSplashScreenSpinner" value="false" />
<preference name="FadeSplashScreen" value="false" />
<preference name="SplashMaintainAspectRatio" value="true" />
<preference name="SplashShowOnlyFirstTime" value="false" />
<preference name="SplashShowOnlyFirstTime" value="false" />
<splash qualifier="land-hdpi" src="res/drawable-land-hdpi/splash.png" />
<splash qualifier="land-ldpi" src="res/drawable-land-ldpi/splash.png" />
<splash qualifier="land-mdpi" src="res/drawable-land-mdpi/splash.png" />
<splash qualifier="land-xhdpi" src="res/drawable-land-xhdpi/splash.png" />
<splash qualifier="land-xxhdpi" src="res/drawable-land-xxhdpi/splash.png" />
<splash qualifier="land-xxxhdpi" src="res/drawable-land-xxxhdpi/splash.png" />
<splash qualifier="port-hdpi" src="res/drawable-port-hdpi/splash.png" />
<splash qualifier="port-ldpi" src="res/drawable-port-ldpi/splash.png" />
<splash qualifier="port-mdpi" src="res/drawable-port-mdpi/splash.png" />
<splash qualifier="port-xhdpi" src="res/drawable-port-xhdpi/splash.png" />
<splash qualifier="port-xxhdpi" src="res/drawable-port-xxhdpi/splash.png" />
<splash qualifier="port-xxxhdpi" src="res/drawable-port-xxxhdpi/splash.png" />
<icon qualifier="hdpi" src="res/drawable-hdpi/icon.png" />
<icon qualifier="ldpi" src="res/drawable-ldpi/icon.png" />
<icon qualifier="mdpi" src="res/drawable-mdpi/icon.png" />
<icon qualifier="xhdpi" src="res/drawable-xhdpi/icon.png" />
<icon qualifier="xxhdpi" src="res/drawable-xxhdpi/icon.png" />
<icon qualifier="xxxhdpi" src="res/drawable-xxxhdpi/icon.png" />
</platform>
Теперь запустите phonegap remote build android
и откройте файл журнала из сборки phonegap.
Файл журнала находится в https://build.phonegap.com/apps/X/logs/android/build/
, где X
является вашим App ID
В журнале вы должны увидеть что-то вроде
...
[crunch] Processing image to cache: /project/res/drawable-hdpi/icon.png => /project/bin/res/drawable-hdpi/icon.png
[crunch] (processed image to cache entry /project/bin/res/drawable-hdpi/icon.png: 0% size of source)
[crunch] Processing image to cache: /project/res/drawable-land-ldpi/splash.png => /project/bin/res/drawable-land-ldpi/splash.png
...
Если вы видите эти строки, ваш экран заставки должен работать.
Также обратите внимание на эту строку в config.xml
<preference name="SplashScreen" value="splash" />
Это сообщает сборке phonegap, что ваши png файлы с заставкой называются splash.png
. Таким образом, система может их найти.
Ответ 7
В моем случае я просто добавил <preference name="ShowSplashScreenSpinner" value="false"/>
, он делает Magic.
Вот часть Android в моем файле config.xml
<platform name="android">
<allow-intent href="market:*" />
<preference name="ShowSplashScreenSpinner" value="false"/>
<splash src="res/screen/android/splash-land-hdpi.png" density="land-hdpi"/>
<splash src="res/screen/android/splash-land-hdpi.png" density="land-ldpi"/>
<splash src="res/screen/android/splash-land-hdpi.png" density="land-mdpi"/>
<splash src="res/screen/android/splash-land-hdpi.png" density="land-xhdpi"/>
<splash src="res/screen/android/splash-land-hdpi.png" density="port-hdpi"/>
<splash src="res/screen/android/splash-land-hdpi.png" density="port-ldpi"/>
<splash src="res/screen/android/splash-land-hdpi.png" density="port-mdpi"/>
<splash src="res/screen/android/splash-land-hdpi.png" density="port-xhdpi"/>
</platform>
Ответ 8
Телефонная почта регулярно обновляет свою систему сборки, поэтому вы также можете отслеживать эти изменения. До вчерашнего дня я видел всплеск на android, но не видел его сегодня (на 6.5.0), хотя я не внес никаких изменений в config.xml
После добавления следующих предпочтений к их недавно введенной версии версии построителя, он снова работает.
<preference name='phonegap-version' value='cli-6.5.0' />
<preference name='pgb-builder-version' value='2' />
builder-version 1 для старого строителя и 2 для нового, который использует кордову, как строитель.
Прочтите следующую запись в блоге pgb для более подробной информации.
https://blog.phonegap.com/phonegap-7-0-1-now-on-build-and-it-includes-some-important-changes-89087fe465f5