android 引导界面的实现 .

文章出处:http://blog.csdn.net/djy1992/article/details/9020831

现在越来越多程序都有引导页面了。

网上资料不全。现在自己实现下。

下图是总的目录结构。

/**
 * 实现
 * @author dujinyang
 *
 */



顺序是: OneAcitivity  -->MainActivity -> TwoActivity

然后第2次进去就是:OneActivity -> TwoActivity

代码里都有注释的了,这里就不多说了。



OneActivity的代码如下:

  1. package cn.djy.activity;  
  2.   
  3. import android.app.Activity;  
  4. import android.content.Context;  
  5. import android.content.Intent;  
  6. import android.os.Bundle;  
  7. import android.os.Handler;  
  8.   
  9. /** 
  10.  * 开机动画 
  11.  * @author Administrator 
  12.  * 
  13.  */  
  14. public class OneActivity extends Activity {  
  15.   
  16.     @Override  
  17.     protected void onCreate(Bundle savedInstanceState) {  
  18.         // TODO Auto-generated method stub   
  19.         super.onCreate(savedInstanceState);  
  20.         setContentView(R.layout.one);  
  21.           
  22.         boolean flag=this.isFirstEnter(getApplicationContext(), this.getClass().getName());  
  23.         if(flag)  
  24.             mHandler.sendEmptyMessageDelayed(SWITCH_GUIDACTIVITY,4000);  
  25.         else  
  26.             mHandler.sendEmptyMessageDelayed(SWITCH_TWOACTIVITY, 4000);  
  27.           
  28.     }  
  29.   
  30.     //***********************************************************************   
  31.     //判断应用是否初次加载,读取SharedPreferences 的字段   
  32.     //***********************************************************************   
  33.     private static final String SHAREDPREFERENCES_NAME="yang";  
  34.     private static final String KEY_GUIDE_ACTIVITY="Open";  
  35.     /**  
  36.      * mResultStr.equalsIgnoreCase("false") 返回FALSE  
  37.      * TRUE 则为空值  
  38.      * @param context  
  39.      * @param className  
  40.      * @return boolean  
  41.      */  
  42.     private boolean isFirstEnter(Context context,String className){  
  43.         if(context==null || className ==null || "".equalsIgnoreCase(className)) return false;  
  44.         String mResultStr=context.getSharedPreferences(SHAREDPREFERENCES_NAME,Context.MODE_WORLD_READABLE).getString(KEY_GUIDE_ACTIVITY, "");  
  45.         if(mResultStr.equalsIgnoreCase("false"))  
  46.             return false;  
  47.         else  
  48.             return true;  
  49.     }  
  50.       
  51.       
  52.     //****************************************   
  53.     //Handler:跳转至不同页面   
  54.     //****************************************   
  55.     private final static int SWITCH_TWOACTIVITY=1000//主页   
  56.       
  57.     private final static int SWITCH_GUIDACTIVITY=1001//滑动手势   
  58.     private Handler mHandler=new Handler(){  
  59.         public void handleMessage(android.os.Message msg) {  
  60.             switch (msg.what) {  
  61.             case SWITCH_TWOACTIVITY:  
  62.                     Intent intent=new Intent();  
  63.                     intent.setClass(OneActivity.this,TwoActivity.class);  
  64.                     OneActivity.this.startActivity(intent);  
  65.                 //  OneActivity.this.finish();   
  66.                 break;  
  67.             case SWITCH_GUIDACTIVITY:  
  68.                     Intent intents=new Intent();  
  69.                     intents.setClass(OneActivity.this,MainActivity.class);  
  70.                     OneActivity.this.startActivity(intents);  
  71.                 //  OneActivity.this.finish();   
  72.                     break;  
  73.             }  
  74.             super.handleMessage(msg);  
  75.         };  
  76.     };  
  77.       
  78. }  
package cn.djy.activity;

import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.os.Handler;

/**
 * 开机动画
 * @author Administrator
 *
 */
public class OneActivity extends Activity {

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		// TODO Auto-generated method stub
		super.onCreate(savedInstanceState);
		setContentView(R.layout.one);
		
