Итак, я делаю это в учебных целях,
Что именно я хочу сделать:
Создайте два фрагмента, Первый фрагмент имеет кнопку, которая при нажатии заменяет фрагмент View в основном действии вторым фрагментом, второй фрагмент просто содержит текстовое представление с надписью «Это второй фрагмент», но когда я попытался это сделать, первый фрагмент загружается два раза, и при нажатии кнопки первый экземпляр остается там, где второй экземпляр заменяется вторым фрагментом. Можете ли вы, ребята, сказать мне, что я делаю не так: (я прилагаю код, а также скриншоты)
MainActivity.java:
package com.femindharamshi.fragmenttrials;
import android.support.v4.app.FragmentTransaction;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity implements FirstFragment.OnFragmentInteractionListener {
FragmentTransaction fragmentTransaction;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
fragmentTransaction = getSupportFragmentManager().beginTransaction();
FirstFragment newFrament = new FirstFragment();
fragmentTransaction.add(R.id.fragmentView, newFrament);
fragmentTransaction.commit();
}
@Override
public void onFragmentInteraction() {
Toast.makeText(this, "Button in fragment pressed!", Toast.LENGTH_SHORT).show();
fragmentTransaction = getSupportFragmentManager().beginTransaction();
SecondFragment newFragment = new SecondFragment();
fragmentTransaction.replace(R.id.fragmentView, newFragment);
fragmentTransaction.commit();
}
}
activity_main.xml
<?xml version = "1.0" encoding = "utf-8"?>
<RelativeLayout 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 = ".MainActivity">
<fragment
android:id = "@+id/fragmentView"
android:name = "com.femindharamshi.fragmenttrials.FirstFragment"
android:layout_width = "match_parent"
android:layout_height = "match_parent"
android:layout_alignParentStart = "true"
android:layout_alignParentTop = "true"/>
</RelativeLayout>
FirstFragment.java
package com.femindharamshi.fragmenttrials;
import android.content.Context;
import android.net.Uri;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
public class FirstFragment extends Fragment {
private OnFragmentInteractionListener mListener;
Button button;
public FirstFragment() {
// Required empty public constructor
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// Inflate the layout for this fragment
View view = inflater.inflate(R.layout.fragment_first, container, false);
button = view.findViewById(R.id.button);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
onButtonPressed();
}
});
return view;
}
public void onButtonPressed() {
if (mListener != null) {
mListener.onFragmentInteraction();
}
}
@Override
public void onAttach(Context context) {
super.onAttach(context);
if (context instanceof OnFragmentInteractionListener) {
mListener = (OnFragmentInteractionListener) context;
} else {
throw new RuntimeException(context.toString()
+ " must implement OnFragmentInteractionListener");
}
}
@Override
public void onDetach() {
super.onDetach();
mListener = null;
}
public interface OnFragmentInteractionListener {
void onFragmentInteraction();
}
}
SecondFragment.java
package com.femindharamshi.fragmenttrials;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
public class SecondFragment extends Fragment {
public SecondFragment() {
// Required empty public constructor
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// Inflate the layout for this fragment
return inflater.inflate(R.layout.fragment_second, container, false);
}
@Override
public void onDetach() {
super.onDetach();
}
}
Проблема : Также, без упоминания android:name = "com.femindharamshi.fragmenttrials.FirstFragment" в основном действии, приложение вылетает. Что делать, если я не хочу загружать фрагмент при запуске активности, зачем мне об этом упоминать? и даже если я загружу в него secondFragment, все в порядке? хотя в названии написано FirstFragment?
Что делать, если я не хочу заранее назначать в основном действии класс фрагмента и хочу сделать это программно?
Скриншоты:
Боже мой, спасибо, решил мою проблему! Итак, теперь представьте, что мой первый фрагмент имеет вид ресайклера, и когда я заменю его вторым фрагментом и .addToBackStack (null); тогда, когда я нажму назад, будет ли представление ресайклера в той же позиции прокрутки, что и до загрузки второго фрагмента?




Элемент
<fragment>в вашем макете - это не просто заполнитель или контейнер. Фактически это вызывает загрузку и добавлениеFragment. Если вы собираетесь обрабатывать своиFragmentдинамически, замените<fragment>на<FrameLayout>, который будет действовать как контейнер дляFragment, с которыми вы совершаете транзакции в своем коде.