Как обращаться с переключателем ящиков и панелью инструментов при наличии панели инструментов для каждого фрагмента
Я использую единую активность и много фрагментов в моем приложении
Теперь, когда в моих фрагментах у меня есть пользовательский вид на панели инструментов, я решил создать отдельную панель инструментов для каждого фрагмента.
Как реализовать отдельную панель инструментов для каждого фрагмента, а макет ящика - в моей деятельности
![category page]()
Ответы
Ответ 1
У меня такая же проблема, я добавлю индивидуальное представление панели инструментов для каждого фрагмента.
Мой метод Utility:
public static View addRemoveViewFromToolbar(FragmentActivity fragmentActivity, int resourceId) {
Toolbar toolbar = removeViewFromToolbar(fragmentActivity);
if (resourceId == 0) {
return null;
} else {
View view = LayoutInflater.from(fragmentActivity).inflate(resourceId, toolbar, false);
toolbar.addView(view);
return view;
}
}
public static Toolbar removeViewFromToolbar(FragmentActivity fragmentActivity) {
Toolbar toolbar = (Toolbar) fragmentActivity.findViewById(R.id.toolbar);
if (toolbar.getChildCount() > 1) {
for (int i = 1; i <= toolbar.getChildCount(); i++) {
toolbar.removeViewAt(1);
}
}
return toolbar;
}
В моем каждом фрагменте
//Create your custom view based on requirement
View view = Utility.addRemoveViewFromToolbar(getActivity(), R.layout.toolbar_search_view);
if (view != null) {
edtCategory1 = (EditText) view.findViewById(R.id.edtCategory1);
edtCategory1.setOnClickListener(this);
}
Надеюсь, что это объяснение поможет вам:)
Ответ 2
Я не уверен, правильно ли я понял ваше описание вашего приложения, но недавно сделал то, что, по вашему мнению, вы описали.
Мой макет активности был DrawerLayout с включенным расписанием CoordinatorLayout/AppBar с одной панелью инструментов и FrameLayout ниже. В menu.xml содержались все элементы, которые мне нужны на панели инструментов для всех фрагментов. Элементы, нажатые в навигационном меню, будут заменять фрагменты в FrameLayout. Мой onNavigationItemSelected() вызвал этот метод для замены фрагментов и обработки стоп-кадра:
public void switchView(int id, int optArg) {
if (currentView != id) {
currentView = id; //currentView keeps track of which fragment is loaded
FragmentTransaction transaction = getFragmentManager().beginTransaction();
//Fragment contentFragment is the current fragment in the FrameLayout
switch (id) {
case 0: //menu item 1
contentFragment = new Nav_Item1_Fragment();
transaction.replace(R.id.fragment_container, contentFragment, "");
break;
case 1: //menu item 2
contentFragment = new Nav_Item2_Fragment();
transaction.replace(R.id.fragment_container, contentFragment, "");
break;
case 2: //menu item 3
contentFragment = new Nav_Item3_Fragment();
transaction.replace(R.id.fragment_container, contentFragment, "");
break;
}
// Replace whatever is in the fragment_container view with this fragment,
// and add the transaction to the back stack
// transaction.replace(R.id.fragment_container, contentFragment);
transaction.addToBackStack(null);
// Commit the transaction
transaction.commit();
}
}
и в каждом фрагменте onPrepareOptionsMenu() я setVisible() hid/отображает пункты меню на панели инструментов, связанные с этим фрагментом. У каждого элемента был метод в действии, на который указывает атрибут atClick элемента, который знал, из какого фрагмента он был и какие представления были переданы ему.
Ящик был настроен в onCreate() активности с помощью ActionBarDrawerToggle следующим образом:
drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close);
drawer.addDrawerListener(toggle);
toggle.syncState();
активность xml:
<android.support.v4.widget.DrawerLayout
android:id="@+id/drawer_layout"
...>
<include
layout="@layout/app_bar_main"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
<android.support.design.widget.NavigationView
android:id="@+id/nav_view"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
android:fitsSystemWindows="true"
.../>
</android.support.v4.widget.DrawerLayout>
app_bar_main.xml
<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
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"
...>
<android.support.design.widget.AppBarLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
...>
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:gravity="top"
.../>
</android.support.design.widget.AppBarLayout>
<FrameLayout
android:id="@+id/fragment_container"
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior">
</FrameLayout>
</android.support.design.widget.CoordinatorLayout>
Итак... Одно меню Nav, одна панель приложений/инструментов, несколько фрагментов
Ответ 3
Почему вы специально хотите отдельную панель инструментов для каждого фрагмента?
Вы можете легко изменить представление панели инструментов для каждого фрагмента.
В вашей функции для переключения фрагментов -
public void selectDrawerItem(MenuItem item) {
FragmentManager fragmentManager = getSupportFragmentManager();
FragmentTransaction fragmentTransaction;
switch (item.getItemId()) {
case R.id.nav_home :
getSupportActionBar().setCustomView(R.layout.home_nav_bar);
fragmentClass = HomeFragment.class;
break;
case R.id.nav_settings :
getSupportActionBar().setCustomView(R.layout.settings_nav_bar);
fragmentClass = SettingsFragment.class;
break;
}
fragment = (Fragment) fragmentClass.newInstance();
fragmentManager.popBackStack(null,
FragmentManager.POP_BACK_STACK_INCLUSIVE);
fragmentTransaction = fragmentManager.beginTransaction();
fragmentTransaction.replace(R.id.fragment_container, fragment);
fragmentTransaction.addToBackStack(null);
fragmentTransaction.commit();
}
Таким образом, вы можете легко использовать ту же панель инструментов и настроить ее в соответствии с вашими требованиями для каждого фрагмента.
Ответ 4
Это можно сделать довольно просто.
-
Сначала создайте действие с помощью drawerlayout
.
-
Во-вторых создайте контейнер viewpager
внутри выполняемой операции
fragments
-
Третий реализует слушателя на вашем viewpager
, который установит
соответствующий toolbar
на основе отображаемого fragment
.
Позвольте мне проиллюстрировать соответствующие XML и код
Сначала XML drawerlayout
для основного действия
<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.DrawerLayout
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:id="@+id/drawer_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
tools:openDrawer="start">
<include
layout="@layout/app_bar_landing_page"
android:layout_width="match_parent"
android:layout_height="match_parent" />
<android.support.design.widget.NavigationView
android:id="@+id/nav_view"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
android:fitsSystemWindows="true"
app:headerLayout="@layout/nav_header_landing_page"
app:menu="@menu/activity_landing_page_drawer" />
</android.support.v4.widget.DrawerLayout>
Обратите внимание на расположение контейнера app_bar_landing_page
. Теперь XML для этого
<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout 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="me.veganbuddy.veganbuddy.ui.LandingPage">
<android.support.design.widget.AppBarLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:theme="@style/AppTheme.AppBarOverlay">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary"
android:elevation="4dp"
app:logo="@drawable/vegan_buddy_menu_icon"
app:popupTheme="@style/AppTheme.PopupOverlay" />
</android.support.design.widget.AppBarLayout>
<android.support.v4.view.ViewPager
android:id="@+id/container_for_fragments"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior" />
</android.support.design.widget.CoordinatorLayout>
Обратите внимание на viewpager
, который будет действовать как контейнер для фрагментов. Теперь OnPageChangeListener
на viewpager.
mViewPager = (ViewPager) findViewById(R.id.container_for_fragments);
mViewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
}
@Override
public void onPageSelected(int position) {
switch (position+1){
case 0:setSupportActionBar(aToolbar);
break;
case 1:setSupportActionBar(bToolbar);
break;
case 2:setSupportActionBar(cToolbar);;
break;
case 3:setSupportActionBar(dToolbar);
break;
default:
break;
}
}
Сообщите мне, требуется ли дальнейшее уточнение
Ответ 5
Самый простой подход, который я хотел бы предложить, - использовать обратные вызовы для активности. Всякий раз, когда каждый фрагмент загружается в действие, организуйте обратный вызов активности и загружайте соответствующую панель инструментов в действие.
У вас есть отдельная панель инструментов xmls в папке макета. Используйте тег include для размещения панелей инструментов в вашей деятельности. Одновременно можно отображать только одну панель инструментов. Когда обратные вызовы фрагмента приходят к вашей активности, сделайте необходимый вид видимым.