		boolean flag=this.isFirstEnter(getApplicationContext(), this.getClass().getName());
		if(flag)
			mHandler.sendEmptyMessageDelayed(SWITCH_GUIDACTIVITY,4000);
		else
			mHandler.sendEmptyMessageDelayed(SWITCH_TWOACTIVITY, 4000);
		
	}

	//***********************************************************************
	//判断应用是否初次加载,读取SharedPreferences 的字段
	//***********************************************************************
	private static final String SHAREDPREFERENCES_NAME="yang";
	private static final String KEY_GUIDE_ACTIVITY="Open";
	/**
	 * mResultStr.equalsIgnoreCase("false") 返回FALSE
	 * TRUE 则为空值
	 * @param context
	 * @param className
	 * @return boolean
	 */
	private boolean isFirstEnter(Context context,String className){
		if(context==null || className ==null || "".equalsIgnoreCase(className)) return false;
		String mResultStr=context.getSharedPreferences(SHAREDPREFERENCES_NAME,Context.MODE_WORLD_READABLE).getString(KEY_GUIDE_ACTIVITY, "");
		if(mResultStr.equalsIgnoreCase("false"))
			return false;
		else
			return true;
	}
	
	
	//****************************************
	//Handler:跳转至不同页面
	//****************************************
	private final static int SWITCH_TWOACTIVITY=1000; //主页
	
	private final static int SWITCH_GUIDACTIVITY=1001; //滑动手势
	private Handler mHandler=new Handler(){
		public void handleMessage(android.os.Message msg) {
			switch (msg.what) {
			case SWITCH_TWOACTIVITY:
					Intent intent=new Intent();
					intent.setClass(OneActivity.this,TwoActivity.class);
					OneActivity.this.startActivity(intent);
				//	OneActivity.this.finish();
				break;
			case SWITCH_GUIDACTIVITY:
					Intent intents=new Intent();
					intents.setClass(OneActivity.this,MainActivity.class);
					OneActivity.this.startActivity(intents);
				//	OneActivity.this.finish();
					break;
			}
			super.handleMessage(msg);
		};
	};
	
}


