效果图:
SlideActivity.java:
package com.demo.slide; import android.app.Activity; import android.os.Bundle; import android.view.View; import android.view.Window; import com.demo.broadcast.R; public class SlideActivity extends Activity { private SlidingMenu mLeftMenu ; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); requestWindowFeature(Window.FEATURE_NO_TITLE); setContentView(R.layout.slide_main); mLeftMenu = (SlidingMenu) findViewById(R.id.id_menu); } public void toggleMenu(View view) { mLeftMenu.toggle(); } }
SlidingMenu.java:
package com.demo.slide; import android.content.Context; import android.util.AttributeSet; import android.util.DisplayMetrics; import android.util.TypedValue; import android.view.MotionEvent; import android.view.ViewGroup; import android.view.WindowManager; import android.widget.HorizontalScrollView; import android.widget.LinearLayout; public class SlidingMenu extends HorizontalScrollView { private LinearLayout mWapper; private ViewGroup mMenu; private ViewGroup mContent; private int mScreenWidth; private int mMenuWidth; // dp private int mMenuRightPadding = 80; private boolean once; private boolean isOpen; /** * 未使用自定义属性时,调用 * * @param context * @param attrs */ public SlidingMenu(Context context, AttributeSet attrs) { this(context, attrs, 0); } /** * 当使用了自定义属性时,会调用此构造方法 * * @param context * @param attrs * @param defStyle */ public SlidingMenu(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); WindowManager wm = (WindowManager) context .getSystemService(Context.WINDOW_SERVICE); DisplayMetrics outMetrics = new DisplayMetrics(); wm.getDefaultDisplay().getMetrics(outMetrics); mScreenWidth = outMetrics.widthPixels; mMenuRightPadding = (int) TypedValue.applyDimension( TypedValue.COMPLEX_UNIT_DIP, 50, context .getResources().getDisplayMetrics()); } public SlidingMenu(Context context) { this(context, null); } /** * 设置子View的宽和高 设置自己的宽和高 */ @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { if (!once) { mWapper = (LinearLayout) getChildAt(0); mMenu = (ViewGroup) mWapper.getChildAt(0); mContent = (ViewGroup) mWapper.getChildAt(1); mMenuWidth = mMenu.getLayoutParams().width = mScreenWidth - mMenuRightPadding; mContent.getLayoutParams().width = mScreenWidth; once = true; } super.onMeasure(widthMeasureSpec, heightMeasureSpec); } /** * 通过设置偏移量,将menu隐藏 */ @Override protected void onLayout(boolean changed, int l, int t, int r, int b) { super.onLayout(changed, l, t, r, b); if (changed) { this.scrollTo(mMenuWidth, 0); } } @Override public boolean onTouchEvent(MotionEvent ev) { int action = ev.getAction(); switch (action) { case MotionEvent.ACTION_UP: // 隐藏在左边的宽度 int scrollX = getScrollX(); if (scrollX >= mMenuWidth / 2) { this.smoothScrollTo(mMenuWidth, 0); isOpen = false; } else { this.smoothScrollTo(0, 0); isOpen = true; } return true; } return super.onTouchEvent(ev); } /** * 打开菜单 */ public void openMenu() { if (isOpen) return; this.smoothScrollTo(0, 0); isOpen = true; } public void closeMenu() { if (!isOpen) return; this.smoothScrollTo(mMenuWidth, 0); isOpen = false; } /** * 切换菜单 */ public void toggle() { if (isOpen) { closeMenu(); } else { openMenu(); } } }
slide_main.xml:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" > <com.demo.slide.SlidingMenu android:id="@+id/id_menu" android:layout_width="match_parent" android:layout_height="match_parent" > <LinearLayout android:layout_width="wrap_content" android:layout_height="match_parent" android:orientation="horizontal" > <include layout="@layout/left_menu" /> <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:background="#ffffff" > <Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:onClick="toggleMenu" android:text="切换" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:layout_marginLeft="20dp" android:text="我是主content" android:textColor="#ff00ff" android:textSize="20sp" /> </LinearLayout> </LinearLayout> </com.demo.slide.SlidingMenu> </RelativeLayout>
left_menu.xml:
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#000000" > <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_centerInParent="true" android:orientation="vertical" > <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="20dp" android:text="我是左侧Menu" android:textColor="#ffffff" android:textSize="20sp" /> </LinearLayout> </RelativeLayout>
相关推荐
NULL 博文链接:https://chenzheng8975.iteye.com/blog/2057024
使用Toolbar工具来实现DrawerLayout左侧滑动菜单;Menu实现方式:PopupMenu
android左侧或右侧可选滑动菜单
Android左侧滑动菜单右侧Content 一个简单的例子,可以做出像QQ和人人的UI设计中左侧可以滑动显示出隐藏的菜单,右侧的内容随之改变的效果 是eclipse工程文档,直接导入即可。
主要实现左右滑动菜单效果,他可以点击主界面上的按钮来显示左右菜单,也可以通过左右滑动来显示,希望可以帮到你哦!!
android 左边抽屉式菜单,具有滑动效果,可以自己调整速度,感觉还可以,分享一下~
Android项目导航菜单横向左右滑动并和下方的控件实现联动.rar
android滑动菜单,实现了 左边滑动和右边滑动
摘要:Java源码,Android源码,滑动菜单,滚动视图 Android版SlidingMenu滑动菜单 - 实现手动、自动滚动视图,提供右侧显示视图,右侧视图的滑动区域,只能在左侧视图范围内滑动,每次滑动记录一次移动位置,用于计算...
自定义ViewGroup实现左侧菜单的滑动效果
在主界面手指向右滑动,就可以将菜单展示出来,而主界面会被隐藏大部分,但是仍有左侧的一小部分同菜单一起展示。
人人客户端有一个特效还是挺吸引人的,在主界面手指向右滑动,就可以将菜单展示出来,而主...但其实这种效果并不难实现,因此我今天给大家带来的也是史上最简单的滑动菜单实现方案。 首先还是讲一下实现原理。在一个A
改造LayoutManager实现弧形滚动和中间放大的效果
安卓Android源码——导航菜单横向左右滑动并和下方的控件实现联动.rar
简单实用,很多代码很杂乱,为实现这种小功能网上许多代码是掺杂了各种各样的其他代码,很难读懂,小编简化了侧滑菜单的功能,自己实现了这一单一功能,以便下载者设计更加丰富的样式。
摘要:Java源码,Android源码,滑动菜单 Android滑动菜单制作RenRenSlidingLayout源代码,侧滑布局对象,用于通过手指滑动将左侧的菜单布局进行显示或隐藏,menu按钮,点击按钮展示左侧布局,再点击一次隐藏左侧布局,...
BidirSlidingLayout.java为双向滑动菜单框架,在这里可以设置滚动显示和隐藏左侧布局时,手指滑动需要达到的速度、记录当前的滑动状态、是否正在滑动等。左侧和右侧菜单当前是显示还是隐藏。只有完全显示或隐藏时才...
最近想实现Android左滑弹出菜单框,右滑消失菜单这个个功能。了解了一下Android 的滑动事件,必须是在view组件或者Activity上实现,同时必须实现OnTouchListener, OnGestureListener这个两个接口。 public class ...
android类似人人网的左边菜单滑动效果,点击首界面的左边按钮,则显示左边菜单栏,而此时首界面只显示左边的一小部分。点击菜单,回到首界面。 现在很多应用都采用这种效果