第一个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>

大家用的时候文件名要写对,好友图片也要相应的放到文件中去!

希望对大家有所帮助!

android引导页的实现 及跳转到主页面的更多相关文章

  1. viewpager在最后一页滑动之后,跳转到主页面

    [TOC] viewpager在最后一页滑动之后,跳转到主页面 思路 主要有是两个监听, 一是addOnPageChangeListener();二是setOnTouchListener(): add ...

  2. silverlight 退出当前页面、跳转到主页面

    1.退出当前页面 private void imgExit_MouseLeftButtonUp(object sender, MouseButtonEventArgs e) { if (Message ...

  3. Android 引导页公共方法LeaderPager

    SimpAndroidFarme是近期脑子突然发热想做的android快速开发的框架,目标是模块化 常用的控件,方便新手学习和使用.也欢迎老鸟来一起充实项目:项目地址 引导页是我们开发app很常用的功 ...

  4. Android引导页设计

    大家在安装好一个应用后,第一次打开时往往会出现一个使用引导页,形式一般为三.四张图片,随着我们的滑动进行切换,在最后一页会有一个进入应用的按钮,我们通过点击这个按钮可以进入应用,其实这其中没有太多的复 ...

  5. Xamarin.Android 引导页

    http://blog.csdn.net/qq1326702940/article/details/78665588 https://www.cnblogs.com/catcher1994/p/555 ...

  6. Android引导页过多导致OOM内存泄漏

    摘要:前几天推广我们APP的时候,有些手机加载引导页的时候会闪退或崩溃,在Bugly显示是OOM异常.    然后Bugly上面显示的解决方案是: 该异常表示未能成功分配字节内存,通常是因为内存不足导 ...

  7. 解决:spring security 登录页停留时间过长 跳转至 403页面

    前言:最近的项目中用到了spring security组件,说句显low的话:我刚开始都不知道用了security好不勒,提了bug,在改的过程中,遇到了一些问题,找同事交流,才知道是用的securi ...

  8. Android 引导页的代码

    布局代码 <android.support.v4.view.ViewPager android:id="@+id/viewpage" android:layout_width ...

  9. Android引导页

    源码地址:https://github.com/myloften/IntroSliderSample 博客地址:http://blog.csdn.net/loften_93663469/article ...

随机推荐

  1. 在ASP.NET应用中执行后台任务

    在ASP.NET应用中执行后台任务 昨天下午,在微软的MVP 2015社区大讲堂上给大家分享了一个题目:在ASP.NET应用中执行后台任务.这是一点都不高大上,并且还有点土气的技术分享.不过我相信很多 ...

  2. AngularJs + ASP.NET MVC

    [AngularJs + ASP.NET MVC]使用AntularJs快速建立ASP.NET MVC SPA網站 這幾天接觸到了AngularJs的美麗,讓饅頭有點躍躍欲試使用AngularJs來做 ...

  3. SQL点滴30—SQL中常用的函数

    原文:SQL点滴30-SQL中常用的函数 该文章转载自http://www.cnblogs.com/jiajiayuan/archive/2011/06/16/2082488.html 别人的总结,很 ...

  4. java查找反复类/jar包/普通文件

    开发web应用时,有时更新了类却没有生效,事实上是由于jboss/tomcat中其它公布包下有同名类(包含全路径都同样). 于是萌发了做个程序来检查指定文件夹是否存在反复类(通过asm从类文件里取类的 ...

  5. 使用Vim或Codeblocks格式化代码

    在网上的代码,有很多的代码都是丢失缩进的,几行还好,手动改改,多了呢,不敢想象,没有缩进的代码.别说排错,就是阅读都是困难的,还好,有两个常用工具可以轻松的解决问题. (一)Vim(简单方便,可将代码 ...

  6. WEB浏览器与服务器通讯过程

    以访问网页www.baidu.com为例,下面是使用Wireshark捕捉到的数据: 浏览器先发起一个TCP连接,然后发送GET报文给服务器,服务器之后返回一个Response报文. 从服务器端返回时 ...

  7. 深入浅出SQL Server 2008 分区函数和分区表

    原文:深入浅出SQL Server 2008 分区函数和分区表 当我们数据量比较大的时候,我们需要将大型表拆分为多个较小的表,则只访问部门数据的查询就可以更快的运行,基本原理就是,因为要扫描的数据变的 ...

  8. 33、Python.Unix和Linux系统管理指南.(美)基弗特

  9. 用C++进行简单的文件I/O操作-转自VC知识库

    原文请见 http://www.vckbase.com/index.php/wv/1158 序论 我曾发表过文件输入输出的文章,现在觉得有必要再写一点.文件 I/O 在C++中比烤蛋糕简单多了. 在这 ...

  10. 依赖注入和IOC

    http://www.bbsmvc.com/archiver/csharp/thread-831-1.html 本来想使用一下Ninject的,然后搜索了很久,都没找到比较详细的关于Ninject的使 ...