Autore Topic: BackStack esce dell'applicazione  (Letto 582 volte)

Offline carbos

  • Nuovo arrivato
  • *
  • Post: 30
  • Respect: +1
    • Mostra profilo
  • Dispositivo Android:
    Samsung Galaxy S3 Neo
  • Sistema operativo:
    Windows10
BackStack esce dell'applicazione
« il: 09 Febbraio 2016, 14:05:15 CET »
0
Io ho un applicazione dove ho un activity e due fragment di cui faccio il replace, adesso quando metto addToBackStack(null) al secondo fragment, se premo il tasto indietro mi da errore, allora ho provato a fare l'overload della funzione onBackPressed e far si che quando viene cambiato sempre di fare il replace con il fragment precedente ma niente... Come mi consigliate di fare? Ecco il source:

MainActivity
Codice (Java): [Seleziona]
package com.carbos.user.animelistapp;

import android.app.FragmentManager;
import android.app.FragmentTransaction;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.Menu;
import android.view.MenuItem;

public class MainActivity extends AppCompatActivity implements ListAnime.OnFragmentInteractionListener{
    private FragmentManager fm;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);

        fm = getFragmentManager();
        FragmentTransaction ft = fm.beginTransaction();
        ListAnime a = ListAnime.newInstance("a", "b");
        ft.add(R.id.list_anime, a);
        ft.commit();
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.menu_main, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();

        //noinspection SimplifiableIfStatement
        if (id == R.id.action_settings) {
            return true;
        }

        return super.onOptionsItemSelected(item);
    }



    public void onClickAnime(int i){
        FragmentTransaction ft = fm.beginTransaction();
        AnimeDesc Desc = AnimeDesc.newInstance(i);
        ft.replace(R.id.list_anime, Desc);
        ft.addToBackStack(null);
        ft.commit();
    }
}

ListAnime (Fragment 1)
Codice (Java): [Seleziona]
package com.carbos.user.animelistapp;

import android.content.Context;
import android.net.Uri;
import android.os.Bundle;
import android.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListView;


/**
 * A simple {@link Fragment} subclass.
 * Activities that contain this fragment must implement the
 * {@link ListAnime.OnFragmentInteractionListener} interface
 * to handle interaction events.
 * Use the {@link ListAnime#newInstance} factory method to
 * create an instance of this fragment.
 *
 */

public class ListAnime extends Fragment {
    // TODO: Rename parameter arguments, choose names that match
    // the fragment initialization parameters, e.g. ARG_ITEM_NUMBER
    private static final String ARG_PARAM1 = "param1";
    private static final String ARG_PARAM2 = "param2";

    // TODO: Rename and change types of parameters
    private String mParam1;
    private String mParam2;

    private OnFragmentInteractionListener mListener;

    /**
     * Use this factory method to create a new instance of
     * this fragment using the provided parameters.
     *
     * @param param1 Parameter 1.
     * @param param2 Parameter 2.
     * @return A new instance of fragment ListAnime.
     */

