`
445822357
  • 浏览: 741303 次
文章分类
社区版块
存档分类
最新评论

Android特效开发(仿zaker用手向上推动的效果(推动门效果))

 
阅读更多

本文由manymore13原创,转载请标明出处http://blog.csdn.net/manymore13/article/details/12219687

最近在商店下载了zaker ,闲暇时拿来看看新闻!发现每次打开软件进入主界面时有个界面,需要你把它往上滑到一

定距离才能进入到主界面。每次进入软件时它的背景可能不一样,在往上拨的时候你会看见主界面,好似向上推的门一样!

打开它你就可以看到外面的世界。与窗帘有点不同的是在你没有拉开足够距离时,它会俏皮的关闭自己不让你看到外面的美景。

说这么多想像起来挺模糊的,那让我们看看实际效果图,我现在打开zaker截两张图 如下所示

左边一张是不做任何操作时的效果滑动时效果

左边一张是不做任何操作时的效果,右边一张是界面跟着手往上滑的效果,在滑的时候你会发现即将进入的界面,当你没有滑到一定的距离松开手后窗帘会慢慢关闭,在合闭的时候有个弹动的效果。非常棒!

正如你看到的图片内容,今天是国庆节,在这里祝大家节日快乐!所以你每次打开的时候图片可能不一样。这个效果看起来有点像android里面讲的TranslateAnimation动画,我觉得用Animation动画应该很难实现出这种效果(当然有用animation实现zaker这种效果的大牛可以与我们分享下)。QQ里也有这么个功能的界面,只不过QQ的是展示一张图片两到三秒后再进入主界面。

下面开始实现这种效果 推动们效果。

根据效果我实现出一个类,方便与需要用的筒靴使用。代码中有注释

  1. packagecom.manymore13.scrollerdemo;
  2. importandroid.annotation.SuppressLint;
  3. importandroid.content.Context;
  4. importandroid.graphics.Color;
  5. importandroid.graphics.drawable.Drawable;
  6. importandroid.util.AttributeSet;
  7. importandroid.util.DisplayMetrics;
  8. importandroid.util.Log;
  9. importandroid.view.MotionEvent;
  10. importandroid.view.View;
  11. importandroid.view.WindowManager;
  12. importandroid.view.animation.AccelerateInterpolator;
  13. importandroid.view.animation.BounceInterpolator;
  14. importandroid.view.animation.Interpolator;
  15. importandroid.widget.FrameLayout;
  16. importandroid.widget.ImageView;
  17. importandroid.widget.RelativeLayout;
  18. importandroid.widget.Scroller;
  19. publicclassPullDoorViewextendsRelativeLayout{
  20. privateContextmContext;
  21. privateScrollermScroller;
  22. privateintmScreenWidth=0;
  23. privateintmScreenHeigh=0;
  24. privateintmLastDownY=0;
  25. privateintmCurryY;
  26. privateintmDelY;
  27. privatebooleanmCloseFlag=false;
  28. privateImageViewmImgView;
  29. publicPullDoorView(Contextcontext){
  30. super(context);
  31. mContext=context;
  32. setupView();
  33. }
  34. publicPullDoorView(Contextcontext,AttributeSetattrs){
  35. super(context,attrs);
  36. mContext=context;
  37. setupView();
  38. }
  39. @SuppressLint("NewApi")
  40. privatevoidsetupView(){
  41. //这个Interpolator你可以设置别的我这里选择的是有弹跳效果的Interpolator
  42. Interpolatorpolator=newBounceInterpolator();
  43. mScroller=newScroller(mContext,polator);
  44. //获取屏幕分辨率
  45. WindowManagerwm=(WindowManager)(mContext
  46. .getSystemService(Context.WINDOW_SERVICE));
  47. DisplayMetricsdm=newDisplayMetrics();
  48. wm.getDefaultDisplay().getMetrics(dm);
  49. mScreenHeigh=dm.heightPixels;
  50. mScreenWidth=dm.widthPixels;
  51. //这里你一定要设置成透明背景,不然会影响你看到底层布局
  52. this.setBackgroundColor(Color.argb(0,0,0,0));
  53. mImgView=newImageView(mContext);
  54. mImgView.setLayoutParams(newLayoutParams(LayoutParams.MATCH_PARENT,
  55. LayoutParams.MATCH_PARENT));
  56. mImgView.setScaleType(ImageView.ScaleType.FIT_XY);//填充整个屏幕
  57. mImgView.setImageResource(R.drawable.bg1);//默认背景
  58. addView(mImgView);
  59. }
  60. //设置推动门背景
  61. publicvoidsetBgImage(intid){
  62. mImgView.setImageResource(id);
  63. }
  64. //设置推动门背景
  65. publicvoidsetBgImage(Drawabledrawable){
  66. mImgView.setImageDrawable(drawable);
  67. }
  68. //推动门的动画
  69. publicvoidstartBounceAnim(intstartY,intdy,intduration){
  70. mScroller.startScroll(0,startY,0,dy,duration);
  71. invalidate();
  72. }
  73. @Override
  74. publicbooleanonTouchEvent(MotionEventevent){
  75. intaction=event.getAction();
  76. switch(action){
  77. caseMotionEvent.ACTION_DOWN:
  78. mLastDownY=(int)event.getY();
  79. System.err.println("ACTION_DOWN="+mLastDownY);
  80. returntrue;
  81. caseMotionEvent.ACTION_MOVE:
  82. mCurryY=(int)event.getY();
  83. System.err.println("ACTION_MOVE="+mCurryY);
  84. mDelY=mCurryY-mLastDownY;
  85. //只准上滑有效
  86. if(mDelY<0){
  87. scrollTo(0,-mDelY);
  88. }
  89. System.err.println("-------------"+mDelY);
  90. break;
  91. caseMotionEvent.ACTION_UP:
  92. mCurryY=(int)event.getY();
  93. mDelY=mCurryY-mLastDownY;
  94. if(mDelY<0){
  95. if(Math.abs(mDelY)>mScreenHeigh/2){
  96. //向上滑动超过半个屏幕高的时候开启向上消失动画
  97. startBounceAnim(this.getScrollY(),mScreenHeigh,450);
  98. mCloseFlag=true;
  99. }else{
  100. //向上滑动未超过半个屏幕高的时候开启向下弹动动画
  101. startBounceAnim(this.getScrollY(),-this.getScrollY(),1000);
  102. }
  103. }
  104. break;
  105. }
  106. returnsuper.onTouchEvent(event);
  107. }
  108. @Override
  109. publicvoidcomputeScroll(){
  110. if(mScroller.computeScrollOffset()){
  111. scrollTo(mScroller.getCurrX(),mScroller.getCurrY());
  112. Log.i("scroller","getCurrX()="+mScroller.getCurrX()
  113. +"getCurrY()="+mScroller.getCurrY()
  114. +"getFinalY()="+mScroller.getFinalY());
  115. //不要忘记更新界面
  116. postInvalidate();
  117. }else{
  118. if(mCloseFlag){
  119. this.setVisibility(View.GONE);
  120. }
  121. }
  122. }
  123. }

View中的scrollTo函数,使View具有滚动效果,就像ListView一样,它的内容是可以滑动的,ViewGroup继承View,所以Relativelayout可以做到滑动效果,另外向下弹动效果是用到Scroller类,而在构造Scroller类时加入BounceInterpolator,你也可以加入别的插值器。其实Scroller只是一个辅助View滑动的一个类,帮助View存储滑动数据的类,当view滑动时,你可以从scroller中取出滑动数据,而真实滑动运动效果其实是利用scrollTo瞬间达到目的地,View结合scroller以及scroller就可以实现这种推动门的效果。

运行Demo程序 查看效果



上面的图片是模拟器上运行的截图,看起来有点卡。其实在真机上测试的很流畅。zaker的效果基本是这个样子。

如果你想使用这个类的话,想实现这种效果的话,那么请满足下面两个条件。

1.PullDoorView match_parent占据全屏像下面这样整个项目父ViewGroup可以用Framelayout

2.PullDoorView 必须要放在界面的最上面使其可以获取touch事件



  1. <com.manymore13.scrollerdemo.PullDoorView
  2. android:id="@+id/myImage"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:background="#ddd">
  6. <Button
  7. android:id="@+id/btn_above"
  8. android:layout_width="wrap_content"
  9. android:layout_height="wrap_content"
  10. android:layout_centerInParent="true"
  11. android:text="第二层"/>
  12. <TextView
  13. android:id="@+id/tv_hint"
  14. android:layout_width="wrap_content"
  15. android:layout_height="wrap_content"
  16. android:layout_alignParentBottom="true"
  17. android:layout_centerHorizontal="true"
  18. android:layout_marginBottom="10dp"
  19. android:text="上滑可以进入首页"
  20. android:textColor="#ffffffff"
  21. android:textSize="18sp"/>
  22. </com.manymore13.scrollerdemo.PullDoorView>

因为PullDoorView是一个RelativeLayout,所以你可以发挥自己的想象在里面添加任何View或者ViewGroup,上面XML中我添加了一个button和一个textView,我想这两个View你可以再上面的动态图片中应该看到了。另外PullDoorView可以根据需要更换背景图片

你可以 PullDoorView.setBgImage(图片)

好了就写这么多,仿zaker用手向上推动的效果的实现到此为止。

点击源码下载


zhuanzihttp://blog.csdn.net/manymore13/article/details/12219687

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics