- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
将 RelativeLayouts 作为 GridLayout 的单元格放置时,我遇到了一个奇怪的错误。我对此进行了扩展 proof-of-concept .当我将相同的 RelativeLayout 子类添加到前三个单元格时,只有第一个单元格的子级可见。该行中的后两个单元格是空白的,除了父级 RelativeLayout。
这是 RelativeLayout 子类、gridlayout 代码和子 XML。
public class MemberCardTile extends HomeBaseTile {
public MemberCardTile(Context context) {
super(context, R.layout.tile_member_card);
}
}
...及其父级:
abstract public class HomeBaseTile extends FrameLayout {
public HomeBaseTile(Context context, int childResourceId) {
super(context);
LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
View rl = inflater.inflate(R.layout.tile_member_card, null);
contentView = (ViewGroup)rl;
this.addView(contentView);
this.setPadding(0, 0, 0, 0);
}
@Override
public void setBackgroundColor(int color) {
this.contentView.setBackgroundColor(color);
super.setBackgroundColor(Color.BLACK);
}
}
当前的 GridLayout 代码虽然未经提炼,但显示为:
public static GridLayout layoutForInMarket(Context context, Point size) {
int screenWidth = size.x;
int tileHeight = (int) (size.y * 0.175f) - (TILE_PADDING );
int smallTileWidth = (int) (screenWidth * 0.33f) - (1 * TILE_PADDING + 2);
int mediumTileWidth = (int) (screenWidth * 0.66f) - (1 * TILE_PADDING);
int largeTileWidth = (int) (screenWidth * 0.99f) - (1 * TILE_PADDING);
// spec(Row, Row Span)
Spec row1 = GridLayout.spec(1, 1);
Spec row2 = GridLayout.spec(2, 1);
Spec row3 = GridLayout.spec(3, 1);
Spec row4 = GridLayout.spec(4, 1);
Spec row5 = GridLayout.spec(5, 1);
// spec(Column, Column Span)
Spec col0Small = GridLayout.spec(0, 1);
Spec col1Small = GridLayout.spec(1, 1);
Spec col2Small = GridLayout.spec(2, 1);
Spec col0Medium = GridLayout.spec(0, 2);
Spec col1Medium = GridLayout.spec(1, 2);
Spec col0Large = GridLayout.spec(0, 3);
GridLayout gridLayout = new GridLayout(context);
gridLayout.setBackgroundColor(Color.WHITE);
gridLayout.setColumnCount(15); // 3 works,
gridLayout.setRowCount(15); // Experiment with this. 6 works, not 5...
// ROW 1
// Item 1 (works fine)
MemberCardTile member = new MemberCardTile(context);
GridLayout.LayoutParams first = new GridLayout.LayoutParams(row1,
col0Small);
first.width = smallTileWidth;
first.height = tileHeight;
first.setMargins(TILE_PADDING, TILE_PADDING, TILE_PADDING, TILE_PADDING);
member.setBackgroundColor(Color.MAGENTA);
gridLayout.addView(member, first);
// item 2 (only the parent shows, no added subviews)
MemberCardTile member1 = new MemberCardTile(context);
GridLayout.LayoutParams first1 = new GridLayout.LayoutParams(row1,
col1Small);
first1.width = smallTileWidth;
first1.height = tileHeight;
first1.setMargins(TILE_PADDING, TILE_PADDING, TILE_PADDING,
TILE_PADDING);
member1.setBackgroundColor(Color.BLUE);
gridLayout.addView(member1, first1);
// item 3 (only the parent shows, no added subviews)
MemberCardTile member2 = new MemberCardTile(context);
GridLayout.LayoutParams first2 = new GridLayout.LayoutParams(row1,
col2Small);
first2.width = smallTileWidth;
first2.height = tileHeight;
first2.setMargins(TILE_PADDING, TILE_PADDING, TILE_PADDING,
TILE_PADDING);
member2.setBackgroundColor(Color.GREEN);
gridLayout.addView(member2, first2);
// ROW 2
TextView gymSite = new TextView(context);
GridLayout.LayoutParams third = new GridLayout.LayoutParams(row2,
col0Small);
third.width = smallTileWidth - 3;
third.height = tileHeight;
third.setMargins(5, 5, 5, 5);
gymSite.setBackgroundColor(Color.RED);
gymSite.setText("Gym Website");
gridLayout.addView(gymSite, third);
/** Remaining tiles are redacted, but appear just as the above (ROW 2) item */
return gridlayout;
}
我已经尝试过以编程方式添加子 RelativeLayout 和通过膨胀的 XML。在上面的示例中,我使用了膨胀的 XML。在这两种情况下,第一个单元格 (0,0) 显示而不是后续两个单元格。
XML:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent" >
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="HELLO"
android:textColor="@color/black" />
</RelativeLayout>
生成的 GridLayout 的屏幕截图(除了背景颜色(即洋红色、蓝色、绿色)外,第一行应该都显示相同)
我觉得这与 GridLayout 设置有关,但我不确定是什么。当我通过 View 创建断点时,肯定会创建第二个和第三个单元格的 View 并将其添加到 View 层次结构中。
我在 4.3 Galaxy Nexus 和 4.4 Nexus 5 上都试过了。
非常感谢任何帮助或建议。再次感谢。
最佳答案
尝试替换:
View rl = inflater.inflate(R.layout.tile_member_card, null);
contentView = (ViewGroup)rl;
this.addView(contentView);
与:
View rl = inflater.inflate(R.layout.tile_member_card, this);
这不仅一次性将子级添加到父级,而且这样做的方式将使 RelativeLayout
表现得更好。
关于android - 只有在 GridLayout 中显示 ViewGroup 的第一个 subview - 后续单元格在视觉上是无 subview 的,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20767155/
我已经尝试在我的 CSS 中添加一个元素来删除每三个 div 的 margin-right。不过,似乎只是出于某种原因影响了第 3 次和第 7 次。需要它在第 3、6、9 等日工作... CSS .s
如何使 div/input 闪烁或“脉冲”?例如,假设表单字段输入了无效值? 最佳答案 使用 CSS3 类似 on this page ,您可以将脉冲效果添加到名为 error 的类中: @-webk
我目前正在尝试构建一个简单的 wireframe来自 lattice 的情节包,但由沿 y 轴的数百个点组成。这导致绘图被线框网格淹没,您看到的只是一个黑色块。我知道我可以用 col=FALSE 完全
在知道 parent>div CSS 选择器在 IE 中无法识别后,我重新编码我的 CSS 样式,例如: div#bodyMain div#paneLeft>div{/*styles here*/}
我有两个 div,一个在另一个里面。当我将鼠标悬停 到最外面的那个时,我想改变它的颜色,没问题。但是,当我将鼠标悬停 到内部时,我只想更改它的颜色。这可能吗?换句话说,当 将鼠标悬停到内部 div 上
我需要展示这样的东西 有人可以帮忙吗?我可以实现以下输出 我正在使用以下代码:: GridView.builder( scrollDirection: Axis.vertical,
当 Bottom Sheet 像 Android 键盘一样打开时,是否有任何方法可以手动上推布局( ScrollView 或回收器 View 或整个 Activity )?或者你可以说我想以 Bott
我有以下代码,用于使用纯 HTML 和 CSS 显示翻转。当您将鼠标悬停在文本上时,它会更改左右图像。 在我测试的所有浏览器中都运行良好,Safari 4 除外。据我收集的信息,Safari 4 支持
我构建了某种 CMS,但在使用 TinyMCE 和 Bootstrap 时遇到了一些问题。 我有一个页面,其中概述了一个 div,如果用户单击该 div,他们可以从模态中选择图像。该图像被插入到一个
出于某种原因,当我设置一个过渡时,当我的鼠标悬停在一个元素上时,背景会改变颜色,它只适用于一个元素,但它们都共享同一个类?任何帮助我的 CSS .outer_ad { position:rel
好吧,这真的很愚蠢。我不知道 Android Studio 中的调试监视框架发生了什么。我有 1.5.1 的工作室。 是否有一些来自 intellij 的 secret 知识来展示它。 最佳答案 与以
我有这个标记: some code > 我正在尝试获取此布局: 注意:上一个和下一个按钮靠近#player 我正在尝试这样: .nextBtn{
网站:http://avuedesigns.com/index 首页有 6 个菜单项。我希望每件元素在您经过时都有自己的颜色。 这是当您将鼠标悬停在 div 上时将所有内容更改为白色的行 li#hom
我需要在 index.php 文件中显示它,但没有任何效果。我所有的文章都没有正确定位。我将其用作代码: 最佳答案 您可以首先检查您
我是一名优秀的程序员,十分优秀!