    // TODO: Rename and change types and number of parameters
    public static ListAnime newInstance(String param1, String param2) {
        ListAnime fragment = new ListAnime();
        Bundle args = new Bundle();
        args.putString(ARG_PARAM1, param1);
        args.putString(ARG_PARAM2, param2);
        fragment.setArguments(args);
        return fragment;
    }
    public ListAnime() {
        // Required empty public constructor
    }

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        if (getArguments() != null) {
            mParam1 = getArguments().getString(ARG_PARAM1);
            mParam2 = getArguments().getString(ARG_PARAM2);
        }
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // Inflate the layout for this fragment
        View rootView =  inflater.inflate(R.layout.fragment_list_anime, container, false);
        Anime anime = new Anime();
        ArrayAdapter<String> adapter = new ArrayAdapter<String>(getActivity(),  android.R.layout.simple_list_item_1, anime.getTitles());
        ListView lv = (ListView) rootView.findViewById(R.id.listanime);
        lv.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                mListener.onClickAnime(position);
            }
        });
        lv.setAdapter(adapter);
        return rootView;
    }

    @Override
    public void onAttach(Context context) {
        super.onAttach(context);
    }

    @Override
    public void onStart() {
        super.onStart();
        try {
            mListener = (OnFragmentInteractionListener) getActivity();
        } catch (ClassCastException e) {
            throw new ClassCastException(getActivity().toString()
                    + " must implement OnFragmentInteractionListener");
        }
    }

    @Override
    public void onDetach() {
        super.onDetach();
        mListener = null;
    }

    /**
     * This interface must be implemented by activities that contain this
     * fragment to allow an interaction in this fragment to be communicated
     * to the activity and potentially other fragments contained in that
     * activity.
     * <p>
     * See the Android Training lesson <a href=
     * "http://developer.android.com/training/basics/fragments/communicating.html"
     * >Communicating with Other Fragments</a> for more information.
     */

    public interface OnFragmentInteractionListener {
        // TODO: Update argument type and name
        public void onClickAnime(int pos);
    }
}

AnimeDesc ( Fragment 2)
Codice (Java): [Seleziona]
package com.carbos.user.animelistapp;

import android.content.Context;
import android.net.Uri;
import android.os.Bundle;
import android.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;

import org.w3c.dom.Text;


/**
 * A simple {@link Fragment} subclass.
 * Activities that contain this fragment must implement the
 * {@link AnimeDesc.OnFragmentInteractionListener} interface
 * to handle interaction events.
 * Use the {@link AnimeDesc#newInstance} factory method to
 * create an instance of this fragment.
 */

public class AnimeDesc extends Fragment {
    // TODO: Rename parameter arguments, choose names that match
    // the fragment initialization parameters, e.g. ARG_ITEM_NUMBER
    private static final String ARG_PARAM1 = "param1";
    private static final String ARG_PARAM2 = "param2";

    // TODO: Rename and change types of parameters
    private int mParam1;

    private OnFragmentInteractionListener mListener;

    public AnimeDesc() {
        // Required empty public constructor
    }

    /**
     * Use this factory method to create a new instance of
     * this fragment using the provided parameters.
     *
     * @param param1 Parameter 1.
     * @return A new instance of fragment AnimeDesc.
     */

    // TODO: Rename and change types and number of parameters
    public static AnimeDesc newInstance(int param1) {
        AnimeDesc fragment = new AnimeDesc();
        Bundle args = new Bundle();
        args.putInt(ARG_PARAM1, param1);
        fragment.setArguments(args);
        return fragment;
    }

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        if (getArguments() != null) {
            mParam1 = getArguments().getInt(ARG_PARAM1);
        }
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // Inflate the layout for this fragment
        View root = inflater.inflate(R.layout.fragment_anime_desc, container, false);
        Anime anime = new Anime();
        TextView tv =(TextView) root.findViewById(R.id.title);
        tv.setText(anime.getTitle(mParam1));
        TextView desc = (TextView) root.findViewById(R.id.desc);
        desc.setText(anime.getDesc(mParam1));
        return root;
    }

    // TODO: Rename method, update argument and hook method into UI event
    public void onButtonPressed(Uri uri) {
        if (mListener != null) {
            mListener.onFragmentInteraction(uri);
        }
    }

    @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;
    }

    /**
     * This interface must be implemented by activities that contain this
     * fragment to allow an interaction in this fragment to be communicated
     * to the activity and potentially other fragments contained in that
     * activity.
     * <p/>
     * See the Android Training lesson <a href=
     * "http://developer.android.com/training/basics/fragments/communicating.html"
     * >Communicating with Other Fragments</a> for more information.
     */

    public interface OnFragmentInteractionListener {
        // TODO: Update argument type and name
        void onFragmentInteraction(Uri uri);
    }
}

