Как заменить фреймлайт фрагментом программно
Я пытаюсь заменить framelayout с контейнером id фрагментом, когда кнопка нажимается в действии. Я думаю, что написанный мною код работает, но что-то не так, возможно, это проблема компоновки. Когда приложение запускается, Фрагмент появляется на мгновение и сразу исчезает, что-то блокирует его. Может быть, у структуры кадра возникла проблема с viewpager.Please подскажите, что я делаю не так здесь.
Это мой xml.
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/drawer"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#000">
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content" >
<include
android:id="@+id/toolbar_actionbar"
layout="@layout/toolbar_default"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:visibility="gone"/>
<FrameLayout
android:id="@+id/container"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_below="@+id/toolbar_actionbar"
android:clickable="true" />
<android.support.v4.view.ViewPager
android:id="@+id/pager"
android:layout_width="match_parent"
android:layout_height="match_parent" />
<TextView
android:layout_below="@+id/toolbar_actionbar"
android:paddingRight="30dp"
android:textColor="#fff"
android:layout_width="80dp"
android:layout_height="80dp"
android:text="Skip"
android:textSize="20sp"
android:gravity="right"
android:id="@+id/txt_skip"
android:layout_alignParentRight="true"
android:layout_marginTop="20dp"
/>
<com.viewpagerindicator.CirclePageIndicator
android:id="@+id/indicator"
android:layout_width="80dp"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
android:gravity="bottom"
app:centered="true"
app:fillColor="@color/white"
app:pageColor="@color/white"
app:snap="false"
android:paddingBottom="20dp"
android:layout_margin="2dp"
/>
<com.gc.materialdesign.views.ButtonRectangle
android:id="@+id/sign_in_button"
android:layout_width="90dp"
android:layout_height="60dp"
android:background="@color/primary_color"
android:text="Sign in"
android:paddingBottom="20dp"
android:paddingRight="40dp"
android:layout_alignParentBottom="true"
android:layout_alignParentLeft="true"/>
<com.gc.materialdesign.views.ButtonRectangle
android:id="@+id/sign_up_button"
android:layout_width="90dp"
android:layout_height="60dp"
android:background="@color/primary_color"
android:text="Sign Up"
android:paddingBottom="20dp"
android:paddingLeft="40dp"
android:layout_alignParentBottom="true"
android:layout_alignParentRight="true"/>
</RelativeLayout>
<fragment
android:visibility="gone"
android:layout_width="280dp"
android:layout_height="match_parent"
android:id="@+id/fragment_drawer"
android:layout_gravity="start"
android:background="#ff0000"
app:layout="@layout/fragment_navigation_drawer"
android:name="com.app.foodmandu.view.nav.NavigationDrawerFragment"/>
</android.support.v4.widget.DrawerLayout>
Этот метод запускает транзакцию фрагмента из действия при нажатии кнопки.
// inside onClick method.
openFragment( SignupFragment.newInstance());
// This method gets invoked when a button is clicked.
public void openFragment(Fragment fragment) {
FragmentTransaction ft = getSupportFragmentManager()
.beginTransaction();
ft.replace(R.id.container,
fragment);
ft.setTransition(FragmentTransaction.TRANSIT_FRAGMENT_OPEN);
ft.addToBackStack(null);
ft.commitAllowingStateLoss();
}
2 ответа
Вам необходимо добавить фрагмент по умолчанию для метода onCreate действия, например:
getFragmentManager().beginTransaction().add(R.id.container, YOUR FRAGMENT).commit();
Я думаю, что ваш FrameLayout скрыт под ViewPager и ViewPager перекрывает FrameLayout. Попробуй это:
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content" >
<include
android:id="@+id/toolbar_actionbar"
layout="@layout/toolbar_default"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:visibility="gone"/>
<android.support.v4.view.ViewPager
android:id="@+id/pager"
android:layout_width="match_parent"
android:layout_height="match_parent" />
<TextView
android:layout_below="@+id/toolbar_actionbar"
android:paddingRight="30dp"
android:textColor="#fff"
android:layout_width="80dp"
android:layout_height="80dp"
android:text="Skip"
android:textSize="20sp"
android:gravity="right"
android:id="@+id/txt_skip"
android:layout_alignParentRight="true"
android:layout_marginTop="20dp"
/>
<com.viewpagerindicator.CirclePageIndicator
android:id="@+id/indicator"
android:layout_width="80dp"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
android:gravity="bottom"
app:centered="true"
app:fillColor="@color/white"
app:pageColor="@color/white"
app:snap="false"
android:paddingBottom="20dp"
android:layout_margin="2dp"
/>
<com.gc.materialdesign.views.ButtonRectangle
android:id="@+id/sign_in_button"
android:layout_width="90dp"
android:layout_height="60dp"
android:background="@color/primary_color"
android:text="Sign in"
android:paddingBottom="20dp"
android:paddingRight="40dp"
android:layout_alignParentBottom="true"
android:layout_alignParentLeft="true"/>
<com.gc.materialdesign.views.ButtonRectangle
android:id="@+id/sign_up_button"
android:layout_width="90dp"
android:layout_height="60dp"
android:background="@color/primary_color"
android:text="Sign Up"
android:paddingBottom="20dp"
android:paddingLeft="40dp"
android:layout_alignParentBottom="true"
android:layout_alignParentRight="true"/>
<FrameLayout
android:id="@+id/container"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_below="@+id/toolbar_actionbar"
android:clickable="true" />
</RelativeLayout>
<fragment
android:visibility="gone"
android:layout_width="280dp"
android:layout_height="match_parent"
android:id="@+id/fragment_drawer"
android:layout_gravity="start"
android:background="#ff0000"
app:layout="@layout/fragment_navigation_drawer"
android:name="com.app.foodmandu.view.nav.NavigationDrawerFragment"/>
Поместив свой FrameLayout на последний внутри RelativeLayout, он появится поверх всего и будет перекрывать любой другой вид.