向上滚动时项目覆盖
Item overlay when scroll up
我开发了一个 android 应用程序,在一个屏幕上有一个 gridview,其中有两个项目。
每个项目都由一张图片和下面的文字组成。
加载布局时,它会以正确的方式显示元素,但是当我向上滚动获取第一个元素时,会覆盖具有多行文本的项目。
这是元素的代码:
布局
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<GridView
android:id="@+id/atlas_list"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:numColumns="2"
android:orientation="vertical"
android:dividerHeight="15dp"
android:layout_marginStart="20dp"
android:layout_marginEnd="20dp"
android:layout_marginBottom="15dp"
android:divider="@android:color/transparent"/>
</LinearLayout>
</RelativeLayout>
项目
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:layout_margin="10dp">
<ImageView
android:id="@+id/atlas_item_image"
android:layout_width="match_parent"
android:layout_height="90dp"
android:layout_gravity="center"
android:layout_margin="15dp"/>
<TextView
android:id="@+id/atlas_item_text"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textSize="20sp"
android:textStyle="bold"
android:textColor="@android:color/holo_blue_dark"
android:fontFamily="casual"
android:textAlignment="center"/>
</LinearLayout>
将项目添加到 GridView
的代码是:
final GridView gridView = findViewById(R.id.atlas_list);
AtlasItemAdapter adapter = new AtlasItemAdapter(activity, atlasItems);
gridView.setAdapter(adapter);
其中 AtlasItemAdapter
是自定义 class 扩展 ArrayAdapter<AtlasItem>
,覆盖 getView
方法。
您可以检查 Play Store 中的应用程序以重现该行为。
提前致谢
我不太清楚为什么会这样,但我会做的是:使用 RecyclerView 和 GridLayoutManager 作为 LayoutManeger。
文件如下:
layout.xml
:
<android.support.v7.widget.RecyclerView
android:id="@+id/atlasList"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
Activity.java
:
RecyclerView myRecycler = findViewById(R.id.atlasList);
RecyclerView.LayoutManager mLayoutManager = new GridLayoutManager(context, 2);
myRecycler.setLayoutManager(mLayoutManager);
MyAdapter adapter = new MyAdapter(atlasList);
myRecycler.setAdapter(adapter);
Adapter.java
:
class MyAdapter extends RecyclerView.Adapter<Viewholder> {
private List<Atlas> list;
public MyAdapter(List<Atlas> atlasList) { this.list = atlasList; }
// needed methods of RecyclerView.Adapter class
}
我开发了一个 android 应用程序,在一个屏幕上有一个 gridview,其中有两个项目。
每个项目都由一张图片和下面的文字组成。
加载布局时,它会以正确的方式显示元素,但是当我向上滚动获取第一个元素时,会覆盖具有多行文本的项目。
这是元素的代码:
布局
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<GridView
android:id="@+id/atlas_list"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:numColumns="2"
android:orientation="vertical"
android:dividerHeight="15dp"
android:layout_marginStart="20dp"
android:layout_marginEnd="20dp"
android:layout_marginBottom="15dp"
android:divider="@android:color/transparent"/>
</LinearLayout>
</RelativeLayout>
项目
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:layout_margin="10dp">
<ImageView
android:id="@+id/atlas_item_image"
android:layout_width="match_parent"
android:layout_height="90dp"
android:layout_gravity="center"
android:layout_margin="15dp"/>
<TextView
android:id="@+id/atlas_item_text"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textSize="20sp"
android:textStyle="bold"
android:textColor="@android:color/holo_blue_dark"
android:fontFamily="casual"
android:textAlignment="center"/>
</LinearLayout>
将项目添加到 GridView
的代码是:
final GridView gridView = findViewById(R.id.atlas_list);
AtlasItemAdapter adapter = new AtlasItemAdapter(activity, atlasItems);
gridView.setAdapter(adapter);
其中 AtlasItemAdapter
是自定义 class 扩展 ArrayAdapter<AtlasItem>
,覆盖 getView
方法。
您可以检查 Play Store 中的应用程序以重现该行为。
提前致谢
我不太清楚为什么会这样,但我会做的是:使用 RecyclerView 和 GridLayoutManager 作为 LayoutManeger。
文件如下:
layout.xml
:
<android.support.v7.widget.RecyclerView
android:id="@+id/atlasList"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
Activity.java
:
RecyclerView myRecycler = findViewById(R.id.atlasList);
RecyclerView.LayoutManager mLayoutManager = new GridLayoutManager(context, 2);
myRecycler.setLayoutManager(mLayoutManager);
MyAdapter adapter = new MyAdapter(atlasList);
myRecycler.setAdapter(adapter);
Adapter.java
:
class MyAdapter extends RecyclerView.Adapter<Viewholder> {
private List<Atlas> list;
public MyAdapter(List<Atlas> atlasList) { this.list = atlasList; }
// needed methods of RecyclerView.Adapter class
}