MainActivity的代码如下:

  1. package cn.djy.activity;  
  2.   
  3. import java.util.ArrayList;  
  4.   
  5. import android.app.Activity;  
  6. import android.content.Intent;  
  7. import android.content.SharedPreferences;  
  8. import android.os.Bundle;  
  9. import android.os.Parcelable;  
  10. import android.support.v4.view.PagerAdapter;  
  11. import android.support.v4.view.ViewPager;  
  12. import android.support.v4.view.ViewPager.OnPageChangeListener;  
  13. import android.view.LayoutInflater;  
  14. import android.view.View;  
  15. import android.view.View.OnClickListener;  
  16. import android.view.ViewGroup;  
  17. import android.view.ViewGroup.LayoutParams;  
  18. import android.widget.Button;  
  19. import android.widget.ImageView;  
  20. import android.widget.TwoLineListItem;  
  21. /** 
  22.  * 实现 
  23.  * @author dujinyang 
  24.  * 
  25.  */  
  26. public class MainActivity extends Activity {  
  27.       
  28.     private ViewPager _viewpager;  
  29.       
  30.     /** 
  31.      * 分页显示的View数组 
  32.      */  
  33.     private ArrayList<View> _pagerlist;  
  34.     private ImageView image;  
  35.       
  36.     /** 
  37.      * 小圆点的图片 放进数组 
  38.      */  
  39.     private ImageView[] _imageViews;  
  40.       
  41.     //包裹滑动的图片Linearlayout   
  42.     private ViewGroup _group;  
  43.       
  44.     //包裹小圆点的Linearlayout   
  45.     private ViewGroup _viewPonits;  
  46.       
  47.       
  48.       
  49.       
  50.     /** Called when the activity is first created. */  
  51.     @Override  
  52.     public void onCreate(Bundle savedInstanceState) {  
  53.         super.onCreate(savedInstanceState);  
  54.         setContentView(R.layout.start);  
  55.           
  56.         LayoutInflater inflater=getLayoutInflater();  
  57.         _pagerlist =new ArrayList<View>();  
  58.         _pagerlist.add(inflater.inflate(R.layout.viewpager_page1,null));  
  59.         _pagerlist.add(inflater.inflate(R.layout.viewpager_page2,null));  
  60.           
  61.         //创建Imageviews数组,大小是要显示的图片数量   
  62.         _imageViews =new ImageView[_pagerlist.size()];  
  63.           
  64.           
  65.           
  66. //        ViewGroup    
  67.         _group =(ViewGroup) inflater.inflate(R.layout.start, null);//加载MAIN.XML   
  68.           
  69.         _viewPonits=(ViewGroup) _group.findViewById(R.id.icon_circle);//加载小圆点的图片   
  70.           
  71.         _viewpager =(ViewPager) _group.findViewById(R.id.guidePages);//android.support.v4.view.ViewPager   
  72.           
  73.           
  74.         //添加小圆点的图片   
  75.         for (int i = 0; i < _imageViews.length; i++) {  
  76.              image= new ImageView(this);  
  77.              //设置小圆点的imageview的参数   
  78.              image.setLayoutParams(new LayoutParams(20,20));//宽高均为20   
  79.              image.setPadding(200200);  
  80.              _imageViews[i]=image;  
  81.                
  82.              //第一张是选中状态   
  83.              if(i==0){  
  84.                  _imageViews[i].setBackgroundResource(R.drawable.a2a);  
  85.              }else{  
  86.                  _imageViews[i].setBackgroundResource(R.drawable.a1a);  
  87.              }  
  88.              _viewPonits.addView(_imageViews[i]);  
  89.         }  
  90.         //显示视图   
  91.         setContentView(_group);  
  92.         _viewpager.setAdapter(new GuidePageAdapter());  
  93.         _viewpager.setOnPageChangeListener(new GuidePageChangeListener());  
  94.     }  
  95.       
  96.       
  97.     void setGuided(){  
  98.         SharedPreferences shared=getSharedPreferences("yang",0);  
  99.         SharedPreferences.Editor editor=shared.edit();  
  100.         editor.putString("Open""false");  
  101.         editor.commit();  
  102.     }  
  103.       
  104.     class GuidePageAdapter extends PagerAdapter{  
  105.   
  106.         @Override  
  107.         public int getCount() {  
  108.             return _pagerlist.size();  
  109.         }  
  110.           
  111.         //initalization position page   
  112.         @Override  
  113.         public Object instantiateItem(View container, int position) {  
  114.             ((ViewPager)container).addView(_pagerlist.get(position));  
  115.             if(position==1){  
  116.                 Button bt=(Button) container.findViewById(R.id.bt_close);  
  117.                 bt.setOnClickListener(new OnClickListener() {  
  118.                     @Override  
  119.                     public void onClick(View v) {  
  120.                         //设置已经引导   
  121.                         setGuided();  
  122.                         //Intent    
  123.                         Intent intent=new Intent();  
  124.                         intent.setClass(MainActivity.this,TwoActivity.class );  
  125.                         MainActivity.this.startActivity(intent);  
  126.                         MainActivity.this.finish();  
  127.                     }  
  128.                 });  
  129.                   
  130.             }  
  131.             return _pagerlist.get(position);  
  132.         }  
  133.           
  134.           
  135.         //判断是否由对象生成页面   
  136.         @Override  
  137.         public boolean isViewFromObject(View view, Object obj) {  
  138.             return view==obj;  
  139.         }  
  140.           
  141.         //销毁页面的位置   
  142.         @Override  
  143.         public void destroyItem(View container, int position, Object object) {  
  144.             ((ViewPager)container).removeView(_pagerlist.get(position));  
  145.         }  
  146.           
  147.           
  148.         @Override  
  149.         public void finishUpdate(View container) {  
  150.             //finish   
  151.         }  
  152.           
  153.         @Override  
  154.         public void startUpdate(View container) {  
  155.             //start   
  156.         }  
  157.           
  158.         @Override  
  159.         public int getItemPosition(Object object) {  
  160.             //getItemPosition   
  161.             return super.getItemPosition(object);  
  162.         }  
  163.           
  164.           
  165.         @Override  
  166.         public void restoreState(Parcelable state, ClassLoader loader) {  
  167.             super.restoreState(state, loader);  
  168.             //restore   
  169.         }  
  170.           
  171.         @Override  
  172.         public Parcelable saveState() {  
  173.             return super.saveState();  
  174.             //save   
  175.         }  
  176.     }  
  177.       
  178.     class GuidePageChangeListener implements OnPageChangeListener{  
  179.   
  180.         @Override  
  181.         public void onPageScrollStateChanged(int arg0) {  
  182.               
  183.         }  
  184.   
  185.         @Override  
  186.         public void onPageScrolled(int arg0, float arg1, int arg2) {  
  187.               
  188.         }  
  189.   
  190.         @Override  
  191.         public void onPageSelected(int position) {  
  192.             for (int i = 0; i < _imageViews.length; i++) {  
  193.                     _imageViews[position].setBackgroundResource(R.drawable.a2a);  
  194.                     if(position!=i)  
  195.                         _imageViews[i].setBackgroundResource(R.drawable.a1a);  
  196.                       
  197.             }  
  198.         }  
  199.           
  200.     }  
  201. }  
