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

Flutter State Management With Provider and ChangeNotifier

Flutter state management with provider library and why it's so important? There are lots of topics in flutter which are very important but out of those state management of your flutter application is the most important and little bit complicated as well. So in this article, I will try to explain how to use the provider package for managing the state of flutter and dart application and how to access the data down the hierarchy of the widget tree without recreating the whole UI. Basic knowledge of the state management and data flow in the Flutter Before starting the coding I would like to explain some basics about the Flutter application so that you can understand, why it's important to manage the state of your application in the correct way. In Flutter, everything is a widget and whenever the state of your application changes the UI is recreated the UI with the new data. Let's list out the topic or problem that we are going to explore about state management. Challenge o