J’ai le code suivant qui fonctionne qui génère des fragments, mais seulement si je les ajoute à une disposition linéaire qui existe dans mon fichier XML.
LinearLayout fragmentsLayout = (LinearLayout) findViewById(R.id.foodItemActvity_linearLayout_fragments); FragmentManager fragMan = getFragmentManager(); FragmentTransaction fragTransaction = fragMan.beginTransaction(); Fragment myFrag= new ImageFragment(); fragTransaction.add(R.id.foodItemActvity_linearLayout_fragments, myFrag , "fragment" + fragCount); fragTransaction.commit();
Maintenant, que faire si je veux append ce fragment à une disposition linéaire qui n’existe pas déjà dans le fichier XML, telle que
LinearLayout rowLayout = new LinearLayout();
Partie 2:
Fragment frag1 = generateAppropriateFragment(type1); Fragment frag2 = generateAppropriateFragment(type2); LinearLayout fragmentsLayout = (LinearLayout) findViewById(R.id.foodItemActvity_linearLayout_fragments); LinearLayout rowLayout = new LinearLayout(this); rowLayout.setId(12345); // add counter to end fragmentsLayout.addView(rowLayout); getFragmentManager().beginTransaction().add(rowLayout.getId(), frag1, "fragment_grandchild" + fragCount).commit(); fragCount++; getFragmentManager().beginTransaction().add(rowLayout.getId(), frag2, "fragment_grandchild" + fragCount).commit(); fragCount++;
À un moment donné, je suppose que vous appendez votre LinearLayout créé par programmation à une présentation racine que vous avez définie dans .xml. Ceci est juste une suggestion de moi et probablement une de nombreuses solutions, mais cela fonctionne: il suffit de définir un ID pour la mise en page créée par programme et de l’append à la disposition racine que vous avez définie dans .xml, puis d’ utiliser le fragment.
Cela pourrait ressembler à ceci:
LinearLayout rowLayout = new LinearLayout(); rowLayout.setId(whateveryouwantasid); // add rowLayout to the root layout somewhere here FragmentManager fragMan = getFragmentManager(); FragmentTransaction fragTransaction = fragMan.beginTransaction(); Fragment myFrag = new ImageFragment(); fragTransaction.add(rowLayout.getId(), myFrag , "fragment" + fragCount); fragTransaction.commit();
Choisissez simplement la valeur entière que vous voulez pour l’ID:
rowLayout.setId(12345);
Si vous n’utilisez pas une seule fois la ligne de code ci-dessus, il serait probablement judicieux de trouver un moyen de créer des identifiants uniques afin d’ éviter les doublons .
METTRE À JOUR:
Voici le code complet de la façon dont cela doit être fait: (ce code est testé et fonctionne) J’ajoute deux fragments à une LinearLayout avec une orientation horizontale, ce qui fait que les fragments sont alignés les uns à côté des autres. Sachez également que j’ai utilisé une hauteur et une largeur fixes de 200dp, de sorte qu’un fragment n’utilise pas le plein écran comme avec “match_parent”.
MainActivity.java:
public class MainActivity extends Activity { @SuppressLint("NewApi") @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); LinearLayout fragContainer = (LinearLayout) findViewById(R.id.llFragmentContainer); LinearLayout ll = new LinearLayout(this); ll.setOrientation(LinearLayout.HORIZONTAL); ll.setId(12345); getFragmentManager().beginTransaction().add(ll.getId(), TestFragment.newInstance("I am frag 1"), "someTag1").commit(); getFragmentManager().beginTransaction().add(ll.getId(), TestFragment.newInstance("I am frag 2"), "someTag2").commit(); fragContainer.addView(ll); } }
TestFragment.java:
public class TestFragment extends Fragment { public static TestFragment newInstance(Ssortingng text) { TestFragment f = new TestFragment(); Bundle b = new Bundle(); b.putSsortingng("text", text); f.setArguments(b); return f; } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View v = inflater.inflate(R.layout.fragment, container, false); ((TextView) v.findViewById(R.id.tvFragText)).setText(getArguments().getSsortingng("text")); return v; } }
activity_main.xml:
fragment.xml:
Et c’est le résultat du code ci-dessus: (les deux fragments sont alignés l’un à côté de l’autre)