Android提高之多方向抽屉实现方法

所属分类: 软件编程 / Android 阅读数: 247
收藏 0 赞 0 分享

说起在android上要实现类似Launch的抽屉效果,大家一定首先会想起SlidingDrawer。SlidingDrawer是android官方控件之一,但是本文的主角并不是它,而是民间的控件工具集合:android-misc-widgets。android-misc-widgets里面包含几个widget:Panel、SmoothButton、Switcher、VirtualKeyboard,还有一些动画特效,本文主要介绍抽屉容器Panel的用法。android-misc-widgets的google工程地址:-widgets/http://code.google.com/p/android-misc。

工程代码中Panel的演示效果如下所示:

这个Panel控件可以轻易实现不同方向的抽屉效果,比SlidingDrawer有更强的扩展性!

在多次使用Panel的过程中,发现Panel有个bug,会间断性出现“闪烁”,也就是在onTouchListener里面的触发ACTION_DOWN后,抽屉瞬间弹出然后瞬间回收(版本日期为Feb 3, 2009)。把原Panel的OnTouchListener加以替换,即以下代码:

OnTouchListener touchListener = new OnTouchListener() {
 int initX;
 int initY;
 boolean setInitialPosition;
 public boolean onTouch(View v, MotionEvent event) {
 if (mState == State.ANIMATING) {
  // we are animating
  return false;
 }
//  Log.d(TAG, "state: " + mState + " x: " + event.getX() + " y: " + event.getY());
 int action = event.getAction();
 if (action == MotionEvent.ACTION_DOWN) {
  if (mBringToFront) {
  bringToFront();
  }
  initX = 0;
  initY = 0;
  if (mContent.getVisibility() == GONE) {
  // since we may not know content dimensions we use factors here
  if (mOrientation == VERTICAL) {
   initY = mPosition == TOP? -1 : 1;
  } else {
   initX = mPosition == LEFT? -1 : 1;
  }
  }
  setInitialPosition = true;
 } else {
  if (setInitialPosition) {
  // now we know content dimensions, so we multiply factors...
  initX *= mContentWidth;
  initY *= mContentHeight;
  // ... and set initial panel's position
  mGestureListener.setScroll(initX, initY);
  setInitialPosition = false;
  // for offsetLocation we have to invert values
  initX = -initX;
  initY = -initY;
  }
  // offset every ACTION_MOVE & ACTION_UP event 
  event.offsetLocation(initX, initY);
 }
 if (!mGestureDetector.onTouchEvent(event)) {
  if (action == MotionEvent.ACTION_UP) {
  // tup up after scrolling
  post(startAnimation);
  }
 }
 return false;
 }
};

替换为:

OnTouchListener touchListener = new OnTouchListener() {
 float touchX, touchY;
 public boolean onTouch(View v, MotionEvent event) {
 if (mState == State.ANIMATING) {
  // we are animating
  return false;
 }
 int action = event.getAction();
 if (action == MotionEvent.ACTION_DOWN) {
  if (mBringToFront) {
  bringToFront();
  }
  touchX = event.getX();
  touchY = event.getY();
 }
 if (!mGestureDetector.onTouchEvent(event)) {
  if (action == MotionEvent.ACTION_UP) {
  // tup up after scrolling
  int size = (int) (Math.abs(touchX - event.getX()) + Math
   .abs(touchY - event.getY()));
  if (size == mContentWidth || size == mContentHeight) {
   mState = State.ABOUT_TO_ANIMATE;
   //Log.e("size", String.valueOf(size));
   //Log.e(String.valueOf(mContentWidth),String.valueOf(mContentHeight));
  }
  post(startAnimation);
  }
 }
 return false;
 }
};

即可修复这个bug,并且也同样实现了OnClickListener的功能,可以把原Panel的OnClickListener给删掉了!

希望本文所述实例对于大家进行Android项目开发能有所帮助。

更多精彩内容其他人还在看

Android异常 java.lang.IllegalStateException解决方法

这篇文章主要介绍了Android异常 java.lang.IllegalStateException解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android中Split()字符串分割特殊用法案例详解

本文通过案例的形式给大家详细介绍了android中split()字符串分割特殊用法的知识,非常不错具有参考借鉴价值,感兴趣的朋友参考下
收藏 0 赞 0 分享

Android仿新浪微博启动界面或登陆界面(1)

这篇文章主要为大家详细介绍了Android仿新浪微博启动界面或登陆界面的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android仿新浪微博oauth2.0授权界面实现代码(2)

这篇文章主要为大家详细介绍了Android仿新浪微博oauth2.0授权界面实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android开发中使用sqlite实现新闻收藏和取消收藏的功能

本篇文章主要介绍了sqlite实现新闻收藏和取消收藏功能,主要涉及到oracle数据库方面的内容,对于Android开发sqlite实现收藏和取消功能感兴趣的朋友可以参考下本文
收藏 0 赞 0 分享

Android仿新浪微博分页管理界面(3)

这篇文章主要为大家详细介绍了Android仿新浪微博分页管理界面,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android UI自定义ListView实现下拉刷新和加载更多效果

这篇文章主要介绍了Android UI自定义ListView实现下拉刷新和加载更多效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android—基于微信开放平台v3SDK开发(微信支付填坑)

这篇文章主要介绍了Android—基于微信开放平台v3SDK开发(微信支付填坑),具有一定的参考价值,有需要的可以了解一下。
收藏 0 赞 0 分享

Android仿新浪微博自定义ListView下拉刷新(4)

这篇文章主要为大家详细介绍了Android仿新浪微博自定义ListView下拉刷新,重点介绍了Adapter的详细代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android控件之使用ListView实现时间轴效果

这篇文章主要介绍了Android基础控件之使用ListView实现时间轴效果的相关资料,本文是以查看物流信息为例,给大家介绍了listview时间轴的实现代码,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多