我正在开发一个 android 应用程序,其屏幕类似于下图 -
请注意单元格之间的横幅广告。由于 GridView 不支持这样的列跨度,我不知道该怎么做。
请提供任何建议。提前致谢。
我正在开发一个 android 应用程序,其屏幕类似于下图 -
请注意单元格之间的横幅广告。由于 GridView 不支持这样的列跨度,我不知道该怎么做。
请提供任何建议。提前致谢。
在我看来,最好的方法是将 RecyclerView 与 GridLayoutManager 一起使用。只需为 GridLayoutManager 提供 SpanSizeLookup 即可确定每个位置的大小。例如,第一个位置需要占据整排
//Two items in a row
int spanCount = 2;
GridLayoutManager manager = new GridLayoutManager(getActivity(),spanCount);
manager.setSpanSizeLookup(new GridLayoutManager.SpanSizeLookup() {
@Override
public int getSpanSize(int position) {
return (position == 0 ? spanCount : 1);
}
});
在您的适配器中提供 2 种类型的项目 - 普通项目和广告项目
最好通过 ItemDecoration 设置项目填充。
如果需要,我可以提供更多代码
您需要为 Gridview Adapter 中的项目创建两个布局。一个用于您要显示的内容,另一个用于 adView,并在创建视图时交替放置布局。
检查这个以获得更多想法。
好吧,我想我可以给你一些代码示例......首先,我添加了AsymmetricGridView。
compile 'com.felipecsl.asymmetricgridview:library:2.0.1'
我使用本指南。原来是这样一个附加适配器:
ListAdapter ia = new PreviewsAdapter(mContext, currentPreviews).setAdsWidth(numRows);
gridListView.setRequestedColumnWidth(Utils.dpToPx(mContext, 80));
gridListView.setAllowReordering(true);
AsymmetricGridViewAdapter asymmetricAdapter =
new AsymmetricGridViewAdapter<>(mContext, gridListView, ia);
gridListView.setAdapter(asymmetricAdapter);
gridListView.setOnItemClickListener(gridviewOnItemClickListener);
注意numRows。在添加物理视图之前,我们不知道会有多少列。而且我们无法知道有多少单元格(宽)需要广告。您可以使用标准方法 AsymmetricGridView。
我不得不使用这个可怕的代码(其中阻塞了我的常量。
Display display = mContext.getWindowManager().getDefaultDisplay();
Point size = new Point();
if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB_MR2){
display.getSize(size);
} else {
size.set(display.getWidth(), display.getHeight());
}
final int mSize;
if(getResources().getConfiguration().orientation == Configuration.ORIENTATION_PORTRAIT) {
mSize = Math.min(size.x, size.y);
} else if (getResources().getConfiguration().orientation == Configuration.ORIENTATION_LANDSCAPE) {
mSize = Math.max(size.x, size.y) - Math.min(size.x, size.y);
} else {
mSize = Math.min(size.x, size.y);
}
int numRows = Math.round((float) mSize / (float) Utils.dpToPx(mContext, 100));
// 80 width cell item + 20 padding
适配器PreviewsAdapter 中的所有魔法都扩展了 BaseAdapter
确定哪里有广告。我要在中间
adsId = currentPreviews.size() / 2;
伪造一些条目。我们的条目 nums + ad
public int getCount() {
return currentPreviews.size() + 1;
}
现在我们将返回对象。要么是我们的会员,要么是广告。
public Object getItem(int position) {
if(adsId != position) {
if(position >= adsId) {
position-=1;
}
return currentPreviews.get(position);
} else {
return new AdsItem(this.numRows, 1);
}
}
我们的对象必须实现 AsymmetricItem。广告也是。这是对象类广告的示例。
public class AdsItem implements AsymmetricItem {
private final int width;
private final int height;
public AdsItem(int adsWidth, int adsHeight) {
width = adsWidth;
height = adsHeight;
}
@Override
public int getColumnSpan() {
return width;
}
@Override
public int getRowSpan() {
return height;
}
@Override
public int describeContents() {
return 0;
}
@Override
public void writeToParcel(Parcel parcel, int i) {
}
}
getRowSpan、getColumnSpan 确定单元格中对象 View 的宽度和高度。
下面是获取View的方法:
public View getView(int position, View convertView, ViewGroup parent) {
if(adsId != position) {
ImageView imageView;
if (convertView == null) {
imageView = new SquareImageView(mContext);
imageView.setLayoutParams(new GridView.LayoutParams(GridView.LayoutParams.MATCH_PARENT, GridView.LayoutParams.MATCH_PARENT));
imageView.setPadding(10, 10, 10, 10);
} else {
imageView = (SquareImageView) convertView;
}
AvatarPart ap = (AvatarPart) getItem(position);
Bitmap b = imgs.get(ap.getFile());
imageView.setImageBitmap(b);
imageView.invalidate();
return imageView;
} else {
String adId = mContext.getResources().getString(R.string.add_id);
AdView mAdView = new AdView(mContext);
mAdView.setPadding(0, 15, 0, 15);
mAdView.setAdSize(AdSize.BANNER);
mAdView.setAdUnitId(adId);
AdRequest adRequest = new AdRequest.Builder()
.build();
if(mAdView.getAdSize() != null )
mAdView.loadAd(adRequest);
return mAdView;
}
}
但我不确定这条线:
imageView = (SquareImageView) convertView;
我不知道AdView是否可以到达那里。但是虽然它没有坏:D
要处理点击必须编写另一种方法。
public AvatarPart getItemWithoutAds(int position) {
if(position == adsId) return null;
if(position >= adsId) {
position-=1;
}
return currentPreviews.get(position);
}
实现一个自定义ArrayAdapter,这里是一个例子:开发一个自定义适配器