package cn.djy.activity;

import java.util.ArrayList;

import android.app.Activity;
import android.content.Intent;
import android.content.SharedPreferences;
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.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.view.ViewGroup.LayoutParams;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.TwoLineListItem;
/**
 * 实现
 * @author dujinyang
 *
 */
public class MainActivity extends Activity {
	
	private ViewPager _viewpager;
	
	/**
	 * 分页显示的View数组
	 */
	private ArrayList<View> _pagerlist;
	private ImageView image;
	
	/**
	 * 小圆点的图片 放进数组
	 */
	private ImageView[] _imageViews;
	
	//包裹滑动的图片Linearlayout
	private ViewGroup _group;
	
	//包裹小圆点的Linearlayout
	private ViewGroup _viewPonits;
	
	
	
	
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.start);
        
        LayoutInflater inflater=getLayoutInflater();
        _pagerlist =new ArrayList<View>();
        _pagerlist.add(inflater.inflate(R.layout.viewpager_page1,null));
        _pagerlist.add(inflater.inflate(R.layout.viewpager_page2,null));
        
        //创建Imageviews数组,大小是要显示的图片数量
        _imageViews =new ImageView[_pagerlist.size()];
        
        
        
//        ViewGroup 
        _group =(ViewGroup) inflater.inflate(R.layout.start, null);//加载MAIN.XML
        
        _viewPonits=(ViewGroup) _group.findViewById(R.id.icon_circle);//加载小圆点的图片
        
        _viewpager =(ViewPager) _group.findViewById(R.id.guidePages);//android.support.v4.view.ViewPager
        
        
        //添加小圆点的图片
        for (int i = 0; i < _imageViews.length; i++) {
			 image= new ImageView(this);
			 //设置小圆点的imageview的参数
			 image.setLayoutParams(new LayoutParams(20,20));//宽高均为20
			 image.setPadding(20, 0, 20, 0);
			 _imageViews[i]=image;
			 
			 //第一张是选中状态
			 if(i==0){
				 _imageViews[i].setBackgroundResource(R.drawable.a2a);
			 }else{
				 _imageViews[i].setBackgroundResource(R.drawable.a1a);
			 }
			 _viewPonits.addView(_imageViews[i]);
		}
        //显示视图
        setContentView(_group);
        _viewpager.setAdapter(new GuidePageAdapter());
        _viewpager.setOnPageChangeListener(new GuidePageChangeListener());
    }
    
    
    void setGuided(){
    	SharedPreferences shared=getSharedPreferences("yang",0);
    	SharedPreferences.Editor editor=shared.edit();
    	editor.putString("Open", "false");
    	editor.commit();
    }
    
    class GuidePageAdapter extends PagerAdapter{

		@Override
		public int getCount() {
			return _pagerlist.size();
		}
		
		//initalization position page
		@Override
		public Object instantiateItem(View container, int position) {
			((ViewPager)container).addView(_pagerlist.get(position));
			if(position==1){
				Button bt=(Button) container.findViewById(R.id.bt_close);
				bt.setOnClickListener(new OnClickListener() {
					@Override
					public void onClick(View v) {
						//设置已经引导
						setGuided();
						//Intent 
						Intent intent=new Intent();
						intent.setClass(MainActivity.this,TwoActivity.class );
						MainActivity.this.startActivity(intent);
						MainActivity.this.finish();
					}
				});
				
			}
			return _pagerlist.get(position);
		}
		
		
		//判断是否由对象生成页面
		@Override
		public boolean isViewFromObject(View view, Object obj) {
			return view==obj;
		}
    	
		//销毁页面的位置
		@Override
		public void destroyItem(View container, int position, Object object) {
			((ViewPager)container).removeView(_pagerlist.get(position));
		}
		
		
		@Override
		public void finishUpdate(View container) {
			//finish
		}
		
		@Override
		public void startUpdate(View container) {
			//start
		}
		
		@Override
		public int getItemPosition(Object object) {
			//getItemPosition
			return super.getItemPosition(object);
		}
		
		
		@Override
		public void restoreState(Parcelable state, ClassLoader loader) {
			super.restoreState(state, loader);
			//restore
		}
		
		@Override
		public Parcelable saveState() {
			return super.saveState();
			//save
		}
    }
    
    class GuidePageChangeListener implements OnPageChangeListener{

		@Override
		public void onPageScrollStateChanged(int arg0) {
			
		}

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

		@Override
		public void onPageSelected(int position) {
			for (int i = 0; i < _imageViews.length; i++) {
					_imageViews[position].setBackgroundResource(R.drawable.a2a);
					if(position!=i)
						_imageViews[i].setBackgroundResource(R.drawable.a1a);
					
			}
		}
    	
    }
}



