Android fragment 生命周期: onResume called twice

标签 android android-activity fragment lifecycle onresume

在用户切换到另一个 Activity 然后返回到当前 Activity 后,我试图在我的 fragment 中保存和恢复滚动。 这是发生了什么: enter image description here

如您所见,在第一个 fragment 的 onResume 进入暂停状态后,尽管用户未执行任何操作。

问题是:我的代码有什么问题?

这是我的代码:

public class DisplayNoteActivity extends Activity {

private Context mContext;
//static final int SUBACT_EDITNOTE=100;
private long m_NoteID;
private String m_sTextNoAbbrev;


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    try
    {
        Log.v("DEBUG", "DisplayNoteActivity.onCreate()");
        setContentView(R.layout.activity_display_note);

        Bundle extras = getIntent().getExtras();
        m_NoteID = extras.getLong("DisplayNote_NOTEID");
        m_sTextNoAbbrev = extras.getString("DisplayNote_TextNoAbbrev");

        if (savedInstanceState != null)
            RefreshFragment();
    }
    catch(Exception e){
        Toast.makeText(this, e.getMessage() , Toast.LENGTH_LONG).show();
        e.printStackTrace();
    }

}


public void onSaveInstanceState(Bundle savedInstanceState)
{
    Log.v("DEBUG", "DisplayNoteActivity.onSaveInstanceState()");
    super.onSaveInstanceState(savedInstanceState);
    savedInstanceState.putLong("DisplayNote_NOTEID", m_NoteID);
    savedInstanceState.putString("DisplayNote_TextNoAbbrev", m_sTextNoAbbrev);
}

public void onRestoreInstanceState(Bundle savedInstanceState) {
    super.onRestoreInstanceState(savedInstanceState);
    // Restore UI state from the savedInstanceState.
    // This bundle has also been passed to onCreate.
    Log.v("DEBUG", "DisplayNoteActivity.onRestoreInstanceState()");
    m_NoteID = savedInstanceState.getLong("DisplayNote_NOTEID");
    m_sTextNoAbbrev= savedInstanceState.getString("DisplayNote_TextNoAbbrev");
}

@Override
public void onResume() {
    Log.v("DEBUG", "DisplayNoteActivity.onResume()");
    super.onResume();

    RefreshFragment();
}


private void RefreshFragment()
{

    Bundle bundle = new Bundle();
    bundle.putLong("DisplayNote_NOTEID", m_NoteID);
    bundle.putString("DisplayNote_TextNoAbbrev", m_sTextNoAbbrev);

    android.app.FragmentManager fm=getFragmentManager();
    android.app.FragmentTransaction ft = fm.beginTransaction();

    DisplayNoteFragment dnf = new DisplayNoteFragment();
    dnf.setArguments(bundle);
    ft.replace(R.id.container, dnf);

    ft.commit();
}}

fragment 代码:

