Добавление фрагмента в действие без фактического фрагмента

Итак, я делаю это в учебных целях,

Что именно я хочу сделать:

Создайте два фрагмента, Первый фрагмент имеет кнопку, которая при нажатии заменяет фрагмент 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?

Что делать, если я не хочу заранее назначать в основном действии класс фрагмента и хочу сделать это программно?

Скриншоты:

Добавление фрагмента в действие без фактического фрагментаДобавление фрагмента в действие без фактического фрагмента

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

Mike M. 23.11.2018 21:07

Боже мой, спасибо, решил мою проблему! Итак, теперь представьте, что мой первый фрагмент имеет вид ресайклера, и когда я заменю его вторым фрагментом и .addToBackStack (null); тогда, когда я нажму назад, будет ли представление ресайклера в той же позиции прокрутки, что и до загрузки второго фрагмента?

Femn Dharamshi 23.11.2018 21:09
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
В компьютерном программировании биты играют важнейшую роль в представлении и манипулировании данными на двоичном уровне. Побитовые операции...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Полный курс Java для разработчиков веб-сайтов и приложений
Полный курс Java для разработчиков веб-сайтов и приложений
Получите сертификат Java Web и Application Developer, используя наш курс.
0
2
37
0

Другие вопросы по теме