我想通过一个片段时,被点击活动按钮,以取代ID容器的FrameLayout。我想我已经写了代码工作,但东西是不正确可能是它的布局问题。当应用程序运行时,所述片段显示为第二的闪烁和它消失马上,出头阻止。可能是FrameLayout里正在跟viewpager问题。我在做什么错在这里?
这是我的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();
}
您需要添加上的活动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,它会出现在所有的顶部,将重叠任何其他视图。