美文网首页
android 侧滑回退 导航 模仿iOS的Navigation

android 侧滑回退 导航 模仿iOS的Navigation

作者: lidajun | 来源:发表于2017-11-09 13:39 被阅读61次

用过iOS都知道iOS大多app都可以划动界面回退到一下页面,这个是iOS官方提供的一个叫NavigationController的功能。想实现一个一样的,找github,没找到合适了。自己写一个分享出来吧。
实现原理很简单,就是使用fragment和activty。如果你也是使用fragment来管理你的页面可以试试。

1:添加gradle

repositories {
    jcenter()
}

compile 'com.github.lidajun.android:navigation-controller:1.1.1'

2:如果每个Fragment都有一个标题,并想要侧滑时有一个标题的动画,可以使用NavigationToolbar。不使用请忽略

<com.github.lidajun.android.navigationcontroller.widget.NavigationToolbar
    android:id="@+id/toolbar"
    android:layout_width="match_parent"
    android:layout_height="50dp"/>

Toolbar可选属性

<attr name="title_view_text_size" format="float"/>
<attr name="back_view_text_size" format="float"/>
<attr name="title_view_text_color" format="color"/>
<attr name="back_view_text_color" format="color"/>
<attr name="title_view_text" format="string"/>
<attr name="back_view_text" format="string"/>

可以在fragment中给你的toolbar添加一个title

setToolbarTitle("FragmentA");

3:让你的包含Fragment的Activity继承NavigationActivity或NavigationActivityV4
区别就是你是不是使用的v4包的fragment
如果使用NavigationToolbar就在initNavigationToolbar返回你的toolbar,没有使用就return null;

@Override
protected NavigationToolbar initNavigationToolbar() {
   NavigationToolbar toolbar = (NavigationToolbar) findViewById(R.id.toolbar);
   setSupportActionBar(toolbar);
   return toolbar;
}

例如:添加fragment:

((NavigationActivity) getActivity()).addAndCommitFragment(R.id.frameLayout, new FragmentB());

4:让你的fragment继承NavigationFragment或NavigationFragmentV4
其它:
你可以通过viewChange(float page)方法获得fragment的滑动,比0开始。不使用请忽略

    public void viewChange(float page) {
    }

github地址:
https://github.com/lidajun/NavigationController

demo.gif

相关文章

网友评论

      本文标题:android 侧滑回退 导航 模仿iOS的Navigation

      本文链接:https://www.haomeiwen.com/subject/bmbpmxtx.html