public class DisplayNoteFragment extends Fragment {


private Context mContext;

private long mNoteID = 0;
private Note m_NoteData;

private long mTextID = 0;
private int m_levels = 0;

private String m_dbtype;
private String m_dblang;
GitaTextsHelper m_tdb;

private String m_sTextNo;
private ScrollView m_Scroll;
private int mScrollPos=0;

AutoResizeTextView m_atvHeaderTitle;
AutoResizeTextView m_atvHeaderSubTitle;

AutoResizeTextView m_atvBookTitle;
AutoResizeTextView m_atvChapterTitle;
TextView m_atvTags;
AutoResizeTextView m_atvVerse;

TextView m_tvGitaText;
ImageView m_NoteTypeIcon;
ImageView m_EditNoteIcon;
TextView m_tvNote;

int m_titlePrefixID;


long m_TextRowID = -1;
String m_sVerse;

public DisplayNoteFragment() {
}

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
                         Bundle savedInstanceState) {
    View rootView = inflater.inflate(R.layout.fragment_display_note, container, false);
    Log.v("DEBUG", "DisplayNoteFragment onCreateView()");
    try {
        m_Scroll = (ScrollView)rootView.findViewById(R.id.ScrollView02);
        m_atvHeaderTitle = (AutoResizeTextView) rootView.findViewById(R.id.header_title);
        m_atvHeaderSubTitle = (AutoResizeTextView) rootView.findViewById(R.id.header_subtitle);

        m_atvBookTitle = (AutoResizeTextView) rootView.findViewById(R.id.book_title);
        m_atvChapterTitle = (AutoResizeTextView) rootView.findViewById(R.id.chapter_title);
        m_atvTags = (TextView) rootView.findViewById(R.id.note_tags);
        m_atvVerse = (AutoResizeTextView) rootView.findViewById(R.id.note_verse);

        m_tvGitaText = (TextView) rootView.findViewById(R.id.gita_text);
        m_tvNote = (TextView) rootView.findViewById(R.id.note_text);

        //***** INPUT
        mNoteID = getArguments().getLong("DisplayNote_NOTEID");
        m_NoteData = MyApp.mUserDB.GetNote(mNoteID);
        // common fields for text notes and custom notes
        m_atvHeaderSubTitle.setText(m_NoteData.sCreatedDate);
        m_NoteTypeIcon = (ImageView) rootView.findViewById(R.id.note_type_icon); m_NoteTypeIcon.setImageResource(MyApp.getNoteTypeIcon(m_NoteData.type));
        //tags
        String tags = MyApp.mUserDB.getNoteTags(mNoteID);

        if (tags.equals("")) tags = MyApp.Res.getString(R.string.no_tag_defined);
        m_atvTags.setText(tags);
        m_atvTags.setPaintFlags(m_atvTags.getPaintFlags() | Paint.UNDERLINE_TEXT_FLAG);
        m_atvTags.setOnClickListener(new View.OnClickListener() {
            public void onClick(View v) {
                if (MyApp.mC.hasFlag(Cookies.FL_Tagging, mContext, true)) {
                    Intent intent = new Intent(mContext, TagEdit.class);
                    intent.putExtra("TAGEDIT_NOTEID", mNoteID);
                    intent.putExtra("TAGEDIT_EDIT_TAGS_MODE", 1);

                    startActivity(intent);
                }

            }
        });


    } catch (Exception e) {
        Toast.makeText(mContext, e.getMessage(), Toast.LENGTH_LONG).show();
        e.printStackTrace();
    }

    return rootView;
}

private void openText(int iScroll) {

    Intent intent = new Intent(mContext, DisplayText.class);
    intent.putExtra("rowID", m_TextRowID);
    intent.putExtra("Scroll", iScroll);
    intent.putExtra("Language", m_dblang);
    intent.putExtra("DBType", m_dbtype);
    startActivity(intent);
}


public void onPause() {
    super.onPause();

    mScrollPos=m_Scroll.getScrollY();
    Log.v("DEBUG", "DisplayNoteFragment onPause(). Scroll="+mScrollPos);
}


public void onResume() {
    Log.v("DEBUG", "DisplayNoteFragment onResume(). Scroll="+mScrollPos);
    super.onResume();
    if(mScrollPos!=0) {
        m_Scroll.scrollTo(0, mScrollPos);
        Log.v("DEBUG", "DisplayNoteFragment onResume(). Scrolled to="+mScrollPos);
    }

}

@Override
public void onSaveInstanceState(Bundle outState) {
    super.onSaveInstanceState(outState);
    if(outState==null) return;
    Log.v("DEBUG", "DisplayNoteFragment onSaveInstanceState(). Scroll="+mScrollPos);
    outState.putInt("mScrollPos", mScrollPos);

}

@Override
public void onActivityCreated(Bundle savedInstanceState) {
    super.onActivityCreated(savedInstanceState);
    if(savedInstanceState==null) return;
    mScrollPos = savedInstanceState.getInt("mScrollPos");
    Log.v("DEBUG", "DisplayNoteFragment onActivityCreated(). Scroll="+mScrollPos);
}

最佳答案

fragment 被替换两次,这就是 fragment 的 onResume 被调用两次的原因。您应该只从 Activity 的 onCreate() 调用 RefreshFragment(),而不需要从 Activity 的 onResume() 调用。

关于Android fragment 生命周期: onResume called twice,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44024346/

相关文章:

android - 当底层数据发生变化时,根据 SQlite 数据库中的数据更新 Fragment List 适配器

安卓 : ViewPager doesn't display the first 2 pages after being created again

android - 如何在 ShinobiCharts 中显示网格线

android - 如何使您的应用程序具有图形可移植性?

Android:使用 Parcel 难以将对象从一个 Activity 传递到另一个 Activity

android将应用程序设置为仅纵向,键盘拔出时除外

android - 如何使用 onSaveInstanceState 在我的 fragment 上保存和恢复接口(interface)

java - 我如何只知道Button OnClickListener内的userID即可向特定用户发送推送通知?火力基地

c# - 如何获取xamarin.android中的音乐文件夹路径?

android - 一个 Activity 的两个发射器