A splash screen is an image with animation effects that appears while a game or program is loading. It may also be used to describe an introduction of App or page on a website.
So today we will learn how to create a splash screen in Android so that our app will start with Splash screen and then load Home Screen.
in this example i have defined 5 seconds delay to load home screen you may modify as your need.
so lets try this small app..
My Project structure is look like
-------------------------------------------
App Name: SplashScreenBasic
Package Name: com.rdc
Android SDK: Android SDK 2.3.3 / API 10
Default Activity Name: ActivitySplashScreen
-------------------------------------------
ActivitySplashScreen.java
ActivityHomeScreen.java
create below two xml files in res/layout folder
splash_screen.xml
home_screen.xml
create a drawable folder in resource and put these file for fad animation
splash_fade_in.xml
splash_fade_out.xml
and you AndroidManifest.xml file will be like this.
The app will start like this..
You can download the complete source code zip file here : SplashScreenBasic
cheers!!
I'd love to hear your thoughts!
So today we will learn how to create a splash screen in Android so that our app will start with Splash screen and then load Home Screen.
in this example i have defined 5 seconds delay to load home screen you may modify as your need.
so lets try this small app..
My Project structure is look like
-------------------------------------------
App Name: SplashScreenBasic
Package Name: com.rdc
Android SDK: Android SDK 2.3.3 / API 10
Default Activity Name: ActivitySplashScreen
-------------------------------------------
ActivitySplashScreen.java
package com.rdc; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.os.Handler; import android.view.KeyEvent; import android.view.Window; import android.view.WindowManager; public class ActivitySplashScreen extends Activity { // set splash duration 3 seconds private final int SPLASH_DISPLAY_LENGTH = 3000; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // hide the notification bar title on screen requestWindowFeature(Window.FEATURE_NO_TITLE); // make full screen view getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN); setContentView(R.layout.splash_screen); // create a thread for splash new Handler().postDelayed(new Runnable() { @Override public void run() { Intent i = new Intent(ActivitySplashScreen.this, ActivityHomeScreen.class); startActivity(i); finish(); overridePendingTransition(R.drawable.splash_fade_in, R.drawable.splash_fade_out); } }, SPLASH_DISPLAY_LENGTH); } // disable home button during splash screen @Override public void onAttachedToWindow() { this.getWindow().setType( WindowManager.LayoutParams.TYPE_KEYGUARD_DIALOG); super.onAttachedToWindow(); } // disable back button during splash screen @Override public boolean onKeyDown(int keyCode, KeyEvent event) { return false; } }
ActivityHomeScreen.java
package com.rdc; import android.app.Activity; import android.os.Bundle; public class ActivityHomeScreen extends Activity { @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.home_screen); } }
create below two xml files in res/layout folder
splash_screen.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" android:gravity="center"> <ImageView android:layout_height="fill_parent" android:layout_width="fill_parent" android:id="@+id/splash_image" android:src="@drawable/splashscreen"></ImageView> </LinearLayout>
home_screen.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent" android:gravity="center"> <TextView android:layout_width="wrap_content" android:id="@+id/textView1" android:layout_height="wrap_content" android:text="@string/homeTitle" android:textSize="25sp"></TextView> </LinearLayout>
create a drawable folder in resource and put these file for fad animation
splash_fade_in.xml
<alpha xmlns:android="http://schemas.android.com/apk/res/android" android:interpolator="@android:anim/decelerate_interpolator" android:zAdjustment="top" android:fromAlpha="0.0" android:toAlpha="1.0" android:duration="2000" />
splash_fade_out.xml
<alpha xmlns:android="http://schemas.android.com/apk/res/android" android:interpolator="@android:anim/accelerate_interpolator" android:fromAlpha="1.0" android:toAlpha="0.0" android:duration="3000" />
and you AndroidManifest.xml file will be like this.
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.rdc" android:versionCode="1" android:versionName="1.0"> <uses-sdk android:minSdkVersion="10" /> <application android:icon="@drawable/icon" android:label="@string/app_name"> <activity android:name=".ActivitySplashScreen" android:screenOrientation="nosensor" android:configChanges="keyboardHidden|orientation" android:theme="@android:style/Theme.Black.NoTitleBar.Fullscreen" android:label="@string/app_name"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <activity android:name=".ActivityHomeScreen" android:label="Home Screen"> <intent-filter> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> </application> </manifest>
The app will start like this..
You can download the complete source code zip file here : SplashScreenBasic
cheers!!
I'd love to hear your thoughts!
No comments:
Post a Comment