所以,我在我的应用上遇到了一个非常奇怪的GridView问题。
我想要做的很简单:我只想获得已安装的应用程序列表(a-la app抽屉),并在gridview中按字母顺序显示它们。
效果很好,它们都很好地显示出来,但只要我向下滚动以查看更多应用并向上滚动,顶部的应用就会稍微偏离。垂直方面,更确切地说,每当我向下滚动超过1-2行并向上滚动时,就会发生这种情况。
此外,有时候我会滚动回到顶部并继续滚动顶部应用程序进入遗忘状态,而不是让我向下滚动。我不确定问题是否相关,但我确定要修复这两个问题。单击其中一个项目或在应用程序中切换窗口后,gridView将完全重置为正常。
这只是我第二天使用Android Layouts等等,尽管我之前已经完成了Java编程很长时间,所以我可能会遗漏一些东西,但我并不是全新的。< / p>
我已经在线查看了,我找不到有效的答案,我已经尝试了所有我发现的答案,而现在我只是在解决问题我已经在我的代码中实现了,所以除了这里我不确定该去哪里。
我也不确定要发布哪些代码来解决这个问题,而且我不想把它变成一个巨大的文本墙,包含我的每一个相关文件,所以如果有人可以指导我展示什么,我会非常感激。
我将从我的GridView布局,我的单元格布局和我的适配器的getView方法开始,因为这些似乎是我发现的大多数解决方案所引导的地方。如果您需要更多我的代码,请告诉我。
layout_grid
<GridView
android:id="@+id/gridView1"
android:layout_width="match_parent"
android:layout_height="488dp"
android:numColumns="5"
android:textAlignment="center"
android:verticalSpacing="5dp" >
</GridView>
</LinearLayout>
layout_app
<ImageView
android:id="@+id/ivIcon"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginRight="5dip"
android:scaleType="center"
android:adjustViewBounds="true"
/>
<TextView
android:id="@+id/tvName"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center_vertical"
/>
</LinearLayout>
getView
public View getView(int position, View convertView, ViewGroup parent) {
View v;
if(convertView == null){
v = LayoutInflater.from(mContext).inflate(R.layout.layout_app, null);
//mContext is defined in the constructor for my Adapter
}else{
v = convertView;
}
ImageView icon = (ImageView)v.findViewById(R.id.ivIcon);
TextView name = (TextView)v.findViewById(R.id.tvName);
icon.setImageDrawable(getItem(position).getIcon());
name.setText(getItem(position).getName());
//getIcon and getName are from a custom App class made to store app info.
return v;
}
我有照片的样子,但是由于我的声誉,它不允许我发布它们或给所有人发布链接,所以如果你想看到特别的东西就问我。
PS:我遇到的另一个小问题是,有些图标似乎没有完全缩小到ImageView的大小,但据我所知,这完全没有关系。不是这篇文章的重点。如果你愿意的话,你也可以帮助我:P答案 0 :(得分:2)
我想通了,虽然我不太清楚为什么会这样。显然,由于我的单个单元格没有硬编码高度,因此它们会调整到它们周围的文本并改变大小,从而改变其他单元格的位置。我仍然不知道为什么整个过度滚动的事情发生了,我认为这只是gridview的一个错误,但我觉得很奇怪没有人提到它。哦,好吧......