私たちのアプリでは、GridLayout にフラグメントを動的に追加しようとしています。空のグリッド レイアウトは、フラグメントのレイアウトと同様に XML で定義されます。実行時にいくつかのデータを調べ、そこからレイアウトに追加するフラグメントの数と、各フラグメントに使用するレイアウトを決定します。生成されたビューにフラグメントにサイズを割り当てると、すべて機能しますが、フラグメントのレイアウト ファイルでサイズを指定すると、グリッド レイアウトには何も表示されません。もちろん、ビューを作成するときにサイズを指定することもできますが、各デバイスの正しいレイアウトを選択するために Android の組み込みシステムを利用できるため、フラグメントの xml レイアウトで指定することをお勧めします。
サポート ライブラリ フラグメントを使用しています。それが違いを生む場合、サポートライブラリGridLayoutを使用していません
関連するコードと xml は次のとおりです。
GridLayout XML:
<?xml version="1.0" encoding="utf-8"?>
<merge xmlns:android="http://schemas.android.com/apk/res/android">
<ScrollView
android:id="@+id/grid_scroll"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_above="@+id/bottom_fragment"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:layout_marginRight="8dp"
android:layout_marginTop="?android:attr/actionBarSize"
android:overScrollMode="ifContentScrolls" >
<GridLayout
android:id="@+id/grid"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:alignmentMode="alignMargins"
android:animateLayoutChanges="true"
android:columnCount="3"
android:columnOrderPreserved="true"
android:orientation="horizontal"
android:overScrollMode="ifContentScrolls"
android:rowOrderPreserved="true" >
</GridLayout>
</ScrollView>
</merge>
フラグメント XML の例
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="200dp"
android:layout_height="100dp"
android:alpha="1" >
<Button
android:id="@+id/button1"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:alpha="1.0" />
</RelativeLayout>
フラグメント onCreateView() メソッド
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
super.onCreateView(inflater, container, savedInstanceState);
View view;
GridLayout.Spec rowSpec = GridLayout.spec(mRowStart, mRowSpan);
GridLayout.Spec columnSpec;
GridLayout.LayoutParams childParams;
if (large) {;
view = inflater.inflate(R.layout.my_place_large, container, false);
columnSpec = GridLayout.spec(mColumnStart, 2);
childParams = new GridLayout.LayoutParams(rowSpec, columnSpec);
//childParams.width = 200; //If I do this everything works regardless of the layout size
} else {
view = inflater.inflate(R.layout.my_place_small, container, false);
columnSpec = GridLayout.spec(mColumnStart, 1);
childParams = new GridLayout.LayoutParams(rowSpec, columnSpec);
//childParams.width = 100; //If I do this everything works regardless of the layout size
}
childParams.setMargins(0, 0, 0, 0);
//childParams.height = 100; //If I do this everything works regardless of the layout size
view.setLayoutParams(childParams);
view.setId(ID);
return view;
}
フラグメントをレイアウトに追加するには
private void populateGrid() {
RelativeLayout gridParent = (RelativeLayout) mParentActivity.findViewById(R.id.locations);
mLocationsGrid = (GridLayout) gridParent.findViewById(R.id.grid);
nColumns = mLocationsGrid.getColumnCount();
mAdapter = new MyAdapter(mContext, this, mResolver); //This is how I keep track of the various fragments depending on my app's state
int nCards = mAdapter.getNumberOfCards();
FragmentManager fragmentManager = mParentActivity.getSupportFragmentManager();
FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
for (int i = 0; i < nCards; ++i) {
fragmentTransaction.add(mLocationsGrid.getId(), mAdapter.getFragmentAtIndex(i), String.valueOf(i));
}
fragmentTransaction.commit();
mPopulated = true;
}
それをカバーするべきだと思います。繰り返しますが、onCreateView() でディメンションを明示的に設定する行のコメントを外すと、それらは GridLayout に適切に表示されるので、フラグメント トランザクションと同様に、フラグメントやそのような作業を追跡するすべての機能を把握できます。この問題は、フラグメントの xml でサイズを指定しようとすると発生します。この場合、空白の画面が表示されます。
あなたの考え、提案、黙想は大歓迎です。ありがとう、ジャレッド