最后是TWOActivity:这个Activity是显示的内容。


  1. package cn.djy.activity;  
  2.   
  3. import android.app.Activity;  
  4. import android.os.Bundle;  
  5.   
  6. public class TwoActivity extends Activity{  
  7.       
  8.       
  9.     @Override  
  10.     protected void onCreate(Bundle savedInstanceState) {  
  11.         super.onCreate(savedInstanceState);  
  12.         setContentView(R.layout.end);  
  13.     }  
  14.   
  15. }  
package cn.djy.activity;

import android.app.Activity;
import android.os.Bundle;

public class TwoActivity extends Activity{
	
	
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.end);
	}

}



主要代码完成。

里面涉及的drawable图片是小圆点图片。


下面贴出XML的。

start.xml

 

  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:orientation="vertical"  
  4.     android:layout_width="fill_parent"  
  5.     android:layout_height="fill_parent"  
  6.     >  
  7.      <LinearLayout android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" android:id="@+id/linear_viewpager">  
  8.        
  9.         <android.support.v4.view.ViewPager   android:id="@+id/guidePages" android:layout_width="fill_parent"  android:layout_height="wrap_content"/>  
  10.        
  11.      </LinearLayout>  
  12.        
  13.        
  14.        
  15.      <LinearLayout android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" android:id="@+id/linear_circle">  
  16.            
  17.          <RelativeLayout android:layout_width="fill_parent" android:layout_height="wrap_content" >  
  18.                 <LinearLayout android:id="@+id/icon_circle"   
  19.                               android:layout_width="fill_parent"   
  20.                               android:layout_height="wrap_content"   
  21.                               android:layout_marginBottom="40dip"   
  22.                               android:layout_alignParentBottom="true"   
  23.                               android:gravity="center_vertical"  
  24.                               android:orientation="horizontal"/>  
  25.          </RelativeLayout>  
  26.            
  27.      </LinearLayout>  
  28.        
  29.        
  30.        
  31.        
  32. </FrameLayout>  
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
 	 <LinearLayout android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" android:id="@+id/linear_viewpager">
 	 
 	 	<android.support.v4.view.ViewPager 	android:id="@+id/guidePages" android:layout_width="fill_parent"  android:layout_height="wrap_content"/>
 	 
 	 </LinearLayout>
 	 
 	 
 	 
 	 <LinearLayout android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" android:id="@+id/linear_circle">
 	 	 
 	 	 <RelativeLayout android:layout_width="fill_parent" android:layout_height="wrap_content" >
 	 	 		<LinearLayout android:id="@+id/icon_circle" 
 	 	 					  android:layout_width="fill_parent" 
 	 	 					  android:layout_height="wrap_content" 
 	 	 					  android:layout_marginBottom="40dip" 
 	 	 					  android:layout_alignParentBottom="true" 
 	 	 					  android:gravity="center_vertical"
 	 	 					  android:orientation="horizontal"/>
 	 	 </RelativeLayout>
 	 	 
 	 </LinearLayout>
 	 
 	 
 	 
 	 
