android引導頁的實現 及跳轉到主頁面

第一個activity

package com.qualitypicture.activity;

import java.util.ArrayList;
import java.util.List;
import com.qualitypicture.R;
import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.os.Parcelable;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.util.DisplayMetrics;
import android.view.GestureDetector;
import android.view.KeyEvent;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.view.Window;
import android.view.GestureDetector.SimpleOnGestureListener;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.LinearLayout;

public class GuideActivity extends Activity
{
 private ViewPager viewPager;
 private List<View> mImageViews; // 滑動的圖片集合
 private int[] imageResId; // 圖片ID
 private int currentItem = 0; // 當前圖片的索引號
 private GestureDetector gestureDetector; // 用戶滑動
 /** 記錄當前分頁ID */
 private int flaggingWidth;// 互動翻頁所需滾動的長度是當前屏幕寬度的1/3

 @Override
 public void onCreate(Bundle savedInstanceState)
 {
  super.onCreate(savedInstanceState);
  requestWindowFeature(Window.FEATURE_NO_TITLE);// 去掉標題欄
  setContentView(R.layout.guide_activity);

  gestureDetector = new GestureDetector(new GuideViewTouch());

  // 獲取分辨率
  DisplayMetrics dm = new DisplayMetrics();
  getWindowManager().getDefaultDisplay().getMetrics(dm);
  flaggingWidth = dm.widthPixels / 3;
  imageResId = new int[]
  { R.drawable.pic_1, R.drawable.pic_2, R.drawable.pic_3, R.drawable.pic_4 };
  mImageViews = new ArrayList<View>();
  // 初始化圖片資源
  LayoutInflater viewInflater = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE);
  // 0
  View convertView0 = viewInflater.inflate(R.layout.guide_item, null);
  LinearLayout linearLayout0 = (LinearLayout) convertView0.findViewById(R.id.guide_item);
  linearLayout0.setBackgroundResource(imageResId[0]);
  mImageViews.add(linearLayout0);
  // 1
  View convertView1 = viewInflater.inflate(R.layout.guide_item, null);
  LinearLayout linearLayout1 = (LinearLayout) convertView1.findViewById(R.id.guide_item);
  linearLayout1.setBackgroundResource(imageResId[1]);
  mImageViews.add(linearLayout1);
  // 2
  View convertView2 = viewInflater.inflate(R.layout.guide_item, null);
  LinearLayout linearLayout2 = (LinearLayout) convertView2.findViewById(R.id.guide_item);
  linearLayout2.setBackgroundResource(imageResId[2]);
  mImageViews.add(linearLayout2);
  // 3
  View convertView3 = viewInflater.inflate(R.layout.guide_item, null);
  LinearLayout linearLayout3 = (LinearLayout) convertView3.findViewById(R.id.guide_item);
  linearLayout3.setBackgroundResource(imageResId[3]);
  mImageViews.add(linearLayout3);
  // button監聽
  Button btn = (Button) convertView3.findViewById(R.id.start);
  btn.setVisibility(View.VISIBLE);
  btn.setOnClickListener(new OnClickListener()
  {

   public void onClick(View v)
   {

    GoToMainActivity();
   }
  });

  viewPager = (ViewPager) findViewById(R.id.guide_view);
  viewPager.setAdapter(new MyAdapter());// 設置填充ViewPager頁面的適配器
  // 設置一個監聽器,當ViewPager中的頁面改變時調用
  viewPager.setOnPageChangeListener(new MyPageChangeListener());
 }

 @Override
 public boolean dispatchTouchEvent(MotionEvent event)
 {
  if (gestureDetector.onTouchEvent(event))
  {
   event.setAction(MotionEvent.ACTION_CANCEL);
  }
  return super.dispatchTouchEvent(event);
 }

 private class GuideViewTouch extends SimpleOnGestureListener
 {
  @Override
  public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY)
  {
   if (currentItem == 3)
   {
    if (Math.abs(e1.getX() - e2.getX()) > Math.abs(e1.getY() - e2.getY()) && (e1.getX() - e2.getX() <= (-flaggingWidth) || e1.getX() - e2.getX() >= flaggingWidth))
    {
     if (e1.getX() - e2.getX() >= flaggingWidth)
     {
      GoToMainActivity();
      return true;
     }
    }
   }
   return false;
  }
 }

 /**
  * 進入主界面
  */
 void GoToMainActivity()
 {
  Intent intent = new Intent(GuideActivity.this, TabHostActivity.class);
  startActivity(intent);
  finish();
 }

 /**
  * 當ViewPager中頁面的狀態發生改變時調用
  *
  * @author Administrator
  *
  */
 private class MyPageChangeListener implements OnPageChangeListener
 {
  public void onPageSelected(int position)
  {
   currentItem = position;
  }

  public void onPageScrollStateChanged(int arg0)
  {
  }

  public void onPageScrolled(int arg0, float arg1, int arg2)
  {
  }
 }

 /**
  * 填充ViewPager頁面的適配器
  *
  * @author Administrator
  *
  */
 private class MyAdapter extends PagerAdapter
 {

  @Override
  public int getCount()
  {
   return imageResId.length;
  }

  @Override
  public Object instantiateItem(View arg0, int arg1)
  {
   ((ViewPager) arg0).addView(mImageViews.get(arg1));
   return mImageViews.get(arg1);
  }

  @Override
  public void destroyItem(View arg0, int arg1, Object arg2)
  {
   ((ViewPager) arg0).removeView((View) arg2);
  }

  @Override
  public boolean isViewFromObject(View arg0, Object arg1)
  {
   return arg0 == arg1;
  }

  @Override
  public void restoreState(Parcelable arg0, ClassLoader arg1)
  {
  }

  @Override
  public Parcelable saveState()
  {
   return null;
  }

  @Override
  public void startUpdate(View arg0)
  {

  }

  @Override
  public void finishUpdate(View arg0)
  {

  }
 }

 @Override
 public boolean onKeyDown(int keyCode, KeyEvent event)
 {
  // TODO Auto-generated method stub
  if (keyCode == KeyEvent.KEYCODE_BACK)
  {
   GoToMainActivity();
   return false;
  }
  return super.onKeyDown(keyCode, event);
 }

}

佈局文件

第一個

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent" >

    <android.support.v4.view.ViewPager
        android:id="@+id/guide_view"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent" />

</LinearLayout>

第二個

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/guide_item"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <TextView
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_weight="5" />

    <Button
        android:id="@+id/start"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:background="#00000000"
        android:text="@string/butTxt"
        android:textColor="#00000000"
        android:visibility="gone" >
    </Button>

    <TextView
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_weight="1" />

</LinearLayout>

大家用的時候文件名要寫對,好友圖片也要相應的放到文件中去!

希望對大家有所幫助!

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章