andriod一個不錯的啟動菜單顯示屏動畫效果

ptjs 12年前發布 | 876 次閱讀 Ceph UI ThinkCMFX
效果圖:

看到一個老外做的不錯的android啟動菜單的動畫效果,小結下。 
1 首先在drawable目錄下放一些動畫要用的圖片。
2 splash.xml:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:id="@+id/TheSplashLayout"
  android:layout_gravity="center"
  >
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/SplashImageView"
android:layout_gravity="center"      
>
</ImageView>

  3 點啟動窗口動畫效果后顯示的main.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"
    />
<TextView
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="@string/hello"
    />
</LinearLayout>

  

3 SplashScreen.java
這里是歡迎啟動類的核心部分
public class SplashScreen extends Activity {
   /**
     * The thread to process splash screen events
     */
    private Thread mSplashThread;       /** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);    // Splash screen view
    setContentView(R.layout.splash);
      
        // Start animating the image
    final ImageView splashImageView = (ImageView) findViewById(R.id.SplashImageView);
    splashImageView.setBackgroundResource(R.drawable.flag);
    final AnimationDrawable frameAnimation = (AnimationDrawable)splashImageView.getBackground();
    splashImageView.post(new Runnable(){ public void run() {
frameAnimation.start();       
}           
    });
          
      
    final SplashScreen sPlashScreen = this;  
      
    // The thread to wait for splash screen events
    mSplashThread =  new Thread(){
    @Override
    public void run(){
    try {
    synchronized(this){
    // Wait given period of time or exit on touch
    wait(5000);
    }
    }
    catch(InterruptedException ex){   
    }finish();
      
    // Run next activity
    Intent intent = new Intent();
    intent.setClass(sPlashScreen, MainActivity.class);
    startActivity(intent);
    stop();    
    }
    };
      
    mSplashThread.start();
      
}@Override
public boolean onCreateOptionsMenu(Menu menu){
super.onCreateOptionsMenu(menu);
return false;
}
    
    /**
     * Processes splash screen touch events
     */
    @Override
    public boolean onTouchEvent(MotionEvent evt)
    {
    if(evt.getAction() == MotionEvent.ACTION_DOWN)
    {
    synchronized(mSplashThread){
    mSplashThread.notifyAll();
    }
    }
    return true;
    }

 4 為了更好看,在values 目錄下添加樣式文件styles.xml: 

<resources>
<style name="Animations" parent="@android:Animation" />
<style name="Animations.SplashScreen">
        <item name="android:windowEnterAnimation">@anim/appear</item>
        <item name="android:windowExitAnimation">@anim/disappear</item>
    </style>
<style name="Theme.Transparent" parent="android:Theme">
<item name="android:windowIsTranslucent">true</item>
<item name="android:windowBackground">@android:color/transparent</item>
<item name="android:windowContentOverlay">@null</item>
<item name="android:windowNoTitle">true</item>
<item name="android:windowIsFloating">true</item>
<item name="android:backgroundDimEnabled">false</item>
<item name="android:windowAnimationStyle">@style/Animations.SplashScreen</item>       
</style>       
</resources>

 注意下這里:

<style name="Animations" parent="@android:Animation" />
<style name="Animations.SplashScreen">
        <item name="android:windowEnterAnimation">@anim/appear</item>
        <item name="android:windowExitAnimation">@anim/disappear</item>
    </style>

  源碼下載:http://files.cnblogs.com/feifei1010/AdvancedSplashDemo.zip

歡迎關注微博:http://e.weibo.com/u/2975543812

 本文由用戶 ptjs 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!