</FrameLayout>

其实是用Group把子项包起来作为显示:


那子项为:


viewpager_page1.xml

  1. <LinearLayout  
  2.   xmlns:android="http://schemas.android.com/apk/res/android"  
  3.   android:layout_width="match_parent"  
  4.   android:layout_height="match_parent"  android:orientation="vertical">  
  5.    <TextView android:layout_width="fill_parent" android:layout_height="fill_parent" android:gravity="center" android:text="adfasfasfweqwwfqw'"  
  6.    />  
  7.  </LinearLayout>  
<LinearLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="match_parent"  android:orientation="vertical">
   <TextView android:layout_width="fill_parent" android:layout_height="fill_parent" android:gravity="center" android:text="adfasfasfweqwwfqw'"
   />
 </LinearLayout>


viewpager_page2.xml

  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <LinearLayout  
  3.   xmlns:android="http://schemas.android.com/apk/res/android"  
  4.   android:layout_width="match_parent"  
  5.   android:layout_height="match_parent"  
  6.   android:orientation="vertical"   
  7.   android:gravity="center">  
  8.     
  9.   <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="pages222222222222222222"></TextView>  
  10.     
  11.   <Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="asdfi14234124" android:id="@+id/bt_close"></Button>  
  12. </LinearLayout>  
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:orientation="vertical" 
  android:gravity="center">
  
  <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="pages222222222222222222"></TextView>
  
  <Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="asdfi14234124" android:id="@+id/bt_close"></Button>
</LinearLayout>


总的代码完成。

