Android两侧推出导航菜单的实现

前几天发表了 这篇文章:Android左侧推出导航的简单实现

 

昨天又有人问我如何实现两侧都能够推出导航菜单,我想了一下,其实也很简单,修改了一下代码很容易的实现了这个需求。

 

整个菜单可以通过触碰的方式展开,也可以通过按钮方式,而且菜单的宽度是根据组件宽度自适应。

 

有需要的同学可以下载附件

 




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现 Android 左侧推出导航的方法有很多,以下是其中一种简单的实现方式: 1.在布局文件中定义侧滑菜单布局(例如一个侧滑菜单的 LinearLayout)和主布局(例如一个 FrameLayout)。 2.在主布局上加入一个菜单按钮,用于触发侧滑菜单的显示和隐藏。 3.在主布局中加入一个手势控件,例如 DrawerLayout,用于监听手势事件,以判断用户是否想要打开或关闭侧滑菜单。 4.在代码中处理手势事件,当用户向右滑动时,打开侧滑菜单;当用户向左滑动时,关闭侧滑菜单。 5.在菜单按钮上添加点击事件,用于触发侧滑菜单的显示和隐藏。 6.在菜单布局中添加菜单项,并为每个菜单项添加点击事件,用于处理用户的操作。 具体实现细节可以参考以下代码: 布局文件: ``` <android.support.v4.widget.DrawerLayout android:id="@+id/drawer_layout" android:layout_width="match_parent" android:layout_height="match_parent"> <!-- 主布局 --> <FrameLayout android:id="@+id/content_frame" android:layout_width="match_parent" android:layout_height="match_parent" /> <!-- 侧滑菜单布局 --> <LinearLayout android:id="@+id/left_drawer" android:layout_width="240dp" android:layout_height="match_parent" android:layout_gravity="start" android:background="@android:color/white" android:orientation="vertical"> <!-- 菜单项 --> <TextView android:id="@+id/menu_item1" android:layout_width="match_parent" android:layout_height="wrap_content" android:padding="16dp" android:text="菜单项1" /> <TextView android:id="@+id/menu_item2" android:layout_width="match_parent" android:layout_height="wrap_content" android:padding="16dp" android:text="菜单项2" /> </LinearLayout> </android.support.v4.widget.DrawerLayout> ``` 代码: ``` public class MainActivity extends AppCompatActivity { private DrawerLayout mDrawerLayout; // 抽屉布局 private LinearLayout mLeftDrawer; // 左侧滑菜单 private FrameLayout mContentFrame; // 主布局 private Button mMenuButton; // 菜单按钮 @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 初始化控件 mDrawerLayout = findViewById(R.id.drawer_layout); mLeftDrawer = findViewById(R.id.left_drawer); mContentFrame = findViewById(R.id.content_frame); mMenuButton = findViewById(R.id.menu_button); // 设置菜单按钮点击事件 mMenuButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { if (mDrawerLayout.isDrawerOpen(mLeftDrawer)) { mDrawerLayout.closeDrawer(mLeftDrawer); } else { mDrawerLayout.openDrawer(mLeftDrawer); } } }); // 设置手势监听器,用于打开和关闭侧滑菜单 mDrawerLayout.addDrawerListener(new DrawerLayout.SimpleDrawerListener() { @Override public void onDrawerSlide(View drawerView, float slideOffset) { super.onDrawerSlide(drawerView, slideOffset); mContentFrame.setTranslationX(slideOffset * drawerView.getWidth()); } @Override public void onDrawerClosed(View drawerView) { super.onDrawerClosed(drawerView); mContentFrame.setTranslationX(0); } @Override public void onDrawerOpened(View drawerView) { super.onDrawerOpened(drawerView); mContentFrame.setTranslationX(drawerView.getWidth()); } }); // 设置菜单项点击事件 TextView menuItem1 = findViewById(R.id.menu_item1); TextView menuItem2 = findViewById(R.id.menu_item2); menuItem1.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 处理菜单项1的操作 } }); menuItem2.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 处理菜单项2的操作 } }); } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值