Skip to main content

Right Way to create Splash Screen in Android

In this tutorial, we will learn how to create splash screen without creating splash screen activity. Splash Screen is the screen which you show before the start of the application. What happen some time your application have lots of coding stuff on your main activity and its take lots of time in loading the all these stuff like inflating your layout, downloading bitmap, music and other program logic, which create bad user experience to user because user see black screen until your application not finish with all coding stuff. So in this scenario Splash Screen is very useful where you show custom graphics to end user and create better user experience.

Initially, I have done lots stuff about creating splash screen by starting a light activity before main activity and putting some sleep inside that activity and then start the main activity, but I don't think that is the best way create a splash screen. Because in this case you are creating an activity just to show a graphics before your application start and user have to wait for few second whether they required or not. For example one device with more advance hardware that can load the all stuff within two seconds but still user has to wait for 10 sec because you have put 10-second sleep in your splash screen activity.

Finally, after doing lots of stuff, I saw a video of google to show the splash screen in right way and then I have implemented that and found yes this is the right way create the splash screen.

What we will do in this we create the custom theme and put our graphics inside that theme and set that theme for our main activity inside our AndroidManifest.xml file and in our main activity we change the theme just before the start of our main activity.

Please note I was showing you this example inside the app which we have created in our last post, you can refer it if you have not gone through the last tutorial.

Create drawable for splash screen

Right click on the drawable folder and select new and then drawable resource file and put the following code inside your resource file. You may need to change the logo name in your resource file or can download the logo from GitHub source code of this example,  link given at the end of this page.

 <?xml version="1.0" encoding="utf-8"?>  
<layer-list xmlns:android=""

Create a customer Theme inside your style.xml file and set the above drawable as the background of the theme.
 <style name="AppTheme.Launcher">  
<item name="android:windowBackground">@drawable/splash</item>

Modify your AndroidManifest.xml and set the AppThem.Launcher as your main activity theme.
 <activity android:name=".MainActivity"  
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />

We can run and test our application but you will get the same theme all over your activity which was not good. So for that we have to set our actually theme inside our activity. So open the file and below line before you super.onCreate method called.

We are all set to test you similar to screen shots are given below.

Right Way to Create Splash Screen in androidRight Way to create Splash Screen

You can download the source code from GitHub project page here.


Popular posts from this blog

Flutter How to Start Android Activity from Flutter View

Flutter and Dart is an excellent combination for creating the UI, but for accessing the platform-specific service we need to open platform-specific activity. So lets in this article we will explore how to start an android activity and access the service from Flutter View. Create a Project for this Android Activity Flutter View Demo Create a Project From File menu select the New Flutter Project Enter the project name Select the AndroidX support and click on next After the above, we step click on Finish We will have the following project structure created. Create the Second Activity in Android Just go to the android folder and open it in separate windows. We will have the following project structure. Create the Activity Just right-click on the Kotlin folder and create a blank activity from the menu. If you create the activity then you may be required to upgrade the Gradle and do some import. So Just click on update and wait for the project s

WordPress Android App with REST API And Retrofit

Retrofit is the library which converts your JSON data into Java object. In this tutorial, we will learn about how to implement the Retrofit to create a WordPress Mobile App. As we all know, WordPress is the one of the biggest CMS (Content Management System) of the world. Wordpress full fill the requirements for all most every type of the website. So, in this tutorial, I am going to learn how to create an Android App using the WordPress REST API and Retrofit. What is Retrofit? If you want to know about Retrofit, I would like to give you just a simple one-line explanation of the Retrofit. It is a library which converts your REST HTTP request to Java interface. We will learn how we can do all these stuff using some very simple steps. Further, you can check the Retrofit Library here . So, In this tutorial, we will use the Retrofit to retrieve all post and there except ( A short Description of Post) form a WordPress website. Prerequisite for using the Retrofit for WordPress Android App Ther

How to Read and Write JSON data in Kotlin with GSON

Kotlin is now official language for Android development and it is well supported in Android Studio. So here in this tutorial, we are going to learn about how to read and write JSON data in Kotlin using GSON. If you would like to learn the java version of this tutorial check out the last tutorial " How to Read and Write JSON data using GSON ". Introduction In this tutorial, we will write two methods. In the first method, we will create a JSON file and in second method we will read the file and print in a text box.  If you like to know more about the basic entity of JSON you can check out Basic JSON entity here . What is JSON? JSON stands for J ava S cript O bject N otation JSON is a lightweight data-interchange format It is "self-describing" and easy to understand JSON is language independent and can we used in any language JSON Syntax Rules Data is in name/value pairs Data is separated by commas Curly braces hold objects Square brackets hold