Fragment
- Fragment 可以视为 Activity 的一个片段,它具有自己的生命周期和接收事件的能力,它有以下特点
-
Fragment 依赖于 Activity,不能独立存在,Fragment 的生命周期受 Activity 的生命周期影响
-
Fragment 将 Activity 的 UI 和功能划分为更小的模块,便于管理维护
-
多个 Activity 可以重用同一个 Fragment,一个 Activity 也可以使用多个 Fragment
-
Fragment 可以动态地添加、移除、替换、隐藏,实现复杂的界面交互效果
创建 Fragment
1、通过 Android Studio 创建 Fragment
- 右击【包】 -> 【New】 -> 【Fragment】 -> 【Fragment(Blank)】,对于 Fragment Java 文件,命名尽量为
【Xxx】Fragment
,对于 Fragment XML 文件,命名尽量为fragment_【xxx】
- Android Studio 会自动在【包】下创建 Fragment Java 文件,在【layout 目录】下创建 Fragment XML 文件
/**
* A simple {@link Fragment} subclass.
* Use the {@link TestAFragment#newInstance} factory method to
* create an instance of this fragment.
*/
public class TestAFragment extends Fragment {
// TODO: Rename parameter arguments, choose names that match
// the fragment initialization parameters, e.g. ARG_ITEM_NUMBER
private static final String ARG_PARAM1 = "param1";
private static final String ARG_PARAM2 = "param2";
// TODO: Rename and change types of parameters
private String mParam1;
private String mParam2;
public TestAFragment() {
// Required empty public constructor
}
/**
* Use this factory method to create a new instance of
* this fragment using the provided parameters.
*
* @param param1 Parameter 1.
* @param param2 Parameter 2.
* @return A new instance of fragment TestAFragment.
*/
// TODO: Rename and change types and number of parameters
public static TestAFragment newInstance(String param1, String param2) {
TestAFragment fragment = new TestAFragment();
Bundle args = new Bundle();
args.putString(ARG_PARAM1, param1);
args.putString(ARG_PARAM2, param2);
fragment.setArguments(args);
return fragment;
}
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
if (getArguments() != null) {
mParam1 = getArguments().getString(ARG_PARAM1);
mParam2 = getArguments().getString(ARG_PARAM2);
}
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// Inflate the layout for this fragment
return inflater.inflate(R.layout.fragment_test_a, container, false);
}
}
<?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=".fragment.TestAFragment">
<!-- TODO: Update blank fragment layout -->
<TextView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:text="@string/hello_blank_fragment" />
</FrameLayout>
- 对 Android Studio 自动创建的文件修修改改,在 Fragment Java 文件去除多余的代码和注释,在 Fragment XML 文件中修改控件(这里我更喜欢用 ConstraintLayout 控件),最后得到一个 Fragment 的框架
public class TestAFragment extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
return inflater.inflate(R.layout.fragment_test_a, container, false);
}
}
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 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=".fragment.TestAFragment">
</androidx.constraintlayout.widget.ConstraintLayout>
2、手动创建 Fragment
- 右击【layout 目录】 -> 【New】 -> 【file】,创建 Fragment XML 文件,该文件命名尽量为
fragment_【xxx】.xml
- 对于 Fragment Java 文件,继承 Fragment,实现 onCreateView 方法
public class TestBFragment extends Fragment {
@Nullable
@Override
public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
return inflater.inflate(R.layout.fragment_test_b, container, false);
}
}
-
右击【包】 -> 【New】 -> 【Java Class】,创建 Fragment Java 文件,该文件命名尽量为
【Xxx】Fragment
-
对于 Fragment Xml 文件,添加控件(这里我更喜欢用 ConstraintLayout 控件)
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 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=".fragment.TestBFragment">
</androidx.constraintlayout.widget.ConstraintLayout>