1

В моей главной операции У меня есть фрагмент, который я заменяю другим классом фрагментов.IllegalArgumentException при вызове новой операции

Заменить фрагмент в MainActivity:

getSupportFragmentManager().beginTransaction() 
       .replace(R.id.container, MainFragment.newInstance()) 
       .commit(); 

XML из MainActivity:

<?xml version="1.0" encoding="utf-8"?> 
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:app="http://schemas.android.com/apk/res-auto" 
android:id="@+id/main_content" 
android:layout_width="match_parent" 
android:layout_height="match_parent"> 

<android.support.design.widget.AppBarLayout 
    android:id="@+id/appBar" 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:theme="@style/ThemeOverlay.AppCompat.ActionBar"> 

    <android.support.v7.widget.Toolbar 
     android:id="@+id/toolbar" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:background="?attr/colorPrimary" 
     android:minHeight="?attr/actionBarSize" 
     app:layout_scrollFlags="scroll|enterAlways" 
     app:titleTextColor="@android:color/white" /> 
</android.support.design.widget.AppBarLayout> 

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:id="@+id/container" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    app:layout_behavior="@string/appbar_scrolling_view_behavior"> 
</FrameLayout> 

Это прекрасно работает.

Проблема теперь в моем классе фрагментов. Я хочу вызвать новую группу Activity (DetailRfrdPastActivity) из класса фрагмента. Как только я добавить элемент в XML DetailRfrdPastActivity приложение останавливается со следующей ошибкой:

java.lang.IllegalArgumentException: No view found for id 0x7f0c0071 (com.scherrer.robin.chvote:id/touch_outside) for fragment MainFragment{610d48e #0 id=0x7f0c0071} at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1098) at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1286) at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:758) at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1671) at android.support.v4.app.FragmentManagerImpl$1.run(FragmentManager.java:532) at android.os.Handler.handleCallback(Handler.java:739) at android.os.Handler.dispatchMessage(Handler.java:95) at android.os.Looper.loop(Looper.java:148) at android.app.ActivityThread.main(ActivityThread.java:5417) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)

В классе осколка я начинаю свою деятельность, как это:

public class MainFragment extends Fragment implements SearchView.OnQueryTextListener, FlexibleAdapter.OnItemClickListener { 

public static MainFragment newInstance() { 
    return new MainFragment(); 
} 

private RecyclerView mRecyclerView; 
private FlexibleAdapter<IFlexible> mAdapter; 
private List<IFlexible> originalItems; 

@Override 
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { 
    final View view = inflater.inflate(R.layout.fragment_main, container, false); 

    mRecyclerView = (RecyclerView) view.findViewById(R.id.lvRef); 

    return view; 
} 

@Override 
public void onViewCreated(View view, Bundle savedInstanceState) { 
    super.onViewCreated(view, savedInstanceState); 
    setHasOptionsMenu(true); 

    this.mRecyclerView.setLayoutManager(new LinearLayoutManager(getActivity())); 

    originalItems = AdapterData.getRfrdList(); 

    mAdapter = new FlexibleAdapter<>(AdapterData.getRfrdList()); 
    mAdapter.showAllHeaders(); 
    mAdapter.initializeListeners(this); 

    mRecyclerView.setAdapter(mAdapter); 
    mAdapter.enableStickyHeaders(); 
} 

@Override 
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) { 
    inflater.inflate(R.menu.menu_main, menu); 

    final MenuItem item = menu.findItem(R.id.action_search); 
    final SearchView searchView = (SearchView) MenuItemCompat.getActionView(item); 
    searchView.setOnQueryTextListener(this); 
} 

@Override 
public boolean onQueryTextChange(String query) { 
    List<IFlexible> copyOriginalItems = new ArrayList<>(originalItems); 

    mAdapter.setSearchText(query); 
    mAdapter.filterItems(copyOriginalItems); 

    return true; 
} 

@Override 
public boolean onQueryTextSubmit(String query) { 
    return false; 
} 

@Override 
public boolean onItemClick(int itemPosition) { 
    IFlexible clickedItem = mAdapter.getItem(itemPosition); 

    if (clickedItem instanceof ItemRfrdPast) { 
     Intent detailRfrdPast = new Intent(getActivity().getApplicationContext(), DetailRfrdPastActivity.class); 
     detailRfrdPast.putExtra("pastRfrd", ((ItemRfrdPast) clickedItem).getPastRfrd()); 
     getActivity().startActivity(detailRfrdPast); 
    } 

    return true; 
} 

}

XML Фрагмент из:

