1. 创建Fragment
新建一个工程,添加两个Fragment,分别为 FirstFragment、SecondFragment data:image/s3,"s3://crabby-images/8d81a/8d81ad6c16fe380d984392c64c09d2ea5f8605bc" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/d8259/d82597ee8f8c87a3405e1cc9e58637079a922af8" alt="在这里插入图片描述" fragment_first.xml 、fragment_second.xml 分别添加一个按钮: fragment_first.xml :
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".FirstFragment">
<Button
android:id="@+id/btn_go_to_second"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:text="go to Second Fragment" />
</FrameLayout>
fragment_second.xml :
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".SecondFragment">
<Button
android:id="@+id/btn_back_to_first"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:text="Back to First Fragment" />
</FrameLayout>
2. 添加Navigation
- 在res右键,new -> Android Resource File,添加Navigation
data:image/s3,"s3://crabby-images/9a295/9a295f90faffed77cd9e60af673e9964846b02f7" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/73691/73691785ffb8513ac13554e4f1b257c464699002" alt="在这里插入图片描述" - 添加Navigation,会提示 Add Project Dependency,点击 OK, 等待一会儿
data:image/s3,"s3://crabby-images/f5af9/f5af9445abe8c9acf93cac73d6bbe019d900de0a" alt="在这里插入图片描述" - 把前面添加的两个Fragment添加到Navigation中:
data:image/s3,"s3://crabby-images/5cd85/5cd8577dbfdf993ca168696a603f2996fb43e074" alt="在这里插入图片描述" - 拖拽确定Fragment的跳转关系
data:image/s3,"s3://crabby-images/711f8/711f85f010c4fb0a7f32ae2e6cfb85499c443c91" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/026a1/026a14a831dbc6cbc022bd63276b264a4eb5dfc1" alt="在这里插入图片描述" 查看Code能看出这两个箭头的意思: data:image/s3,"s3://crabby-images/56130/561309b44863f388060e1030884c6185d49d4527" alt="在这里插入图片描述"
3. activity_main中添加NavHostFragment容器
activity_main.xml 的Design模式下,选择containers -> NavHostFragment 拖到activity_main的页面中 data:image/s3,"s3://crabby-images/62109/621097867c72f69382ca46cdea7bab6d501051cb" alt="在这里插入图片描述" 会弹出选择Navigation,选择我们之前创建的my_navigation_graph data:image/s3,"s3://crabby-images/659c6/659c60629c4870e3c90cfe7951911a7e8134c3e1" alt="在这里插入图片描述" 或者直接在activity_main.xml 用代码添加NavHostFragment
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<androidx.fragment.app.FragmentContainerView
android:id="@+id/fragmentContainerView"
android:name="androidx.navigation.fragment.NavHostFragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:defaultNavHost="true"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:navGraph="@navigation/my_navigation_graph" />
</androidx.constraintlayout.widget.ConstraintLayout>
4. MainActivity.java
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
NavHostFragment navHostFragment = (NavHostFragment) getSupportFragmentManager().findFragmentById(R.id.fragmentContainerView);
NavController navController = navHostFragment.getNavController();
}
}
5. 两个Fragment之间的跳转
FirstFragment.java :
public class FirstFragment extends Fragment {
private View mFragmentView;
private Button mBtnGoToSecondFragment;
public FirstFragment() {
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
if (mFragmentView == null){
mFragmentView = inflater.inflate(R.layout.fragment_first, container, false);
mBtnGoToSecondFragment = mFragmentView.findViewById(R.id.btn_go_to_second);
mBtnGoToSecondFragment.setOnClickListener((view) -> {
NavController navController = Navigation.findNavController(view);
navController.navigate(R.id.action_firstFragment_to_secondFragment);
});
}
return mFragmentView;
}
}
SecondFragment.java :
public class SecondFragment extends Fragment {
private View mFragmentView;
private Button mBtnBackToFirstFragment;
public SecondFragment() {
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
if (mFragmentView == null){
mFragmentView = inflater.inflate(R.layout.fragment_second, container, false);
mBtnBackToFirstFragment = mFragmentView.findViewById(R.id.btn_back_to_first);
mBtnBackToFirstFragment.setOnClickListener((view) -> {
NavController navController = Navigation.findNavController(view);
navController.navigate(R.id.action_secondFragment_to_firstFragment);
});
}
return mFragmentView;
}
}
data:image/s3,"s3://crabby-images/3de86/3de86700fe6250d0f7721b31b4286b7fa29601a8" alt="在这里插入图片描述"
6. 效果
data:image/s3,"s3://crabby-images/03692/036928d61d1e87bf03d1d88d40fc334c63b99cca" alt="在这里插入图片描述"
7. 示例代码
https://gitee.com/jie-xio/android_samples/tree/master/Navigation/Navigation
关于Navigation更详细的说明,参考Android官方文档:https://developer.android.google.cn/guide/navigation?hl=zh-cn
|