我想更好地了解Gridview
的工作原理,尤其是auto_fit
。
这是XML布局:
<?xml version="1.0" encoding="utf-8"?>
<GridView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/gridview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:columnWidth="60dp"
android:numColumns="auto_fit"
/>
它可以正常使用一系列六个缩略图(48 * 48像素)。在纵向模式下,它显示一行,六列。
我不明白为什么行android:columnWidth="60dp"
是必要的,因为auto_fit应该找到正确数量的列。
没有行android:columnWidth="60dp"
,它会显示一个3行和2列的网格。
以下是ImageAdapter
类:
package com.examples.HelloGridView;
import android.content.Context;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
public class ImageAdapter extends BaseAdapter {
private Context mContext;
public ImageAdapter(Context c) {
mContext = c;
}
public int getCount() {
return mThumbIds.length;
}
public Object getItem(int position) {
return null;
}
public long getItemId(int position) {
return 0;
}
// create a new ImageView for each item referenced by the Adapter
public View getView(int position, View convertView, ViewGroup parent) {
ImageView imageView;
if (convertView == null) { // if it's not recycled, initialize some attributes
imageView = new ImageView(mContext);
imageView.setPadding(0, 0, 0, 0);
} else {
imageView = (ImageView) convertView;
}
imageView.setImageResource(mThumbIds[position]);
return imageView;
}
// references to our images
private Integer[] mThumbIds = {
R.drawable.ic_1, R.drawable.ic_2,
R.drawable.ic_3, R.drawable.ic_4,
R.drawable.ic_5, R.drawable.ic_6
};
}
感谢您的帮助。
答案 0 :(得分:94)
查看GridView源代码,很明显在ImageView上设置填充和高度根本无济于事。如果未指定列宽,则只选择预设数量的列(2):
private void determineColumns(int availableSpace) {
...
if (mRequestedNumColumns == AUTO_FIT) {
if (requestedColumnWidth > 0) {
// Client told us to pick the number of columns
mNumColumns = (availableSpace + requestedHorizontalSpacing) /
(requestedColumnWidth + requestedHorizontalSpacing);
} else {
// Just make up a number if we don't have enough info
mNumColumns = 2;
}
} else {
// We picked the columns
mNumColumns = mRequestedNumColumns;
}
if (mNumColumns <= 0) {
mNumColumns = 1;
}
...
解决方案是在设置GridView的列宽之前测量列大小。以下是在屏幕外测量视图的快速方法:
public int measureCellWidth( Context context, View cell )
{
// We need a fake parent
FrameLayout buffer = new FrameLayout( context );
android.widget.AbsListView.LayoutParams layoutParams = new android.widget.AbsListView.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
buffer.addView( cell, layoutParams);
cell.forceLayout();
cell.measure(1000, 1000);
int width = cell.getMeasuredWidth();
buffer.removeAllViews();
return width;
}
然后你只需设置GridView的列宽:
gridView.setColumnWidth( width );
答案 1 :(得分:7)
根据android:numColumns documentation
auto_fit
显示尽可能多的列以填充可用空间。
因此,如果您使用
插入ImageView
padding
设置为zero
margin
设置为zero
layout_width
设置为wrap_content
layout_height
设置为wrap_content
gridView应包含尽可能多的子项数
请记住您的ImageView可能会缩放(:
答案 2 :(得分:3)
这可能对某人有帮助...... 您需要手动查找宽度大小。根据宽度大小,您可以设置列
float scalefactor = getResources().getDisplayMetrics().density * 100;
int number = getWindowManager()
.getDefaultDisplay().getWidth();
int columns = (int) ((float) number / scalefactor) / 2;
if (columns == 0 || columns == 1)
columns = 2;
gridView.setNumColumns(columns);
答案 3 :(得分:1)
我发现我通常知道我希望我的列有多宽。要么我知道我的照片的大小,要么我让用户确定这个尺寸。因此我可以在我的Activity中设置宽度:
gridview = (GridView) findViewById(R.id.gridview);
SharedPreferences mySettings;
mySettings = getSharedPreferences(Constants.PREFERENCES, Context.MODE_PRIVATE);
int gridSize = 50 * Integer.parseInt(mySettings.getString("gridSize", "3"));
gridview.setColumnWidth(gridSize + 10);
多数民众赞成。 。 。
卢塞恩的问候, 斯蒂芬
答案 4 :(得分:1)
“wrap_content”就像文字编辑器的自动换行一样 - 如果图像不能适应最后一列的大小,则图像会流向下一行。但是,如果将numcolumns属性设置为数字,则网格可以拉伸/调整列(stretchModde是您可能希望结合使用的另一个属性)。
ps - 虽然你已经找到了答案,但很高兴知道这是否有帮助。