6

次のように、メイン レイアウトに GridView があります。

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <GridView
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:id="@+id/gridview"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:gravity="center"
        android:horizontalSpacing="1dp"
        android:stretchMode="columnWidth"
        android:verticalSpacing="1dp" />

</LinearLayout>

このようなグリッドを生成します ここに画像の説明を入力

各セルの内容は、次のようなレイアウトです。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:background="@drawable/btn_measurement" >

    <Button
        android:id="@+id/numerical"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:text="---" />

</LinearLayout>

しかし、4 番目の列を他の列の 3 分の 1 にしたいのですが、できません。

リンクを確認しました:

さまざまな列サイズの GridViewとAndroid GridView 列のストレッチ

しかし、彼らは役に立ちませんでした。:(

解決策を完全に変更する必要があると思われる場合は、一般的な手がかりを提供するよりも正確にお願いします。ありがとう

4

3 に答える 3

1

このコードを使用して列のサイズを小さくしますが、ここではいくつかのロジックを適用する必要があります。4番目の列を小さくしたいので、 getView() メソッドをオーバーライドしてから、いくつかの変数を使用し、その変数が3または7または11であるかどうかを確認する必要があります...次に、ボタンのサイズを小さくします。私はあなたが私のポイントを得たと思います....

    int logic =3;
    public View getView(int position, View convertView, ViewGroup parent) {
          Button btn;
          LinearLayout layout;
          if (convertView == null) {

            convertView = inflate the layout and initialize convertview

          if(position % logic==0)
    converView..setLayoutParams(new LinearLayout.LayoutParams(LinearLayout.LayoutParams.FILL_PARENT,
                                                                LinearLayout.LayoutParams.FILL_PARENT,
                                                              (float) 0.3));


        btn = new Button(context);
        btn.setGravity(Gravity.RIGHT);
        btn.setPadding(5, 5, 5, 5);


        layout = new LinearLayout(context);
        layout.setOrientation(0);
        layout.setPadding(5, 5, 5, 10);

        btn.setText(names[position]);

        layout.addView(btn);
    }
    else {
        layout = (LinearLayout) convertView;
        btn = (Button) layout.getChildAt(0);
        btn.setText(names[position]);

    }

    return layout;
}
于 2012-10-13T06:20:11.713 に答える
1

「可変スパン サイズ」の下に示されているように、カスタム GridLayoutManager で (GridView の代わりに) RecyclerView を使用します

基本的に、各通常の列が 3 倍になり、小さい列が 1 倍になります。

GridLayoutManager manager = new GridLayoutManager(this, 10); // 3 cols of 3 + 1 col of 1
manager.setSpanSizeLookup(new GridLayoutManager.SpanSizeLookup() {
  @Override
  public int getSpanSize(int position) {
    if (position % 4 == 3)
       return 1; // Fourth column is 1x
    else
       return 3; // Remaining columns are 3x
  }
});
recyclerView.setLayoutManager(manager);
于 2015-12-31T02:59:42.213 に答える