<?xml version="1.0" encoding="utf-8"?> 
<FrameLayout 
xmlns:android="http://schemas.android.com/apk/res/android" 
android:layout_width="match_parent" 
android:layout_height="match_parent"> 

<android.support.v7.widget.RecyclerView 
    android:id="@+id/lvRef" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:scrollbars="vertical" /> 

<include layout="@layout/sticky_header_layout"/> 

DetailRfrdPastActivity - дочерняя активность MainActivity. Я не могу понять, где ошибка, потому что фрагмент и вызываемая деятельность не должны иметь ничего общего друг с другом.

Manifest:

<?xml version="1.0" encoding="utf-8"?> 

<uses-permission android:name="android.permission.INTERNET" /> 
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> 
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> 
<uses-permission android:name="android.permission.WAKE_LOCK" /> 
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> 
<uses-permission android:name="android.permission.READ_PHONE_STATE" /> 

<application 
    android:allowBackup="true" 
    android:icon="@mipmap/ic_launcher" 
    android:label="@string/app_name" 
    android:supportsRtl="true" 
    android:theme="@style/AppTheme"> 
    <activity 
     android:name=".activities.MainActivity" 
     android:launchMode="singleTop" > 
     <intent-filter> 
      <action android:name="android.intent.action.MAIN" /> 

      <category android:name="android.intent.category.LAUNCHER" /> 
     </intent-filter> 
    </activity> 
    <activity 
     android:name=".activities.DetailRfrdPastActivity" 
     android:parentActivityName=".activities.MainActivity" > 

    </activity> 
</application> 

+0

показать полный код для фрагментов – Vickyexpert

+1

Попробуйте заменить 'getSupportFragmentManager(). BeginTransaction()' с 'getChildFragmentManager(). BeginTransaction()'. –

+0

@ Vickyexpert добавил код фрагмента –

ответ

1

FTW, я считаю, что устанавливая onClickListener от ViewHolder и вызова обратного вызова с выбранным элементом будет делать хорошо.

Например:

От FlexibleAdapter класса

public interface OnIFlexibleClickListener { 

    void onIFlexibleClick(IFlexible iFlexible); 

} 

private OnIFlexibleClickListener listener; 

public setOnIFlexibleClickListener(OnIFlexibleClickListener listener) { 
    this.listener = listener; 
} 

public IFlexible getIFlexible(int position) { 
     return iFlexibleList.get(position); //Your iFlexible List 
} 

public class FindViewHolder extends RecyclerView.ViewHolder { 
    private TextView textView; //Replace the TextView with your own view. 

    public FindViewHolder(View itemView) { 
     super(itemView); 
     textView = (TextView) itemView; 
     textView.setOnClickListener(new View.OnClickListener() { 
      @Override 
      public void onClick(View v) { 
       if (listener != null) { 
        listener.onIFlexibleClick(getIFlexible(getAdapterPosition())); 
       } 
      } 
     }); 
    } 
} 

Из класса MainFragment, реализовать OnIFlexibleClickListener

@Override 
public void onIFlexibleClick(IFlexible iFlexible) { 
    if (iFlexible instanceof ItemRfrdPast) { 
     ItemRfrdPast itemRfrdPast = ((ItemRfrdPast) iFlexible).getPastRfrd() 

     Intent intent = new Intent(getContext(), DetailRfrdPastActivity.class); 
     intent.putExtra(PAST_RFRD, itemRfrdPast); //public static final String PAST_RFRD = "pastRfrd"; 
     getActivity().startActivityForResult(intent, DetailRfrdPastActivity.REQUEST_CODE); //create a public static final int REQUEST_CODE 
    } 
} 

Я думаю, что это должно исправить. Приветствия.

+0

Спасибо! довольно хороший ответ! –

0

Это показывает, что вид ID: идентификатор/touch_outside отсутствует из файла XML MainFragment. Пожалуйста, проверьте этот идентификатор в вашем XML, а также включены XMLs

0

Заменить

getSupportFragmentManager().beginTransaction() 

с

getChildFragmentManager().beginTransaction() 

Почему так?

May be because it can't find the Fragment with the given ID because it's in a different FragmentManager .

сошлитесь difference

+0

getChildFragmentManager(). BeginTransaction() работает только во фрагменте, а не в действии. Или я ошибаюсь? –

+0

Да, вы правы. Я также не пробовал это, но что, если вы используете 'android.support.v4.app.Fragment.getChildFragmentManager()' full, как есть. ? Попробуйте один раз, если вы не работаете, я удалю это ans. –

Смежные вопросы