Я настроил ViewPager2 с TabLayout, чтобы переключать фрагменты с помощью пролистывания или нажатия на вкладки. Проблема, которую я знаю, состоит в том, что мои фрагменты не занимают все пространство, и у меня есть свободное место внизу, где я не могу провести. Как я могу сделать свои фрагменты, чтобы заполнить это пространство?
Редактировать: Я думаю, что моя проблема связана с тем фактом, что я пытаюсь загрузить свой просмотрщик внутри другого фрагмента. Я скопировал свой код в новый проект и вместо загрузки своего кода во фрагмент я загрузил его в основной вид деятельности, и он сработал. Это плохая практика для загрузки виджетов внутри фрагмента?
Я изменил свой ProfileFragment.kt , как это, но он все еще не работает:
class ProfileFragment : Fragment() {
private lateinit var tabsText: List<String>
private val adapter by lazy {
ViewPagerAdapter(childFragmentManager, lifecycle)
}
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
tabsText = listOf<String>(getString(R.string.user_info),
getString(R.string.saved_recipes), getString(R.string.shopping_list))
}
override fun onCreateView(
inflater: LayoutInflater,
container: ViewGroup?,
savedInstanceState: Bundle?
): View? {
return inflater.inflate(R.layout.fragment_profile, container, false)
}
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
super.onViewCreated(view, savedInstanceState)
pager.adapter = adapter
TabLayoutMediator(tabs, pager) { tab, position ->
tab.text = tabsText.get(position)
}.attach()
}
}
class ViewPagerAdapter(manager: FragmentManager, lifecycle: Lifecycle): FragmentStateAdapter(manager, lifecycle) {
override fun getItemCount(): Int = 3
override fun createFragment(position: Int): Fragment = when(position) {
0 -> UserInfoFragment.newInstance()
1 -> SavedRecipesFragment.newInstance()
else -> ShoppingListFragment.newInstance()
}
}
фрагмент_профиля. xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:orientation="vertical">
<com.google.android.material.tabs.TabLayout
android:id="@+id/tabs"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:tabMode="fixed"/>
<androidx.viewpager2.widget.ViewPager2
android:id="@+id/pager"
android:layout_width="match_parent"
android:layout_height="wrap_content"/>
</LinearLayout>
ProfileFragment.kt
class ProfileFragment : Fragment() {
private lateinit var tabsText: List<String>
private val adapter by lazy {
ViewPagerAdapter(this)
}
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
tabsText = listOf<String>(getString(R.string.user_info),
getString(R.string.saved_recipes), getString(R.string.shopping_list))
}
override fun onCreateView(
inflater: LayoutInflater,
container: ViewGroup?,
savedInstanceState: Bundle?
): View? {
return inflater.inflate(R.layout.fragment_profile, container, false)
}
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
super.onViewCreated(view, savedInstanceState)
pager.adapter = adapter
TabLayoutMediator(tabs, pager) { tab, position ->
tab.text = tabsText.get(position)
}.attach()
}
}
class ViewPagerAdapter(fragment: Fragment): FragmentStateAdapter(fragment) {
override fun getItemCount(): Int = 3
override fun createFragment(position: Int): Fragment = when(position) {
0 -> UserInfoFragment.newInstance()
1 -> SavedRecipesFragment.newInstance()
else -> ShoppingListFragment.newInstance()
}
}
Один из загружаемых мной фрагментов имеет это xml: frag_user_info. xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:orientation="vertical"
android:padding="8dp">
<TextView
android:id="@+id/username_text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:drawableTop="@drawable/ic_account_circle_black_56dp"
android:text="@string/username" />
<com.google.android.material.textfield.TextInputLayout
android:id="@+id/init_info_age"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@id/username_text"
android:layout_marginTop="8dp"
style="@style/Widget.MaterialComponents.TextInputLayout.OutlinedBox"
android:hint="@string/age"
app:helperTextEnabled="true"
app:helperText="@string/fui_required_field">
<com.google.android.material.textfield.TextInputEditText
android:id="@+id/init_info_age_editText"
android:inputType="number"
android:layout_width="match_parent"
android:layout_height="wrap_content"
/>
</com.google.android.material.textfield.TextInputLayout>
<LinearLayout
android:id="@+id/linear_layout1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:baselineAligned="false"
android:layout_below="@id/init_info_age">
<com.google.android.material.textfield.TextInputLayout
android:id="@+id/profile_info_height"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:layout_marginTop="8dp"
android:layout_marginEnd="8dp"
style="@style/Widget.MaterialComponents.TextInputLayout.OutlinedBox"
android:hint="@string/height"
app:helperTextEnabled="true"
app:helperText="@string/fui_required_field"
>
<com.google.android.material.textfield.TextInputEditText
android:id="@+id/profile_info_height_editText"
android:inputType="number"
android:layout_width="match_parent"
android:layout_height="wrap_content"
/>
</com.google.android.material.textfield.TextInputLayout>
<com.google.android.material.textfield.TextInputLayout
android:id="@+id/profile_info_weight"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:layout_marginTop="8dp"
style="@style/Widget.MaterialComponents.TextInputLayout.OutlinedBox"
android:hint="@string/weight"
app:helperTextEnabled="true"
app:helperText="@string/fui_required_field"
>
<com.google.android.material.textfield.TextInputEditText
android:id="@+id/profile_info_weight_editText"
android:inputType="number"
android:layout_width="match_parent"
android:layout_height="wrap_content"
/>
</com.google.android.material.textfield.TextInputLayout>
</LinearLayout>
<LinearLayout
android:id="@+id/linear_layout2"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:baselineAligned="false"
android:layout_below="@id/linear_layout1">
<com.google.android.material.textfield.TextInputLayout
android:id="@+id/profile_gender"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:layout_marginTop="8dp"
style="@style/Widget.MaterialComponents.TextInputLayout.OutlinedBox.ExposedDropdownMenu"
android:hint="@string/gender"
>
<AutoCompleteTextView
android:id="@+id/autocomplete_view_gender"
android:labelFor="@id/profile_gender"
android:layout_height="wrap_content"
android:layout_width="wrap_content"
tools:ignore="LabelFor" />
</com.google.android.material.textfield.TextInputLayout>
<com.google.android.material.textfield.TextInputLayout
android:id="@+id/profile_lifestyle"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:layout_marginTop="8dp"
style="@style/Widget.MaterialComponents.TextInputLayout.OutlinedBox.ExposedDropdownMenu"
android:hint="@string/activity"
>
<AutoCompleteTextView
android:id="@+id/autocomplete_view_lifestyle"
android:labelFor="@id/profile_gender"
android:layout_height="wrap_content"
android:layout_width="wrap_content"
tools:ignore="LabelFor" />
</com.google.android.material.textfield.TextInputLayout>
</LinearLayout>
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/edit"
android:layout_below="@id/linear_layout2"
android:layout_alignParentEnd="true"/>
</RelativeLayout>
