仿QQ5.0侧滑(基于ViewDragHelper实现).doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
仿QQ5.0侧滑(基于ViewDragHelper实现)

仿QQ5.0侧滑(基于ViewDragHelper实现) ①自定义控件SlidingMenu继承FrameLayout,放在FrameLayout上面的布局一层叠着者一层,通过getChildAt()可以很方便的获取到任意一层,进而控制此布局的变化。 public class SlidingMenu extends FrameLayout { private ViewDragHelper mViewDragHelper; private int mHeight;// 当前控件的高度 private int mWidhth;// 当前控件的宽度 private int mRange; // 菜单移动的距离 private ViewGroup mMenu;// 菜单内容 private ViewGroup mContent; // 主页面内容 private boolean isOpen = false;// 判断是否打开菜单 public SlidingMenu(Context context) { this(context, null); } public SlidingMenu(Context context, AttributeSet attrs) { this(context, attrs, 0); } public SlidingMenu(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); // 初始化ViewDragHelper mViewDragHelper = ViewDragHelper.create(this, callback); } } ②接下来我们在布局文件中使用我们自定的SlidingMenu,根据布局,我们一步一步实现SlidingMenu. ?xml version=1.0 encoding=utf-8? com.yitong.myslidingmenu2.view.SlidingMenu xmlns:android=/apk/res/android xmlns:tools=/tools android:id=@+id/main_slidingMenu android:layout_width=match_parent android:layout_height=match_parent android:background=@mipmap/bg android:orientation=horizontal tools:context=com.yitong.myslidingmenu2.MainActivity include layout=@layout/left_menu/ LinearLayout android:id=@+id/main_content android:layout_width=match_parent android:layout_height=match_parent android:background=@mipmap/qq android:orientation=horizontal Button android:layout_width=wrap_content android:layout_height=wrap_content android:onClick=click android:text=切换菜单/ /LinearLayout /com.yitong.myslidingmenu2.view.SlidingMenu ③如果想实现侧滑,自定义控件中必须包含两个布局,在我们的SlidingMenu中的onFinishInflate方法中加以判断,并且获取菜单和主页面。在onSizeChanged获取到??单滑出的宽和高。 @Override protected void onFinishInflate() { super.onFinishInflate(); if (getChildCount() 2) { throw new I

文档评论(0)

shuwkb + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档