LoginSignup
1
0

【Android】スプラッシュ画面を簡単に実装

Last updated at Posted at 2024-01-21

スプラッシュ画面とは

アプリを起動すると現れるロゴが中央に配置されている画面です。今回はこの画面の実装を行います。

Step1. ライブラリをインストールする

まず、スプラッシュ画面を実装するためのライブラリをgradle(app)にインストールします。

build.gradle(app)
dependencies {
    implementation("androidx.core:core-splashscreen:1.0.0")
}

入力したらgradleをSyncさせてください。

Step2. 背景色を用意する

スプラッシュ画面には背景色を用意する必要があるため、color.xmlで入力します。

color.xml
<?xml version="1.0" encoding="utf-8"?>
<resources>
    <!-- 中略-->
    <color name="pink">#F48FB1</color>
</resources>

今回はかわいらしくしたいと思ってこの色にしています。

Step3. ロゴ画像を用意する

画面中央に配置されるロゴを用意します。

事前にfigmaで用意した星をandroid Studioのdrawableファイルの中に取り込みます。
figmaのリンク
PNGでも挿入できますが、画面が大きくなった時に荒くなってしまうため、今回はSVGで用意します。

SVGで取り込む方法

drawableファイルを右クリック、Newメニューの中から"Vector Asset"を選択します。

Desktop Screenshot 2024.01.21 - 11.11.50.23.png

SVGファイルが保存されている場所を指定してsize指定をしてNextをクリックします。
Desktop Screenshot 2024.01.21 - 11.14.50.31.png

生成されるxmlの場所を確認されるので特に何もなければFinishをクリックして完了です。
Desktop Screenshot 2024.01.21 - 11.17.28.93.png

追加されるxml

icon_svg.xml

<vector xmlns:android="http://schemas.android.com/apk/res/android"
    android:width="108dp"
    android:height="108dp"
    android:viewportWidth="108"
    android:viewportHeight="108">
  <path
      android:pathData="M0,0h108v108h-108z"
      android:fillColor="#F48FB1"/>
  <path
      android:strokeWidth="1"
      android:pathData="M54,19.62L61.61,43.03L61.72,43.38H62.08H86.7L66.78,57.84L66.49,58.06L66.6,58.4L74.21,81.82L54.29,67.35L54,67.13L53.71,67.35L33.79,81.82L41.4,58.4L41.51,58.06L41.22,57.84L21.3,43.38H45.92H46.28L46.39,43.03L54,19.62Z"
      android:fillColor="#ffffff"
      android:strokeColor="#ffffff"/>
</vector>

ロゴ作成時の注意

ロゴの全体の大きさは縦横それぞれ108dpにし、表示されるのは縦横72dpまでになります。大きくなりすぎないようご注意ください。
android公式サイト参照
あと、画像を直接挿入しようとするとなぜか拡大されてしまうという現象が発生する場合があります。そういう時は、layer-listのxmlを挟むとうまく描写されます。

ic_splash.xml
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:drawable="@drawable/icon_svg"/>
</layer-list>

Step4. テーマ設定

theme.xmlに先ほどのステップで用意した背景色やロゴ画像を設定します。

最初から記述されているアプリテーマは削除せずに下にスプラッシュ画面のテーマを追加します。

theme.xml
<resources xmlns:tools="http://schemas.android.com/tools">
    <!-- Base application theme. -->
    <style name="Base.Theme.SplashOpening" parent="Theme.Material3.DayNight.NoActionBar">
    </style>

    <style name="Theme.SplashOpening" parent="Base.Theme.SplashOpening" />

    <!-- ここより下を追加する -->
    <style name="Theme.App.SplashOpening" parent="Theme.SplashScreen">
        <item name="windowSplashScreenBackground">@color/pink</item>
        <item name="windowSplashScreenAnimatedIcon">@drawable/ic_splash</item>
        <item name="postSplashScreenTheme">@style/Base.Theme.SplashOpening</item>
    </style>
</resources>

Step5. マニフェストの設定

activityのところに先ほど追加したテーマを設定します。

AndroidManifest.xml
<activity
            android:name=".MainActivity"
            android:theme="@style/Theme.App.SplashOpening"
            android:exported="true">
            
</activity>

Step6. コードの実装

いよいよ大詰めです!

ここのコードはすごく簡単で、追加する行数はたったの1行です。

MainActivity.kt

 override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        // installSplashScreen()を追加
        installSplashScreen()
        setContentView(R.layout.activity_main)
    }

ここまで実装するとアプリ起動時にこのような画面が出現します。

以上でスプラッシュ画面の実装は完了です。

成果物

参考サイトなど

先輩方、ありがとうございました🙇

1
0
2

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0