Potrzebuję pomocy przy pracy nad fragmentem wewnątrz fragmentu, właściwie mam problem z wciśnięciem przycisku Wstecz. Na ekranie głównym aplikacji znajdują się przyciski, a naciśnięcie każdego przycisku powoduje zastąpienie widoku nowego fragmentem (i ten fragment zawiera inny fragment), dynamiczne dodawanie / zastępowanie fragmentu działa dobrze, po naciśnięciu przycisku button1 fragment jest zastępowany, to samo dzieje się po naciśnięciu przycisku, ale jeśli naciśnę przycisk znowu, dostałem wyjątek:
"Duplicate id 0x7f05000a, tag null, or parent id 0x7f050009 with
another fragment for com........ fragmentname"
oznacza, że fragment lub fragmenty wewnętrzne są już dodane i próbuję je dodać ponownie, każdy ma pomysł, jak pracować z fragmentem wewnątrz fragmentu i poruszać się tam iz powrotem bez problemu, dzięki za wsparcie.
MainActivity, w którym fragmenty są dynamicznie dodawane i zastępowane.
public class FragmentInsideFragmentTestActivity extends Activity {
private Button button1;
private Button button2;
private Button button3;
private Button button4;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
button1 =(Button) this.findViewById(R.id.button1);
button1.setOnClickListener(new View.OnClickListener() {
public void onClick(View view) {
onButtonClick(view);
}
});
button2 =(Button) this.findViewById(R.id.button2);
button2.setOnClickListener(new View.OnClickListener() {
public void onClick(View view) {
onButtonClick(view);
}
});
button3 =(Button) this.findViewById(R.id.button3);
button3.setOnClickListener(new View.OnClickListener() {
public void onClick(View view) {
onButtonClick(view);
}
});
button4 =(Button) this.findViewById(R.id.button4);
button4.setOnClickListener(new View.OnClickListener() {
public void onClick(View view) {
onButtonClick(view);
}
});
}
public void onButtonClick(View v) {
Fragment fg;
switch (v.getId()) {
case R.id.button1:
fg=FirstFragment.newInstance();
replaceFragment(fg);
break;
case R.id.button2:
fg=SecondFragment.newInstance();
replaceFragment(fg);
break;
case R.id.button3:
fg=FirstFragment.newInstance();
replaceFragment(fg);
break;
case R.id.button4:
fg=SecondFragment.newInstance();
replaceFragment(fg);
break;
}
}
private void replaceFragment(Fragment newFragment) {
FragmentTransaction trasection = getFragmentManager().beginTransaction();
if(!newFragment.isAdded()) {
try {
//FragmentTransaction trasection =
getFragmentManager().beginTransaction();
trasection.replace(R.id.linearLayout2, newFragment);
trasection.addToBackStack(null);
trasection.commit();
} catch (Exception e) {
// TODO: handle exception
// AppConstants.printLog(e.getMessage());
} else {
trasection.show(newFragment);
}
}
}
Oto układ: main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical">
<LinearLayout
android:id="@+id/linearLayout1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<Button
android:id="@+id/button1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Button1" />
<Button
android:id="@+id/button2"
android:text="Button2"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<Button
android:id="@+id/button3"
android:text="Button3"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<Button
android:id="@+id/button4"
android:text="Button4"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</LinearLayout>
<LinearLayout
android:id="@+id/linearLayout2"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal" />
</LinearLayout>
Mam nadzieję, że próbowałem rozwiązać mój problem.
źródło
Odpowiedzi:
AFAIK, fragmenty nie mogą zawierać innych fragmentów.
AKTUALIZACJA
Przy obecnych wersjach pakietu Android Support - lub natywnych fragmentach na poziomie API 17 i wyższych - możesz zagnieżdżać fragmenty za pomocą
getChildFragmentManager()
. Zwróć uwagę, że oznacza to, że musisz użyć wersji pakietu Android Support dla fragmentów na poziomach API 11-16, ponieważ chociaż na tych urządzeniach istnieje natywna wersja fragmentów, ta wersja nie magetChildFragmentManager()
.źródło
getChildFragmentManager()
i usunięciesetRetainInstance(true)
z wewnętrznego fragmentu (szkoda) naprawiło to. Dzięki za ponowne uratowanie mojego bekonu, @CommonsWare.Potrzebowałem więcej kontekstu, więc zrobiłem przykład, aby pokazać, jak to się robi. Najbardziej pomocna rzecz, jaką przeczytałem podczas przygotowań, to:
Czynność
activity_main.xml
Dodaj
FrameLayout
do swojej aktywności, aby trzymać fragment nadrzędny.MainActivity.java
Załaduj fragment nadrzędny i zaimplementuj detektory fragmentów. (Zobacz fragment komunikacji .)
Fragment nadrzędny
fragment_parent.xml
Dodaj kolejny
FrameLayout
pojemnik na fragment podrzędny.ParentFragment.java
Użyj
getChildFragmentManager
in,onViewCreated
aby skonfigurować fragment podrzędny.Fragment podrzędny
fragment_child.xml
Nie ma tu nic specjalnego.
ChildFragment.java
Nie ma tu też nic specjalnego.
Uwagi
źródło
Od wersji Android 4.2 (API 17) zagnieżdżone fragmenty stają się dostępne http://developer.android.com/about/versions/android-4.2.html#NestedFragments
Aby umieścić fragment wewnątrz innego fragmentu, użyj metody getChildFragmentManager ()
Jest również dostępny w bibliotece wsparcia!
źródło
Fragmenty mogą być dodawane wewnątrz innych fragmentów, ale wtedy będziesz musiał usunąć go z fragmentu nadrzędnego za każdym razem, gdy
onDestroyView()
zostanie wywołana metoda fragmentu nadrzędnego. I ponownie dodaj to wonCreateView()
metodzie Parent Fragment .Po prostu zrób to:
źródło
onActivityCreated()
nim dodano dwa fragmenty, po jednym w każdym z widoków, używającgetFragmentManager()
. To zadziałało za pierwszym razem, ale po obróceniu i wznowieniu widoczny był tylko jeden z fragmentów.getChildFragmentManager()
Zamiast tego zachowanie było poprawne . Podejście sugerowane tutaj stanowiło wyjątek, ponieważ działanieonSaveInstanceState()
zostało już wywołane. Zatwierdzenie transakcji przy użyciucommitAllowingStateLoss()
uniknęło wyjątku, ale nie rozwiązało pierwotnego problemu.Rozwiązałem ten problem. Możesz skorzystać z biblioteki pomocy technicznej i
ViewPager
. Jeśli nie potrzebujesz przesuwania gestem, możesz wyłączyć przesuwanie. Oto kod, który ulepszy moje rozwiązanie:PS To brzydki kod do testów, ale poprawia, że jest to możliwe.
Fragment PPS Inside
ChildFragmentManager
należy przekazać doViewPagerAdapter
źródło
możesz użyć
getChildFragmentManager()
funkcji.przykład:
Fragment nadrzędny:
Układ nadrzędny (
parent_fragment.xml
):Fragment podrzędny:
źródło
To nic skomplikowanego. Nie możemy
getFragmentManager()
tutaj użyć . Aby użyć fragmentów wewnątrz fragmentu , używamygetChildFragmentManager()
. Reszta będzie taka sama.źródło
Możesz dodać
FrameLayout
do fragmentu i zastąpić go innym fragmentem podczas inicjalizacji.W ten sposób możesz uznać, że drugi fragment znajduje się wewnątrz pierwszego fragmentu.
źródło
Użyj getChildFragmentManager (), kliknij link: Zagnieżdżony fragment
źródło
Obecnie w zagnieżdżonych fragmentach zagnieżdżone są obsługiwane tylko wtedy, gdy są generowane programowo! Więc w tej chwili żaden zagnieżdżony układ fragmentów nie jest obsługiwany w schemacie układu xml!
źródło
To może pomóc tym, którzy pracują w Kotlinie Możesz użyć funkcji rozszerzenia, więc stwórz plik kotlin powiedzmy "util.kt" i dodaj ten fragment kodu
Powiedzmy, że to klasa dziecka
Teraz możesz dodać dzieci do fragmentu ojca w ten sposób
gdzie R.id.fragmet_field to id układu, który będzie zawierał fragment. Ten tekst znajduje się oczywiście wewnątrz fragmentu ojca. Oto przykład
father_fragment.xml :
źródło
Nie ma wsparcia dla
MapFragment
, zespół Androida twierdzi, że pracuje nad tym od Androida 3.0. Tutaj więcej informacji o problemie Ale co możesz zrobić, tworząc fragment, który zwraca plikMapActivity
. Oto przykład kodu. Dzięki inazaruk:Jak to działa :
FragmentActivity
i obsługuje dwa MapFragments.MapView.
LocalActivityManagerFragment
hosty LocalActivityManager.LocalActivityManagerFragment
i za pomocąTabHost
tworzy wewnętrzną instancję MyMapActivity.Jeśli masz jakiekolwiek wątpliwości, daj mi znać
źródło
Cześć, rozwiązałem ten problem, umieszczając każdy fragment w odrębnym układzie, a także sprawiłem, że powiązany układ był widoczny, a pozostałe widoczności zniknęły.
Mam na myśli:
Założyłem, że otworzysz swoją stronę po kliknięciu przycisku 1.Możesz kontrolować widoczność swojego fragmentu po kliknięciu akcji.Możesz sprawić, by powiązany układ był widoczny, a inne zniknęły, a dzięki Menedżerowi fragmentów możesz wziąć swój fragment.To podejście zadziałało dla mnie. A ponieważ widok, który ma widoczność: zniknął, jest niewidoczny i nie zajmuje miejsca na potrzeby układu, myślę, że takie podejście nie powoduje żadnego problemu z przestrzenią.
PS: Właśnie próbowałem wyjaśnić, że kod mojego rozwiązania może zawierać błędy składniowe lub niekompletną strukturę.
źródło