This is a common problem and with a variety of solutions. In the solution I'll show you in a little while we check in our Activity if there is an id for the 2nd Fragment ( the one that will play the role of the DetailFragment ).
One common tactic is having two different versions of the xml layout we are wokring on. One in the layout folder and another one in the layout-sw600dp or whatever we define for the dual mode.
The 2nd file contains one more FrameLayout so what we basically have to do is check if the view is there. If its true then we are on a dual mode, if not then we are on a single mode.
First we define a Boolean isDualMode with false as an initial value.
Then on onCreate we check for the details id :
View aView = findViewById(R.id.details);
if (aView != null) {
isDualPane = true;
}
If thats true we add and commit the DetailsFragment also.
Full code for onCreate() :
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
View aView = findViewById(R.id.details);
if (aView != null) {
isDualPane = true;
}
android.support.v4.app.FragmentManager fragmentManager = getSupportFragmentManager();
android.support.v4.app.FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
mainFragment = new MainFragment();
if (isDualPane) {
detailsFragment = new DetailsFragment();
fragmentManager.beginTransaction().add(R.id.details, detailsFragment).commit();
}
fragmentManager.beginTransaction().add(R.id.main, mainFragment).commit();
fragmentTransaction.commit();
}