- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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)