【问题标题】:Two views with different heights in a viewflipper on a gridview tile在 gridview tile 上的 viewflipper 中具有不同高度的两个视图
【发布时间】:2016-10-05 23:58:38
【问题描述】:

我有一个GridView,每个图块中都有一个ViewFlipperViewFlipper 中的每个视图都有不同的大小,但是当磁贴翻转时,两个视图都被强制为与 GridView 列相同的大小。我试过的:

  • 谷歌搜索
  • 在 ViewFlipper 上将 android:measureAllChildren 设置为 false仅适用于 ListView
  • android:columnWidth未指定
  • 在网格图块布局文件中制作了ViewFlipper 根标签

grid_item.xml:

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

<ViewFlipper
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:measureAllChildren="false"
    android:id="@+id/view_flipper_3"
    >

    <RelativeLayout
        android:layout_width="180dp"
        android:layout_height="150dp"
        android:id="@+id/front2"
        android:background="#088980"

        >

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/commitmentNumber"
            android:textSize="25dp"
            />
    </RelativeLayout>

    <RelativeLayout
        android:layout_width="220dp"
        android:layout_height="190dp"
        android:background="#000000"
        android:id="@+id/back_2"
        >

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentTop="true"
            android:id="@+id/commitmentPartOne"
            android:paddingBottom="5dp"
            android:textSize="25sp"
            android:text="Part One"
            android:layout_centerHorizontal="true"
            android:layout_centerVertical="true"
            />

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/commitmentPartTwo"
            android:textSize="25sp"
            android:text="Part Two"
            android:paddingBottom="5dp"
            android:layout_below="@+id/commitmentPartOne"
            android:layout_centerHorizontal="true"
            android:layout_centerVertical="true"
            />

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/commitmentPartThree"
            android:textSize="25sp"
            android:text="Part Three"
            android:layout_below="@+id/commitmentPartTwo"
            android:layout_centerHorizontal="true"
            android:layout_centerVertical="true"
            />

    </RelativeLayout>

</ViewFlipper>

</RelativeLayout>

fragment_with_gridview.xml:

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

<GridView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:id="@+id/sixCommitmentsGridView"
    android:layout_alignParentTop="true"
    android:layout_centerHorizontal="true"
    android:numColumns="2"
    android:gravity="center"
    android:columnWidth="179dp"
    android:stretchMode="columnWidth"
    />
</RelativeLayout>

GridViewAdapter.java:

public class SixCommitmentsGridAdapter extends BaseAdapter {

Context context;
String[] numbers;

public SixCommitmentsGridAdapter(Context context, String[] numbers) {
    this.context = context;
    this.numbers = numbers;
}

@Override
public int getCount() {
    return numbers.length;
}

@Override
public Object getItem(int position) {
    return numbers[position];
}

@Override
public long getItemId(int position) {
    return 0;
}

@Override
public View getView(final int position, View convertView, ViewGroup parent) {
    View view;
    final ViewFlipper flipper;
    TextView commitmentNumber;

    if(convertView == null){
       LayoutInflater inflater = (LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
        view = inflater.inflate(R.layout.six_commitments_grid_item, parent, false);
    }else{
        view = convertView;
    }

    flipper = (ViewFlipper) view.findViewById(R.id.view_flipper_3);
    commitmentNumber = (TextView) view.findViewById(R.id.commitmentNumber);

    commitmentNumber.setText(numbers[position]);
    flipper.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            if(position % 2 == 0 || position == 0){
                AnimationFactory.flipTransition(flipper, AnimationFactory.FlipDirection.RIGHT_LEFT, 200);
            }else {
                AnimationFactory.flipTransition(flipper, AnimationFactory.FlipDirection.LEFT_RIGHT, 200);
            }

        }

    });

    return view;
}
}

【问题讨论】:

    标签: android gridview android-viewflipper


    【解决方案1】:

    使用StaggeredGridLayoutManagerRecyclerView 实现了与我的意图ViewFlipper 效果相同的网格样式布局。

    【讨论】:

      【解决方案2】:

      在 Main RelativeLayout 包含 ViewFlipper,你设置高度和宽度! 将它们设置为“wrap_content”

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

      也许有效。 祝你好运。


      更新

      使用这个库:

      https://github.com/etsy/AndroidStaggeredGrid

      【讨论】:

      • 我试过了。没用。解决方案是使用 RecyclerView 而不是 GridView,并将 staggeredlayoutmanager 传递给 recyclerViews setLayoutManager 方法
      • 使用这个库,希望对你有用
      • 老兄......即使那个图书馆推荐我的方法
      猜你喜欢
      • 2012-10-07
      • 2015-08-24
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2020-08-27
      • 2021-11-16
      • 1970-01-01
      相关资源
      最近更新 更多