この質問は過去に尋ねられましたが、私が見つけた答えのどれも私のために問題を解決していません。
私はスプラッシュスクリーンを表示し、準備ができたらアナウンスする非常にシンプルな電話ギャップアプリを作成しようとしています。スプラッシュスクリーンの使用方法を理解するための単なるテストアプリです。
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="http://phonegap.com">
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>
デフォルトのスプラッシュタグがありません
<splash src="splash.png" />
それはドキュメントにあります: http://docs.phonegap.com/phonegap-build/configuring/icons-and-splash/
Phonegapバージョンcli-5.1.1以降を使用している場合は、npmからの新しいスプラッシュスクリーンプラグインが必要です。
Githubの新しいプラグインは次のとおりです。使用方法を確認できます。
追加して問題を解決しました
<preference name="SplashScreen" value="splash" />
これは、phonegap createの使用時に生成される設定の追加設定です。また、これに関する適切なドキュメントも見つかりません。
さらに、この設定を追加するときにいくつかの質問で説明されているように、デフォルトのスプラッシュスクリーンは必要ありません
多くのことを研究して試した後、ようやくこれがうまくいきました:
これを好みに追加してください:
<preference name="SplashScreen" value="splash" />
これを最初のスプラッシュ画像のsrcエントリの前に追加します。
<splash src="splash.png" />
私はそれを知らなかったので、おそらく言及することが重要です:
アプリケーションでハイドレーションが有効になっているオンラインPhoneGap APKコンバーターを使用する場合、アプリを更新するだけでなく、アプリを完全に再構築する必要があります。これは、「向き」や「フルスクリーン」などの設定にも役立ちます。
(必要に応じて)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" />
全体像については、ここにAndroid私の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" />
これは、スプラッシュスクリーンpngファイルの名前がsplash.png
であることをphonegapビルドに伝えます。このようにして、システムはそれらを見つけることができます。
同じ問題があり、スプラッシュ画像を。jpgではなく。pngに変換することで解決しました。
Cordovaは、デバイスレベルのAPIをプラグインとして実装します。コマンドラインインターフェイスで説明されているCLIのプラグインコマンドを使用して、プロジェクトにこの機能を追加します。詳細については、次のリンクを使用してください
http://docs.phonegap.com/en/3.3.0/cordova_splashscreen_splashscreen.md.html
私の場合、追加したのは<preference name="ShowSplashScreenSpinner" value="false"/>
マジックを行います。
ここにAndroid部分があります
<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>
Phonegapはビルドシステムを定期的に更新するため、これらの変更を追跡することもできます。昨日まで、Android=でスプラッシュが表示されていましたが、config.xmlに変更を加えていなかったにもかかわらず、今日(6.5.0)で動作していませんでした。
最近導入されたビルダーのバージョン設定に以下の設定を追加すると、再び機能します。
<preference name='phonegap-version' value='cli-6.5.0' />
<preference name='pgb-builder-version' value='2' />
古いビルダーにはビルダーバージョン1、ビルダーのようにコルドバを使用する新しいバージョン2。
詳細については、次のpgbブログ投稿を参照してください。
不満が多かった後、ありがたいことに、さまざまな提案があった this thread を見つけました。
Config.xmlファイルのスプラッシュ要素のdensity
属性をqualifier
に変更するだけで、この問題は修正されました。役立つ場合に備えて、プラグイン宣言を含めています。
<plugin name="cordova-plugin-splashscreen" spec="~5.0.2" />
<platform name="Android">
<icon qualifier="ldpi" src="www/res/icon/Android/drawable-ldpi-icon.png" />
<icon qualifier="mdpi" src="www/res/icon/Android/drawable-mdpi-icon.png" />
<icon qualifier="hdpi" src="www/res/icon/Android/drawable-hdpi-icon.png" />
<icon qualifier="xhdpi" src="www/res/icon/Android/drawable-xhdpi-icon.png" />
<icon qualifier="xxhdpi" src="www/res/icon/Android/drawable-xxhdpi-icon.png" />
<icon qualifier="xxxhdpi" src="www/res/icon/Android/drawable-xxxhdpi-icon.png" />
<splash qualifier="land-ldpi" src="www/res/screen/Android/drawable-land-ldpi-screen.png" />
<splash qualifier="land-mdpi" src="www/res/screen/Android/drawable-land-mdpi-screen.png" />
<splash qualifier="land-hdpi" src="www/res/screen/Android/drawable-land-hdpi-screen.png" />
<splash qualifier="land-xhdpi" src="www/res/screen/Android/drawable-land-xhdpi-screen.png" />
<splash qualifier="land-xxhdpi" src="www/res/screen/Android/drawable-land-xxhdpi-screen.png" />
<splash qualifier="land-xxxhdpi" src="www/res/screen/Android/drawable-land-xxxhdpi-screen.png" />
<splash qualifier="port-ldpi" src="www/res/screen/Android/drawable-port-ldpi-screen.png" />
<splash qualifier="port-mdpi" src="www/res/screen/Android/drawable-port-mdpi-screen.png" />
<splash qualifier="port-hdpi" src="www/res/screen/Android/drawable-port-hdpi-screen.png" />
<splash qualifier="port-xhdpi" src="www/res/screen/Android/drawable-port-xhdpi-screen.png" />
<splash qualifier="port-xxhdpi" src="www/res/screen/Android/drawable-port-xxhdpi-screen.png" />
<splash qualifier="port-xxxhdpi" src="www/res/screen/Android/drawable-port-xxxhdpi-screen.png" />
</platform>