打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
Android 仿微信之界面导航篇(一)
分类: Android 2012-11-02 14:21 14121人阅读 评论(209) 收藏 举报

  微信是现在比较流行的应用了,在各大安卓市场几乎都是名列前茅了。说实话不得不羡慕腾讯庞大的用户群体,只要腾讯敢做,就会有很多人去用。废话不多说,下面就开始说一下如何实现微信的第一次启动程序的用户导航,ViewPager相信大家都不陌生了,是google放出的一个安卓低版本的兼容包android-support-v4.jar,里面有很多类我们可以去使用。那这个导航就是使用这个类来辅助完成的,在每一个View里放置一个图片,当我们使用ViewPager滑动界面的时候,就会看到一张张图片,从而实现这个效果,我们来看一下官方的:


  其实使用过微信的用户都知道,每次启动程序都会有这个启动画面,如果是第一次使用当然还会出现后面的导航界面。下面以第一次使用为例,来说明如何实现。当启动出现进入第一个Activity,其实就是那个启动画面,有地球那个,之后会在这个Activity里面设置一个Handler去延迟(1秒,数值可以自己设定)执行启动导航界面的Activity,代码如下:

  1. import android.os.Bundle;  
  2. import android.os.Handler;  
  3. import android.app.Activity;  
  4. import android.content.Intent;  
  5. import android.view.Window;  
  6. import android.view.WindowManager;  
  7.   
  8. public class Appstart extends Activity{  
  9.   
  10.     /* 
  11.  * 2012.11.1 
  12.  * @author:wangjinyu501 
  13.  * 这个Activiyt是程序启动画面,也就是一个图片。在这个Activity里使用了Handler一秒后会进入到引导Activity里面。 
  14.  */  
  15.     @Override  
  16.     public void onCreate(Bundle savedInstanceState) {  
  17.           
  18.         super.onCreate(savedInstanceState);   
  19.         requestWindowFeature(Window.FEATURE_NO_TITLE);//去掉标题栏,注意一定要在绘制view之前调用这个方法,不然会出现  
  20.         //AndroidRuntimeException: requestFeature() must be called before adding content 这个错误。  
  21.         setContentView(R.layout.appstart);  
  22.         getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,WindowManager.LayoutParams.FLAG_FULLSCREEN);   //全屏显示  
  23.           
  24.             new Handler().postDelayed(new Runnable(){  
  25.         public void run(){  
  26.             Intent intent = new Intent (Appstart.this,Viewpager.class);           
  27.             startActivity(intent);            
  28.             this.finish();//结束本Activity  
  29.         }  
  30.     }, 1000);  
  31.    }  
  32. }  
  之后就进入前面说的导航页面了,其实就是多个View,每一个View就是一张图片,非常简单,而且就是基于ViewPager实现的,唯一有一些难度的就是当我们滑动图片的时候,下面那些移动的小圆点会随着改变。这种效果在其他程序的导航界面中也是很常见的。代码如下:
  1. import java.util.ArrayList;  
  2. import android.app.Activity;  
  3. import android.content.Intent;  
  4. import android.os.Bundle;  
  5. import android.support.v4.view.PagerAdapter;  
  6. import android.support.v4.view.PagerTitleStrip;  
  7. import android.support.v4.view.ViewPager;  
  8. import android.support.v4.view.ViewPager.OnPageChangeListener;  
  9. import android.view.LayoutInflater;  
  10. import android.view.View;  
  11. import android.view.animation.Animation;  
  12. import android.view.animation.TranslateAnimation;  
  13. import android.widget.ImageView;  
  14.   
  15.   
  16. public class Viewpager extends Activity {  
  17.       
  18.     private ViewPager mViewPager;//声明ViewPager对象  
  19.     private PagerTitleStrip mPagerTitleStrip;//声明动画标题  
  20.     private ImageView mPageImg;// 动画图片  
  21.     private int currIndex = 0;//当前页面  
  22.     private ImageView mPage0,mPage1,mPage2,mPage3,mPage4,mPage5,mPage6,mPage7,mPage8;//声明导航图片对象  
  23.       
  24.     @Override  
  25.     public void onCreate(Bundle savedInstanceState) {  
  26.         super.onCreate(savedInstanceState);  
  27.         setContentView(R.layout.viewpager);  
  28.         mViewPager = (ViewPager)findViewById(R.id.viewpager);          
  29.         mViewPager.setOnPageChangeListener(new MyOnPageChangeListener());  
  30.         mPagerTitleStrip = (PagerTitleStrip)findViewById(R.id.pagertitle);   
  31.           
  32.         mPage0 = (ImageView)findViewById(R.id.page0);  
  33.         mPage1 = (ImageView)findViewById(R.id.page1);  
  34.         mPage2 = (ImageView)findViewById(R.id.page2);  
  35.         mPage3 = (ImageView)findViewById(R.id.page3);  
  36.         mPage4 = (ImageView)findViewById(R.id.page4);  
  37.         mPage5 = (ImageView)findViewById(R.id.page5);  
  38.         mPage6 = (ImageView)findViewById(R.id.page6);  
  39.         mPage7 = (ImageView)findViewById(R.id.page7);  
  40.         mPage8 = (ImageView)findViewById(R.id.page8);  
  41.                  
  42.         //将要分页显示的View装入数组中  
  43.         LayoutInflater mLi = LayoutInflater.from(this);  
  44.         View view1 = mLi.inflate(R.layout.view1, null);  
  45.         View view2 = mLi.inflate(R.layout.view2, null);  
  46.         View view3 = mLi.inflate(R.layout.view3, null);  
  47.         View view4 = mLi.inflate(R.layout.view4, null);  
  48.         View view5 = mLi.inflate(R.layout.view5, null);  
  49.         View view6 = mLi.inflate(R.layout.view6, null);  
  50.         View view7 = mLi.inflate(R.layout.view7, null);  
  51.         View view8 = mLi.inflate(R.layout.view8, null);  
  52.         View view9 = mLi.inflate(R.layout.view9, null);  
  53.                   
  54.         //每个页面的view数据  
  55.         final ArrayList<View> views = new ArrayList<View>();  
  56.         views.add(view1);  
  57.         views.add(view2);  
  58.         views.add(view3);  
  59.         views.add(view4);  
  60.         views.add(view5);  
  61.         views.add(view6);  
  62.         views.add(view7);  
  63.         views.add(view8);  
  64.         views.add(view9);  
  65.         //每一个也没得标题  
  66.         final ArrayList<String> titles = new ArrayList<String>();  
  67.         titles.add("①");  
  68.         titles.add("②");  
  69.         titles.add("③");  
  70.         titles.add("④");  
  71.         titles.add("⑤");  
  72.         titles.add("⑥");  
  73.         titles.add("⑦");  
  74.         titles.add("⑧");  
  75.         titles.add("⑨");  
  76.                  
  77.         //填充ViewPager的数据适配器,我们重写即可  
  78.         PagerAdapter mPagerAdapter = new PagerAdapter() {  
  79.               
  80.             @Override  
  81.             public boolean isViewFromObject(View arg0, Object arg1) {  
  82.                 return arg0 == arg1;  
  83.             }  
  84.               
  85.             @Override  
  86.             public int getCount() {  
  87.                 return views.size();  
  88.             }  
  89.   
  90.             @Override  
  91.             public void destroyItem(View container, int position, Object object) {  
  92.                 ((ViewPager)container).removeView(views.get(position));  
  93.             }  
  94.               
  95.             @Override  
  96.             public CharSequence getPageTitle(int position) {  
  97.                 return titles.get(position);  
  98.             }  
  99.               
  100.             @Override  
  101.             public Object instantiateItem(View container, int position) {  
  102.                 ((ViewPager)container).addView(views.get(position));  
  103.                 return views.get(position);  
  104.             }  
  105.         };  
  106.           
  107.         mViewPager.setAdapter(mPagerAdapter);//与ListView用法相同,设置重写的Adapter。这样就实现了ViewPager的滑动效果。  
  108.     }  
  109.       
  110.     public class MyOnPageChangeListener implements OnPageChangeListener {  
  111.   
  112.         public void onPageSelected(int arg0) {//参数arg0为选中的View  
  113.   
  114.             Animation animation = null;//声明动画对象  
  115.             switch (arg0) {  
  116.             case 0//页面一             
  117.                 mPage0.setImageDrawable(getResources().getDrawable(R.drawable.page_now));//进入第一个导航页面,小圆点为选中状态,下一个页面的小圆点是未选中状态。  
  118.                 mPage1.setImageDrawable(getResources().getDrawable(R.drawable.page));  
  119.                 if (currIndex == arg0+1) {  
  120.                     animation = new TranslateAnimation(arg0+1, arg0, 00);//圆点移动效果动画,从当前View移动到下一个View  
  121.                 }   
  122.                 break;  
  123.             case 1//页面二  
  124.                 mPage1.setImageDrawable(getResources().getDrawable(R.drawable.page_now));//当前View  
  125.                 mPage0.setImageDrawable(getResources().getDrawable(R.drawable.page));//上一个View  
  126.                 mPage2.setImageDrawable(getResources().getDrawable(R.drawable.page));//下一个View  
  127.                 if (currIndex == arg0-1) {//如果滑动到上一个View  
  128.                     animation = new TranslateAnimation(arg0-1, arg0, 00); //圆点移动效果动画,从当前View移动到下一个View  
  129.   
  130.                       
  131.                 } else if (currIndex == arg0+1) {//圆点移动效果动画,从当前View移动到下一个View,下同。  
  132.   
  133.                     animation = new TranslateAnimation(arg0+1, arg0, 00);  
  134.                 }  
  135.                 break;  
  136.             case 2//页面三  
  137.                 mPage2.setImageDrawable(getResources().getDrawable(R.drawable.page_now));  
  138.                 mPage1.setImageDrawable(getResources().getDrawable(R.drawable.page));  
  139.                 mPage3.setImageDrawable(getResources().getDrawable(R.drawable.page));  
  140.                 if (currIndex == arg0-1) {  
  141.                     animation = new TranslateAnimation(arg0-1, arg0, 00);  
  142.                 } else if (currIndex == arg0+1) {  
  143.                     animation = new TranslateAnimation(arg0+1, arg0, 00);  
  144.                 }  
  145.                 break;  
  146.             case 3:  
  147.                 mPage3.setImageDrawable(getResources().getDrawable(R.drawable.page_now));  
  148.                 mPage4.setImageDrawable(getResources().getDrawable(R.drawable.page));  
  149.                 mPage2.setImageDrawable(getResources().getDrawable(R.drawable.page));  
  150.                 if (currIndex == arg0-1) {  
  151.                     animation = new TranslateAnimation(arg0-1, arg0, 00);  
  152.                       
  153.                 } else if (currIndex == arg0+1) {  
  154.                     animation = new TranslateAnimation(arg0+1, arg0, 00);  
  155.                 }  
  156.                 break;  
  157.             case 4:  
  158.                 mPage4.setImageDrawable(getResources().getDrawable(R.drawable.page_now));  
  159.                 mPage3.setImageDrawable(getResources().getDrawable(R.drawable.page));  
  160.                 mPage5.setImageDrawable(getResources().getDrawable(R.drawable.page));  
  161.                 if (currIndex == arg0-1) {  
  162.                     animation = new TranslateAnimation(arg0-1, arg0, 00);  
  163.                 } else if (currIndex == arg0+1) {  
  164.                     animation = new TranslateAnimation(arg0+1, arg0, 00);  
  165.                 }  
  166.                 break;  
  167.             case 5:  
  168.                 mPage5.setImageDrawable(getResources().getDrawable(R.drawable.page_now));  
  169.                 mPage4.setImageDrawable(getResources().getDrawable(R.drawable.page));  
  170.                 mPage6.setImageDrawable(getResources().getDrawable(R.drawable.page));  
  171.                 if (currIndex == arg0-1) {  
  172.                     animation = new TranslateAnimation(arg0-1, arg0, 00);  
  173.                 } else if (currIndex == arg0+1) {  
  174.                     animation = new TranslateAnimation(arg0+1, arg0, 00);  
  175.                 }  
  176.                 break;  
  177.             case 6:  
  178.                 mPage6.setImageDrawable(getResources().getDrawable(R.drawable.page_now));  
  179.                 mPage5.setImageDrawable(getResources().getDrawable(R.drawable.page));  
  180.                 mPage7.setImageDrawable(getResources().getDrawable(R.drawable.page));  
  181.                 if (currIndex == arg0-1) {  
  182.                     animation = new TranslateAnimation(arg0-1, arg0, 00);  
  183.                 } else if (currIndex == arg0+1) {  
  184.                     animation = new TranslateAnimation(arg0+1, arg0, 00);  
  185.                 }  
  186.                 break;  
  187.             case 7:  
  188.                 mPage7.setImageDrawable(getResources().getDrawable(R.drawable.page_now));  
  189.                 mPage8.setImageDrawable(getResources().getDrawable(R.drawable.page));  
  190.                 mPage6.setImageDrawable(getResources().getDrawable(R.drawable.page));  
  191.                 if (currIndex == arg0-1) {  
  192.                     animation = new TranslateAnimation(arg0-1, arg0, 00);  
  193.                 } else if (currIndex == arg0+1) {  
  194.                     animation = new TranslateAnimation(arg0+1, arg0, 00);  
  195.                 }  
  196.                 break;  
  197.             case 8:  
  198.                 mPage8.setImageDrawable(getResources().getDrawable(R.drawable.page_now));  
  199.                 mPage7.setImageDrawable(getResources().getDrawable(R.drawable.page));  
  200.                 if (currIndex == arg0-1) {  
  201.                     animation = new TranslateAnimation(arg0-1, arg0, 00);  
  202.                 }   
  203.                 break;  
  204.             }  
  205.             currIndex = arg0;//设置当前View  
  206.             animation.setFillAfter(true);// True:设置图片停在动画结束位置  
  207.             animation.setDuration(300);//设置动画持续时间  
  208.         }  
  209.       
  210.     public void startbutton(View v) {    
  211.                 Intent intent = new Intent();  
  212.         intent.setClass(Viewpager.this,Viewdoor.class);//进入到开门效果的Activity  
  213.         startActivity(intent);  
  214.         this.finish();//结束本Activity  
  215.       }    
  216.      
  217. }  
 下面再看一下导航Activity的布局文件,
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:layout_width="fill_parent"  
  4.     android:layout_height="fill_parent"  
  5.     android:orientation="vertical" >    
  6.   
  7.     <android.support.v4.view.ViewPager  
  8.         android:id="@+id/viewpager"  
  9.         android:layout_width="wrap_content"  
  10.         android:layout_height="wrap_content"  
  11.         android:layout_gravity="center" >   
  12.           
  13.         <android.support.v4.view.PagerTitleStrip  
  14.             android:id="@+id/pagertitle"  
  15.             android:layout_width="wrap_content"  
  16.             android:layout_height="0dp"  
  17.             android:layout_gravity="bottom"  
  18.             android:background="#0000"  
  19.             android:textColor="#ffff" />  
  20.     </android.support.v4.view.ViewPager>    
  21.       
  22.     <LinearLayout  
  23.         android:layout_width="match_parent"  
  24.         android:layout_height="match_parent"  
  25.         android:orientation="horizontal"  
  26.         android:gravity="center_horizontal" >         
  27.   
  28.         <ImageView  
  29.             android:id="@+id/page0"  
  30.             android:layout_width="wrap_content"  
  31.             android:layout_height="wrap_content"  
  32.             android:layout_gravity="bottom"  
  33.             android:layout_marginBottom="30dp"        
  34.             android:scaleType="matrix"  
  35.             android:src="@drawable/page_now" />  
  36.         <ImageView  
  37.             android:id="@+id/page1"  
  38.             android:layout_width="wrap_content"  
  39.             android:layout_height="wrap_content"  
  40.             android:layout_gravity="bottom"  
  41.             android:layout_marginBottom="30dp"            
  42.             android:layout_marginLeft="10dp"  
  43.             android:scaleType="matrix"  
  44.             android:src="@drawable/page" />  
  45.         <ImageView  
  46.             android:id="@+id/page2"  
  47.             android:layout_width="wrap_content"  
  48.             android:layout_height="wrap_content"  
  49.             android:layout_gravity="bottom"  
  50.             android:layout_marginBottom="30dp"            
  51.             android:layout_marginLeft="10dp"  
  52.             android:scaleType="matrix"  
  53.             android:src="@drawable/page" />  
  54.         <ImageView  
  55.             android:id="@+id/page3"  
  56.             android:layout_width="wrap_content"  
  57.             android:layout_height="wrap_content"  
  58.             android:layout_gravity="bottom"  
  59.             android:layout_marginBottom="30dp"            
  60.             android:layout_marginLeft="10dp"  
  61.             android:scaleType="matrix"  
  62.             android:src="@drawable/page" />  
  63.         <ImageView  
  64.             android:id="@+id/page4"  
  65.             android:layout_width="wrap_content"  
  66.             android:layout_height="wrap_content"  
  67.             android:layout_gravity="bottom"  
  68.             android:layout_marginBottom="30dp"            
  69.             android:layout_marginLeft="10dp"  
  70.             android:scaleType="matrix"  
  71.             android:src="@drawable/page" />  
  72.         <ImageView  
  73.             android:id="@+id/page5"  
  74.             android:layout_width="wrap_content"  
  75.             android:layout_height="wrap_content"  
  76.             android:layout_gravity="bottom"  
  77.             android:layout_marginBottom="30dp"            
  78.             android:layout_marginLeft="20dp"  
  79.             android:scaleType="matrix"  
  80.             android:src="@drawable/page" />  
  81.         <ImageView  
  82.             android:id="@+id/page6"  
  83.             android:layout_width="wrap_content"  
  84.             android:layout_height="wrap_content"  
  85.             android:layout_gravity="bottom"  
  86.             android:layout_marginBottom="30dp"            
  87.             android:layout_marginLeft="10dp"  
  88.             android:scaleType="matrix"  
  89.             android:src="@drawable/page" />  
  90.         <ImageView  
  91.             android:id="@+id/page7"  
  92.             android:layout_width="wrap_content"  
  93.             android:layout_height="wrap_content"  
  94.             android:layout_gravity="bottom"  
  95.             android:layout_marginBottom="30dp"            
  96.             android:layout_marginLeft="10dp"  
  97.             android:scaleType="matrix"  
  98.             android:src="@drawable/page" />  
  99.         <ImageView  
  100.             android:id="@+id/page8"  
  101.             android:layout_width="wrap_content"  
  102.             android:layout_height="wrap_content"  
  103.             android:layout_gravity="bottom"  
  104.             android:layout_marginBottom="30dp"            
  105.             android:layout_marginLeft="10dp"  
  106.             android:scaleType="matrix"  
  107.             android:src="@drawable/page" />  
  108.                  
  109.     </LinearLayout>  
  110.   
  111.     <LinearLayout  
  112.             android:layout_width="wrap_content"  
  113.             android:layout_height="match_parent"  
  114.             android:orientation="vertical" >  
  115.           
  116.             <Button  
  117.               android:layout_width="wrap_content"  
  118.               android:layout_height="32dp"  
  119.               android:layout_marginTop="8dp"  
  120.               android:layout_marginLeft="8dp"  
  121.               android:text="直接开始我的微信生活"  
  122.               android:textSize="10sp"  
  123.               android:textColor="#fff"  
  124.               android:background="@drawable/button_bg"                
  125.               android:onClick="startbutton"  
  126.               />  
  127.      </LinearLayout>  
  128.           
  129. </FrameLayout>  
  在这里采用了Framelayout布局,因为这样就可以把开启我的维新生活Button以及下面的圆点一同显示在同一个页面上。这是一个小技巧,非常实用。导航页面完毕我们点击开启我的微信生活就会进入到一个大门效果的Activity,这也是一个动画效果。原理就是两张图片,分别朝不同的方向移动就实现了开门的效果。代码如下:
  1. import android.os.Bundle;  
  2. import android.os.Handler;  
  3. import android.app.Activity;  
  4. import android.content.Intent;  
  5. import android.view.Menu;  
  6. import android.view.animation.Animation;  
  7. import android.view.animation.AnimationSet;  
  8. import android.view.animation.TranslateAnimation;  
  9. import android.widget.ImageView;  
  10.   
  11. public class Viewdoor extends Activity {  
  12.       
  13.     private ImageView mLeft;//往左边移动的图片  
  14.     private ImageView mRight;//往右边移动的图片  
  15.   
  16.     @Override  
  17.     public void onCreate(Bundle savedInstanceState) {  
  18.         super.onCreate(savedInstanceState);  
  19.         setContentView(R.layout.viewdoor);  
  20.           
  21.         mLeft = (ImageView)findViewById(R.id.imageLeft);  
  22.         mRight = (ImageView)findViewById(R.id.imageRight);  
  23.           
  24.         AnimationSet anim = new AnimationSet(true);//动画集,一个类似于集合的功能  
  25.         TranslateAnimation mytranslateanim = new TranslateAnimation(Animation.RELATIVE_TO_SELF,0f,Animation.RELATIVE_TO_SELF,-1f,Animation.RELATIVE_TO_SELF,0f,Animation.RELATIVE_TO_SELF,0f);  
  26.         mytranslateanim.setDuration(2000);//设置动画时间  
  27.         anim.addAnimation(mytranslateanim);//添加动画  
  28.         anim.setFillAfter(true);//设置动画结束时停在结束位置  
  29.         mLeft.startAnimation(anim);//开始动画,下同。  
  30.           
  31.         AnimationSet anim1 = new AnimationSet(true);  
  32.         TranslateAnimation mytranslateanim1 = new TranslateAnimation(Animation.RELATIVE_TO_SELF,0f,Animation.RELATIVE_TO_SELF,+1f,Animation.RELATIVE_TO_SELF,0f,Animation.RELATIVE_TO_SELF,0f);  
  33.         mytranslateanim1.setDuration(1500);  
  34.         anim1.addAnimation(mytranslateanim1);  
  35.         anim1.setFillAfter(true);  
  36.         mRight.startAnimation(anim1);  
  37.           
  38.         new Handler().postDelayed(new Runnable(){  
  39.             public void run(){  
  40.                 Intent intent = new Intent (Viewdoor.this,Main.class);  //进入到主页面          
  41.                 startActivity(intent);            
  42.                 Viewdoor.this.finish();//结束本Activity  
  43.             }  
  44.         }, 1500);  
  45.   
  46.     }  
  47.       
  48. }  
  至此,关于微信的导航功能就介绍到这,比较重要的地方有,ViewPager的使用,小圆点动画效果的设置,也就是Tween动画要熟练掌握。下一篇将讲述微信主页面的实现,欢迎大家关注!

效果如下:

  下载地址:




更多2
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
Android 仿QQ主页面的实
Android进阶篇之引导页系列之ViewPager实现Animation动画引导页
ViewPager + HorizontalScrollView 实现可滚动的标签栏
记录一波三折的ViewPager与PagerAdapter
android 欢迎引导页面 ViewPager实现
Tab底部导航样式页面可滑动
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服