- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以这就是我想要实现的,是一个回收者 View 使用 3x3 网格,当项目超过 3x3 时,它们会溢出到下一个屏幕/页面。
所以我使用了水平滚动的recyclerview
这是我目前取得的成就
当项目数为 7 及以上时,我当前的代码确实有效。
当计数低于 7 时,我面临需要帮助的问题。
将我的问题列为问题
问题 1:
为什么 recyclerview 项目以垂直方式填充?
1 4
2 5
3 6
我已将我的 recyclerview 设置为水平滚动,
new GridLayoutManager(this, span, GridLayoutManager.HORIZONTAL, false);
问题 2:
当我的项目数是 6 时,如何避免行与行之间的空格?
问题 3:
当我的项目是 4 时,我想将我的项目显示为
1 2 3
4
或
1 3 4
2
当前显示为
如果我将 span 设置为 1,我会将网格设置为
1 2 3 4
导致 4 像这样离开屏幕
1 2 3 |4
我想避免。
==============
我使用的代码
布局:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="88dp"
android:layout_height="88dp"
android:gravity="center"
android:layout_margin="10dp"
android:background="@drawable/border"
android:orientation="vertical">
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:background="@android:color/darker_gray"
android:orientation="vertical"
android:weightSum="1">
<TextView
android:id="@+id/lblTitle"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:text="TEST"
android:textSize="20sp" />
<TextView
android:id="@+id/lblDesc"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/lblTitle"
android:layout_centerHorizontal="true"
android:text="TEST"
android:textSize="13sp" />
</RelativeLayout>
</LinearLayout>
适配器:
public class RecyclerViewAdapter extends RecyclerView.Adapter<RecyclerViewAdapter.CustomViewHolder> {
Context ctx;
List<String> listText;
public class CustomViewHolder extends RecyclerView.ViewHolder {
TextView lblText;
public CustomViewHolder(View view) {
super(view);
view.setClickable(true);
lblText = (TextView) view.findViewById(R.id.lblDesc);
}
}
public RecyclerViewAdapter(Context ctx, List<String> listText) {
this.ctx = ctx;
this.listText = listText;
}
@Override
public RecyclerViewAdapter.CustomViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View itemView = LayoutInflater.from(parent.getContext())
.inflate(R.layout.recycler_child_row, parent, false);
return new CustomViewHolder(itemView);
}
@Override
public void onBindViewHolder(CustomViewHolder holder, int position) {
holder.lblText.setText(listText.get(position));
}
@Override
public int getItemCount() {
return listText.size();
}
}
Activity
public class MainActivity extends AppCompatActivity {
private RecyclerView recyclerTest;
private GridLayoutManager gridLayoutRecyclerview;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
recyclerTest = (RecyclerView) findViewById(R.id.recyclerTest);
List<String> items = Arrays.asList("1", "2", "3", "4");
/*List<String> items = Arrays.asList("1", "2", "3", "4", "5");*/
/*List<String> items = Arrays.asList("1", "2", "3", "4", "5", "6", "7");*/
/*List<String> items = Arrays.asList("1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11");*/
/*List<String> items = Arrays.asList("1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13","14");*/
/*List<String> items = Arrays.asList("1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11","12","13","14","15");*/
/*List<String> items = Arrays.asList("1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11","12","13","14","15","16","17");*/
int span = 0;
if (items.size() <= 3) {
span = 1;
} else if (items.size() <= 6) {
span = 2;
} else {
span = 3;
}
gridLayoutRecyclerview = new GridLayoutManager(this, span, GridLayoutManager.HORIZONTAL, false);
recyclerTest.setLayoutManager(gridLayoutRecyclerview);
SnapHelper snapHelper = new GravitySnapHelper(Gravity.START);
snapHelper.attachToRecyclerView(recyclerTest);
recyclerTest.setAdapter(new RecyclerViewAdapter(this, items));
}
}
最佳答案
Why is the recyclerview items populated in vertical fashion?
1 4
2 5
3 6
RecyclerView 适用于滚动的列表。如果您有水平布局,它将填充第一列,然后是第二列,然后是第三列,等等。毕竟,这就是我们期望列表的工作方式。这就是“编号已关闭”的原因。它从第一列开始,填满后继续下一列。
When my item count is 6 , how do i avoid the space between the rows?
我不知道你的设置,但我猜你的 recyclerviews 高度设置为 match_parent
,所以它可能只是用完了所有可用的高度。 recyclerview 的 wrap_content
高度可能会有所帮助。
When my items are say 4 ,i want to show my items as
1 2 3
4or
1 3 4
2
同样,参见上文,这不是 RecyclerView 的工作方式。它总是一一填充列,而不是从一行开始。列数为 2 的 4 个项目将始终首先填充第一列,如下所示。
1 3
2 4
RecyclerView 可能无法满足您的所有需求。您可以切换到具有3 列且少于 9 个项目的垂直 网格布局。这样它就不会水平滚动,甚至会像您描述的那样填满 View 。对于超过 9 个项目,您仍然会显示水平版本并让它滚动。
您实际上描述的是自定义布局:您想要一个以特定方式运行的 View 。您可以查看如何创建自己的 ViewGroup
并使用它来按您喜欢的方式布置所有 View 。除非您想显示长列表,否则这可能是一个不错的替代选择。
关于android - Recyclerview 水平跨度和间距问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46206283/
我目前正在研究一个项目欧拉问题(www.projecteuler.net),但遇到了一个绊脚石。其中一个问题提供了一个 20x20 的数字网格,并要求直线上 4 个数字的最大乘积。这条线可以是水平的、
我有两个表,我需要从每个表中选择一列。 这必须在单个查询中完成。 好消息是这两列以正确的方式排序,并且它们都包含相同数量的行。 现在,我知道我可以通过 rowid 加入两个表,但它很慢,因为它必须进行
我想在我的 iPad 应用程序中实现一个布局,该布局具有一个可左右滚动而不是上下滚动的合适 View : 所以而不是 第 1 行第 2 行第 3 行(垂直滚动)这将是 :第 1 行、第 2 行、第 3
我有五个尺寸的图像:600x30、600x30、600x30、600x30、810x30。它们的名称分别是:0.png、1.png、2.png、3.png、4.png。 如何使用 ImageMagic
我正在寻找一个选项来滚动多个列表(水平),如附件中的图片所示。您可以向左或向右滑动以进入下一个 ListView 。顶部应该有一些按钮可以单击或滚动 我尝试将 ListViews 放入类似此代码的内容
这些值之间是否存在数学关系?如果我知道 hFOV 和 vFOV,我可以计算对角 FOV 而不涉及焦距等其他值吗? 我的第一个想法是使用毕达哥拉斯定理,但也许这是错误的。 最佳答案 感兴趣的物理量是传感
我正在尝试在 game_width=640 和 game_height=480 的窗口内绘制网格。网格单元的数量是预定义的。我想在水平和垂直方向上均匀分布单元格。 void GamePaint(HDC
你好,我已经发布了我的 iphone 应用程序 Micro-Pitch,现在正在将它移植到 android 上。我不知道如何在 ScrollView 中画线,想知道我做错了什么。 这是我的 Scrol
如果您访问我的网站:www.ryancoughlin.com - 如果您在页面右侧看到 Google、Yahoo 等 RSS 按钮。我试图让它们均匀对齐,它们的图像高度都相同,我一直试图让它们均匀对齐
我想将此 Material 水平居中: 最佳答案 将 text-align:center 添加到您的 anchor 。我假设您的 zoom1 具有 display
我正在努力做到这一点,以便我的旋转木马可以与其他文本共享一个水平行,但由于某种原因它无法正常工作,当它设置为 40% 时它占据了 100% 的宽度。 我将在下面发布代码和屏幕截图。 在上图中,它显示了
问题来了。我正在尝试放置一些 彼此相邻的元素。 div 的宽度s 未指定,取决于它们的内容。我正在使用下面的 CSS 代码来定位 彼此相邻: #div{ height: 50px; f
我正在尝试使用这样的 Bootstrap 并排打印表格 但是当我尝试打印预览时,我得到了这个 我的代码如下。我尝试了所有可能的解决方案,但我不知道为什么我无法打印我看到的页面。请指导我解决这个问题。
我想知道是否可以在背景中使用两种不同的颜色,并通过 Bootstrap 在每一侧扩展 100%。 这是我的意思的截图, 左侧为红色,右侧为深色,为更大的屏幕放大 100%。有什么简单的解决方案吗? 最
我正在尝试制作一个包含所有事件的滚动触发的整个网站。我只需要帮助来实现这种效果: 我有一个网站,其中包含一些填满所有视口(viewport)的 div,我希望用户能够向下滚动到一个命名的 div,然后
我的代码是 Show All Show Valid Show Pending Save Clear Download As CSV 我希望那些输入日期和按钮在 class="buttons" di
我在玩这个想法: 在这个 block 中我有 2 作为按钮和 并尝试了 float荷兰国际集团他们让他们粘在一起。实现这种效果的主要思想是操纵 ul 的宽度/显示状态。或者只是菜单部分。 Log
这个问题在这里已经有了答案: How can I horizontally center an element? (134 个回答) 关闭 4 年前。
我遇到了一个 CSS 问题,需要帮助。我在目录中有许多不同大小的图像,我正在动态列出它们以显示以下 View :(我仅显示两个图像作为示例) 这是我的 HTML:
这个问题在这里已经有了答案: 关闭 9 年前。 Possible Duplicate: How can I make a horizontal ListView in Android? 我已经多次使
我是一名优秀的程序员,十分优秀!