希望大家互相学习 互相共享。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Android Studio引导实现可以通过以下步骤完成: 1. 创建一个新的Android Studio项目。 2. 在项目中创建一个新的Activity,用于显示引导页。 3. 在引导页Activity中添加一个ViewPager控件,用于显示多个页面。 4. 创建一个PagerAdapter类,用于管理ViewPager中的页面。 5. 在PagerAdapter中添加需要显示的页面,可以使用布局文件或代码方式创建。 6. 在引导页Activity中添加一个指示器控件,用于显示当前页面的位置。 7. 在ViewPager的OnPageChangeListener中更新指示器的位置。 8. 在最后一个页面中添加一个按钮,用于跳转到主界面或登录界面。 9. 在按钮的点击事件中跳转到相应的界面。 以上就是Android Studio引导实现的基本步骤,可以根据具体需求进行调整和扩展。 ### 回答2: 引导页在移动应用中是一个非常重要的组件,它可以帮助用户更好地了解应用程序的功能和使用,提高用户的体验和满意度。Android Studio提供了良好的支持来实现应用程序的引导页。 实现步骤如下: 1.创建一个新项目 在Android Studio中创建一个新项目。在创建项目的过程中,可以选择空白活动,在项目创建后再进行引导页的添加。 2.设计引导页 准备好需要展示的引导页图片,并按照设计图的要求进行切图、编辑等操作。 3.创建视图控件 打开activity_main.xml文件,并添加ViewPager和CircleIndicator视图控件,用于展示引导页和指示当前展示的引导页的位置。ViewPager需要用Adapter进行管理,并创建好相应的Fragment或者View视图。 4.创建引导页适配器 创建一个继承自PagerAdapter的适配器类,用于管理ViewPager中展示的引导页视图控件。在适配器中需要重写getCount()方法,返回需要展示的引导页数量;getItem()方法,返回某一个特定位置的引导页视图控件;以及isViewFromObject()方法,用于判断某个视图控件是否为某一视图。 5.添加动画效果 在不同的引导页之间需要添加相应的动画效果,以便让用户更加吸引和留意。可以使用Android中提供的Animator、ObjectAnimator等动画技术实现需要的动画效果。 6.完善引导页功能 在ViewPager中添加事件监听器,以便在规定条件下实现页面跳转和引导页的最终目标。 7.测试 在完成代码编写后需要进行测试,并检查引导页中的所有功能是否正常工作。以便在发布应用时达到最佳效果。 总之,通过上述步骤的操作,可以在Android Studio中很轻松地实现一个流畅、功能完备的引导页。这将有助于提高用户体验和应用程序的使用率。 ### 回答3: 在开发Android应用时,经常需要添加引导页来给用户介绍应用的基本功能和操作方法。本文将以Android Studio为例,介绍如何实现引导页。 一、创建项目 首先打开Android Studio,点击“Start a new Android Studio project”,选择“Empty Activity”,输入“App name”和“Package name”,点击“Finish”创建项目。 二、添加引导页 1、步骤一 在“app”文件夹下,右键点击“res”,选择“New”-“Android Resource File”,设置“Resource type”为“layout”,命名为“activity_main.xml”(这里取名为activity_main.xml是为了后面直接复制粘贴代码方便)。 2、步骤二 右键点击“res”文件夹,选择“New”-“Folder”-“Values Folder”,命名为“values-w820dp”(这个文件夹的作用是为了适配平板设备),在该文件夹下创建一个名为“dimens.xml”的布局文件,在该文件中添加以下代码: ``` <resources> <dimen name="tutorial_image_size">450dp</dimen> <dimen name="tutorial_image_padding">30dp</dimen> <dimen name="tutorial_title_size">20sp</dimen> <dimen name="tutorial_title_padding_top">30dp</dimen> <dimen name="tutorial_description_size">14sp</dimen> <dimen name="tutorial_description_padding_top">10dp</dimen> <dimen name="tutorial_button_padding_top">50dp</dimen> <dimen name="tutorial_button_size">50dp</dimen> </resources> ``` 3、步骤三 在“res”文件夹下创建一个名为“drawable”的文件夹,将要使用的引导页图片拷贝到该文件夹下。 4、步骤四 在“res”文件夹下创建一个名为“values”的文件夹,在该文件夹下创建一个名为“colors.xml”的布局文件,在该文件中添加以下代码: ``` <resources> <color name="colorPrimary">#3F51B5</color> <color name="colorPrimaryDark">#303F9F</color> <color name="colorAccent">#FF4081</color> <color name="colorTutorialBackground">#FFFFFF</color> </resources> ``` 5、步骤五 在“res”文件夹下创建一个名为“drawable”的文件夹,在该文件夹下创建一个名为“gradient_tutorial_background.xml”的布局文件,在该文件中添加以下代码: ``` <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle"> <gradient android:startColor="@color/colorPrimary" android:endColor="@color/colorPrimaryDark" android:angle="135" /> </shape> ``` 6、步骤六 在“res”文件夹下创建一个名为“layout”的文件夹,在该文件夹下创建一个名为“item_viewpager_tutorial.xml”的布局文件,在该文件中添加以下代码: ``` <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@color/colorTutorialBackground" android:orientation="vertical" android:padding="@dimen/tutorial_image_padding"> <ImageView android:id="@+id/imageViewPagerTutorial" android:layout_width="@dimen/tutorial_image_size" android:layout_height="@dimen/tutorial_image_size" android:layout_gravity="center_horizontal" android:layout_marginBottom="@dimen/tutorial_title_padding_top" android:src="@drawable/tutorial1" /> <TextView android:id="@+id/tvTitleViewPagerTutorial" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:layout_marginTop="@dimen/tutorial_title_padding_top" android:text="Title" android:textColor="#000000" android:textSize="@dimen/tutorial_title_size" /> <TextView android:id="@+id/tvDescriptionViewPagerTutorial" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:layout_marginTop="@dimen/tutorial_description_padding_top" android:text="Description" android:textColor="#000000" android:textSize="@dimen/tutorial_description_size" /> <Button android:id="@+id/btnSkipViewPagerTutorial" android:layout_width="@dimen/tutorial_button_size" android:layout_height="@dimen/tutorial_button_size" android:layout_gravity="right" android:background="@null" android:paddingTop="@dimen/tutorial_button_padding_top" android:text="Skip" android:textColor="#000000" /> </LinearLayout> ``` 7、步骤七 在“res”文件夹下创建一个名为“layout”的文件夹,在该文件夹下创建一个名为“activity_view_pager_tutorial.xml”的布局文件,在该文件中添加以下代码: ``` <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@drawable/gradient_tutorial_background"> <androidx.viewpager.widget.ViewPager android:id="@+id/viewPagerTutorial" android:layout_width="match_parent" android:layout_height="match_parent" /> </RelativeLayout> ``` 三、编写代码 1、步骤一 打开“MainActivity.java”文件,添加以下代码: ``` public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); boolean isFirstTime = MyPreferences.isFirst(MainActivity.this); if (isFirstTime) { startActivity(new Intent(MainActivity.this, ViewPagerTutorialActivity.class)); finish(); } } } ``` 2、步骤二 创建一个名为“MyPreferences”的Java类,在该类中添加以下代码: ``` public class MyPreferences { private static final String FIRST = "first"; private static SharedPreferences getSharedPreferences(Context context) { return context.getSharedPreferences("MyPreferences", MODE_PRIVATE); } public static void setFirst(Context context, boolean value) { SharedPreferences.Editor editor = getSharedPreferences(context).edit(); editor.putBoolean(FIRST, value).apply(); } public static boolean isFirst(Context context) { return getSharedPreferences(context).getBoolean(FIRST, true); } } ``` 3、步骤三 创建一个名为“ViewPagerTutorialActivity”的Java类,在该类中添加以下代码: ``` public class ViewPagerTutorialActivity extends AppCompatActivity { int[] tutorialImages = {R.drawable.tutorial1, R.drawable.tutorial2, R.drawable.tutorial3}; String[] titles = {"Title 1", "Title 2", "Title 3"}; String[] descriptions = {"Description 1", "Description 2", "Description 3"}; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_view_pager_tutorial); ViewPager viewPager = findViewById(R.id.viewPagerTutorial); TutorialViewPagerAdapter adapter = new TutorialViewPagerAdapter(this, tutorialImages, titles, descriptions); viewPager.setAdapter(adapter); Button btnSkip = findViewById(R.id.btnSkipViewPagerTutorial); btnSkip.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { MyPreferences.setFirst(ViewPagerTutorialActivity.this, false); startActivity(new Intent(ViewPagerTutorialActivity.this, MainActivity.class)); finish(); } }); } } ``` 4、步骤四 创建一个名为“TutorialViewPagerAdapter”的Java类,在该类中添加以下代码: ``` public class TutorialViewPagerAdapter extends PagerAdapter { private Context context; private int[] images; private String[] titles; private String[] descriptions; private LayoutInflater layoutInflater; public TutorialViewPagerAdapter(Context context, int[] images, String[] titles, String[] descriptions) { this.context = context; this.images = images; this.titles = titles; this.descriptions = descriptions; layoutInflater = LayoutInflater.from(context); } @Override public int getCount() { return images.length; } @Override public boolean isViewFromObject(View view, Object object) { return view == object; } @Override public Object instantiateItem(ViewGroup container, int position) { View view = layoutInflater.inflate(R.layout.item_viewpager_tutorial, container, false); ImageView imageView = view.findViewById(R.id.imageViewPagerTutorial); TextView tvTitle = view.findViewById(R.id.tvTitleViewPagerTutorial); TextView tvDescription = view.findViewById(R.id.tvDescriptionViewPagerTutorial); Button btnSkip = view.findViewById(R.id.btnSkipViewPagerTutorial); imageView.setImageResource(images[position]); tvTitle.setText(titles[position]); tvDescription.setText(descriptions[position]); if (position == getCount()-1) { btnSkip.setText("Finish"); } container.addView(view); return view; } @Override public void destroyItem(ViewGroup container, int position, Object object) { container.removeView((View) object); } } ``` 至此,Android Studio引导页的实现就完成了。在运行项目时,第一次打开应用会显示引导页,用户按下Skip按钮,或者直接滑到最后一页,点击Finish按钮进入主界面。之后再打开应用,就不会再显示引导页了,因为已经保存了用户的选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值