片段在安卓中一个重叠



我正在使用 MySql 中的片段在列表视图中获取数据,这是我过去单击按钮时上侧的一个按钮,它不会替换它重叠的片段在单击按钮之前和之后。

这是我以列表视图格式获取数据的代码,在单击按钮上,我想打开一个新片段,但它被覆盖了。

public class PlayQuiz extends Fragment{
public String subject;
String myJSON;
private static final String TAG_RESULTS = "result";  
private static final String TAG_NAME = "subname";
String selcsub;
Button b1;
JSONArray peoples = null;
ArrayList<HashMap<String, String>> personList;
ListView list;
TextView ss,name;
InputStream is = null;
String res = null;
String line = null;
@Override
public View onCreateView(LayoutInflater inflater,
@Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
// TODO Auto-generated method stub
View rootView = inflater.inflate(R.layout.play_quiz, container, false);
list = (ListView) rootView.findViewById(R.id.listView);
ss = (TextView) rootView.findViewById(R.id.textView1);
b1 = (Button) rootView.findViewById(R.id.button1);
b1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View arg0) {
// TODO Auto-generated method stub
PlayQuizSubjectWise fragmentManager = new PlayQuizSubjectWise();//.beginTransaction();
FragmentTransaction fragmentTransaction = getFragmentManager().beginTransaction();
fragmentTransaction.replace(R.id.playsubjectwise, fragmentManager);
fragmentTransaction.addToBackStack(null);
fragmentTransaction.commit();
}
});
}

主列表 xml 文件

<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"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.example.sarvashikshan.PlayQuiz" 
android:background="#DCDCDC"
android:id="@+id/playsubjectwise">
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Select Subject"
android:textAppearance="?android:attr/textAppearanceMedium" />
<ListView
android:id="@+id/listView"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/textView1"
android:layout_below="@+id/textView1"
android:layout_marginTop="16dp" >
</ListView>
<Button
android:id="@+id/button1"
style="?android:attr/buttonStyleSmall"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_alignRight="@+id/listView"
android:layout_marginRight="44dp"
android:text="Button" />
</RelativeLayout>

这是列表 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"
android:orientation="vertical" 
android:background="#DCDCDC"
>
<TextView
android:id="@+id/name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Large Text"
android:textAppearance="?android:attr/textAppearanceLarge" />
</LinearLayout>

PlayQuizSubjectWise XML

<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"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin" >
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="31dp"
android:textAppearance="?android:attr/textAppearanceMedium" />
<TextView
android:id="@+id/textView3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignBaseline="@+id/textView1"
android:layout_alignBottom="@+id/textView1"
android:layout_marginLeft="35dp"
android:layout_toRightOf="@+id/textView1"
android:textAppearance="?android:attr/textAppearanceMedium" />
<RadioGroup
android:id="@+id/radioGroup1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/textView1"
android:layout_below="@+id/textView1"
android:layout_marginTop="45dp" >
<RadioButton
android:id="@+id/radio0"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:checked="true" />
<RadioButton
android:id="@+id/radio1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<RadioButton
android:id="@+id/radio2"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<RadioButton
android:id="@+id/radio3"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</RadioGroup>
<Button
android:id="@+id/button1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_below="@+id/radioGroup1"
android:layout_marginTop="78dp"
android:text="Next" />
<Button
android:id="@+id/button2"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/button1"
android:layout_below="@+id/button1"
android:text="Finish" />
</RelativeLayout>

第二个片段的父布局必须具有背景。

PlayQuizSubjectWise XML

<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"
android:background="#FFF"                                        //Here
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin" >

而不是add使用replace

取代

fragmentTransaction.add(R.id.playsubjectwise, fragmentManager);

fragmentTransaction.replace(R.id.playsubjectwise, fragmentManager);

试试这个

PlayQuizSubjectWise fragmentManager = new PlayQuizSubjectWise();
FragmentTransaction fragmentTransaction = getFragmentManager().beginTransaction();
fragmentTransaction.replace(R.id.playsubjectwise, fragmentManager);
fragmentTransaction.addToBackStack(null);
fragmentTransaction.commit();

它重叠是因为您调用fragmentTransaction.add它只是将片段添加到容器中,同时保持所有旧片段可见。

相反,请使用fragmentTransaction.replace,它将用新片段替换所有现有片段。

为片段添加背景颜色并使片段可点击

android:background="fff"
android:clickable="true" 

如果要将replace用于片段,则布局playsubjectwise不应包含任何视图。

您应该拿起新片段的TextView, ListView and Button,然后可以使用replace切换两个片段。

MainList xml,只是一个布局,不包含任何视图

<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"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.example.sarvashikshan.PlayQuiz" 
android:background="#DCDCDC"
android:id="@+id/playsubjectwise">
</RelativeLayout>

然后将这些视图作为 TempFragment 放入新片段中。

首先,执行fragmentTransaction.add(R.id.playsubjectwise, TempFragment);

如果要替换到fragmentManager,请执行fragmentTransaction.replace(R.id.playsubjectwise, fragmentManager);

这是假代码,希望你能理解。

我也遇到了片段重叠的问题。

对于解决方案:

只需在所有布局中为父布局提供背景颜色 使用 XML 的片段。

例如。

这是一个片段.xml文件

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
**android:background="#fff"**
android:orientation="vertical">
<!-- Fragments UI Components-->
</LinearLayout>

所以在这里我给出了背景色 #fff(白色(。 所以像这样你应该在所有片段中给出背景颜色

我希望它能帮助你:)

最新更新