Layout del MainActivity (content_main)
Codice (XML): [Seleziona]
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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"
   android:paddingBottom="@dimen/activity_vertical_margin"
   android:paddingLeft="@dimen/activity_horizontal_margin"
   android:paddingRight="@dimen/activity_horizontal_margin"
   android:paddingTop="@dimen/activity_vertical_margin"
   app:layout_behavior="@string/appbar_scrolling_view_behavior"
   tools:context="com.carbos.user.animelistapp.MainActivity"
   tools:showIn="@layout/activity_main"
   android:orientation="horizontal">

    <FrameLayout
       android:id="@+id/list_anime"
       android:layout_width="match_parent"
       android:layout_height="match_parent" />

</LinearLayout>

Offline tonno16

  • Utente storico
  • *****
  • Post: 1184
  • Respect: +57
    • Mostra profilo
  • Dispositivo Android:
    moto g
  • Play Store ID:
    Diego Tonini
  • Sistema operativo:
    OpenSuse
Re:BackStack esce dell'applicazione
« Risposta #1 il: 10 Febbraio 2016, 00:22:04 CET »
0
Interessa anche a me. Io riesco a tornare indietro visualizza do il fragment precedente. però l'ultimo step viene inizializzato un fragment vuoto..

Offline carbos

  • Nuovo arrivato
  • *
  • Post: 30
  • Respect: +1
    • Mostra profilo
  • Dispositivo Android:
    Samsung Galaxy S3 Neo
  • Sistema operativo:
    Windows10
Re:BackStack esce dell'applicazione
« Risposta #2 il: 10 Febbraio 2016, 01:49:05 CET »
0
Interessa anche a me. Io riesco a tornare indietro visualizza do il fragment precedente. però l'ultimo step viene inizializzato un fragment vuoto..
Io ho pensato a mettere due frame layout di cui uno nascosto con visibilty Gone, però non so come rispettarlo visibile, e speravo in qualche funzione che fosse capace di risolvere questa cosa senza l'ausilio di un altro fragment

Offline iClaude

  • Utente normale
  • ***
  • Post: 183
  • Respect: +13
    • Mostra profilo
  • Dispositivo Android:
    Samsung Galaxy S5
  • Sistema operativo:
    Windows 10
Re:BackStack esce dell'applicazione
« Risposta #3 il: 10 Febbraio 2016, 08:53:18 CET »
0
Non mi sembra che hai inserito la prima transaction nel backstack.

Offline carbos

  • Nuovo arrivato
  • *
  • Post: 30
  • Respect: +1
    • Mostra profilo
  • Dispositivo Android:
    Samsung Galaxy S3 Neo
  • Sistema operativo:
    Windows10
Re:BackStack esce dell'applicazione
« Risposta #4 il: 10 Febbraio 2016, 09:35:09 CET »
0
La transaction l'ho aggiunta solo al secondo fragment, quello che poi voglio togliere

Offline iClaude

  • Utente normale
  • ***
  • Post: 183
  • Respect: +13
    • Mostra profilo
  • Dispositivo Android:
    Samsung Galaxy S5
  • Sistema operativo:
    Windows 10
Re:BackStack esce dell'applicazione
« Risposta #5 il: 10 Febbraio 2016, 09:37:44 CET »
0
E allora come fa a recuperare il primo Fragment dal back stack se non lo aggiungi?

Offline carbos

  • Nuovo arrivato
  • *
  • Post: 30
  • Respect: +1
    • Mostra profilo
  • Dispositivo Android:
    Samsung Galaxy S3 Neo
  • Sistema operativo:
    Windows10
Re:BackStack esce dell'applicazione
« Risposta #6 il: 10 Febbraio 2016, 09:40:07 CET »
0
E allora come fa a recuperare il primo Fragment dal back stack se non lo aggiungi?
Ah okok adesso lo aggiungo, adesso allora ho un po capito come funziona