- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 ListView 。显示为卡片 View 。在卡片 View 中,我有一个图像,我想根据对象类型动态更改它。因此,为此我创建了两种不同的布局,其中包含小图像和大图像。我已经创建了一个适配器并尝试在 onCreateViewHolder 中膨胀两个不同的布局。我在这些代码行上遇到空指针异常。不知道我错过了什么......请帮助..
itemViewHolder.big.setImageDrawable(drawable1);
itemViewHolder.small.setImageDrawable(drawable);
public class IAdapter extends RecyclerView.Adapter<IAdapter.ItemViewHolder> {
适配器代码
public class ItemAdapter extends RecyclerView.Adapter<IAdapter.ItemViewHolder> {
List<Expense> items;
public static final int TYPE1 = 1;
public static final int TYPE2 = 2;
IAdapter(List<Expense> items) {
this.items = items;
}
@Override
public int getItemCount() {
return items.size();
}
@Override
public int getItemViewType(int position) {
Expense e = new Expense();
if (TYPE1 == 1) {
int type = e.getExpenseType();
return type;
} else {
return TYPE2;
}
}
@Override
public void onBindViewHolder(ItemViewHolder itemViewHolder, int i) {
itemViewHolder.amount.setText(items.get(i).amount);
itemViewHolder.expense.setText(items.get(i).expense);
TextDrawable drawable = TextDrawable.builder()
.beginConfig()
.withBorder(4)
.textColor(Color.BLACK)
.useFont(Typeface.DEFAULT)
.fontSize(25)
.bold()
.toUpperCase()
.endConfig()
.buildRound("11:00", Color.GRAY);
itemViewHolder.small.setImageDrawable(drawable);
TextDrawable drawable1 = TextDrawable.builder()
.beginConfig()
.withBorder(4)
.textColor(Color.BLACK)
.useFont(Typeface.DEFAULT)
.fontSize(25)
.bold()
.toUpperCase()
.endConfig()
.buildRound("10 Jan", Color.CYAN);
itemViewHolder.big.setImageDrawable(drawable1);
}
@Override
public ItemViewHolder onCreateViewHolder(ViewGroup viewGroup, int viewType) {
if (viewType == TYPE1) {
View itemView = LayoutInflater.
from(viewGroup.getContext()).
inflate(R.layout.cardlayout, viewGroup, false);
return new ItemViewHolder(itemView, viewType);
} else {
View itemView = LayoutInflater.
from(viewGroup.getContext()).
inflate(R.layout.bigcircle, viewGroup, false);
ItemViewHolder ivh = new ItemViewHolder(itemView, viewType);
return ivh;
}
}
public static class ItemViewHolder extends RecyclerView.ViewHolder {
CardView cv;
TextView amount;
TextView expense;
ImageView small;
ImageView big;
ItemViewHolder(View itemView, int viewType) {
super(itemView);
amount = (TextView) itemView.findViewById(R.id.txtAmount);
expense = (TextView) itemView.findViewById(R.id.txtexpense);
cv = (CardView) itemView.findViewById(R.id.card_view);
small = (ImageView) itemView.findViewById(R.id.small);
big=(ImageView)itemView.findViewById(R.id.big);
// cv1 = (CardView) itemView.findViewById(R.id.card_view);
//TextDrawable drawable1 = TextDrawable.builder()
// .buildRound("20 Jan", Color.RED);
}
}
@Override
public void onAttachedToRecyclerView(RecyclerView recyclerView) {
super.onAttachedToRecyclerView(recyclerView);
}
}
卡片布局代码
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:card_view="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:weightSum="1"
android:orientation="vertical"
android:measureWithLargestChild="false"
android:background="@android:color/white">
<!-- A CardView that contains a TextView -->
<android.support.v7.widget.CardView
xmlns:card_view="http://schemas.android.com/apk/res-auto"
android:id="@+id/card_view"
android:layout_width="match_parent"
android:layout_height="80dp"
card_view:cardCornerRadius="4dp"
android:background="@android:color/white">
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/relativeLayout"
android:background="@android:color/white"
android:layout_alignParentTop="true">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceMedium"
android:id="@+id/txtAmount"
android:text="text1"
android:layout_centerVertical="true"
android:layout_toLeftOf="@+id/linearLayout"
android:layout_toStartOf="@+id/linearLayout"
android:layout_marginRight="24dp"
android:layout_marginEnd="24dp" />
<LinearLayout
android:orientation="vertical"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:weightSum="1"
android:id="@+id/linearLayout"
android:gravity="center_vertical"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true">
<ImageView
android:layout_width="40dp"
android:layout_height="25dp"
android:id="@+id/imageView2"
android:background="@drawable/line" />
<ImageView
android:id="@+id/small"
android:focusableInTouchMode="false"
android:layout_width="40dp"
android:layout_height="40dp"
android:background="@drawable/circle"/>
<ImageView
android:layout_width="40dp"
android:layout_height="25dp"
android:id="@+id/imageView3"
android:background="@drawable/line" />
</LinearLayout>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceMedium"
android:text="Medium Text"
android:id="@+id/txtexpense"
android:layout_centerVertical="true"
android:layout_toRightOf="@+id/linearLayout"
android:layout_toEndOf="@+id/linearLayout"
android:layout_marginLeft="24dp"
android:layout_marginStart="24dp" />
</RelativeLayout>
</android.support.v7.widget.CardView>
大圆卡布局代码
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:card_view="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:weightSum="1"
android:orientation="vertical"
android:measureWithLargestChild="false">
<!-- A CardView that contains a TextView -->
<android.support.v7.widget.CardView
xmlns:card_view="http://schemas.android.com/apk/res-auto"
android:id="@+id/card_view1"
android:layout_width="match_parent"
android:layout_height="80dp"
card_view:cardCornerRadius="4dp"
android:background="@android:color/white">
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/relativeLayout"
android:background="@android:color/white"
android:layout_alignParentTop="true">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceMedium"
android:id="@+id/txtAmount"
android:text="text1"
android:layout_centerVertical="true"
android:layout_toLeftOf="@+id/linearLayout"
android:layout_toStartOf="@+id/linearLayout"
android:layout_marginRight="24dp"
android:layout_marginEnd="24dp" />
<LinearLayout
android:orientation="vertical"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:weightSum="1"
android:id="@+id/linearLayout"
android:gravity="center_vertical"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true">
<ImageView
android:layout_width="50dp"
android:layout_height="25dp"
android:id="@+id/imageView2"
android:background="@drawable/line" />
<ImageView
android:id="@+id/big"
android:focusableInTouchMode="false"
android:layout_width="50dp"
android:layout_height="50dp"
android:background="@drawable/circle1"/>
<ImageView
android:layout_width="50dp"
android:layout_height="25dp"
android:id="@+id/imageView3"
android:background="@drawable/line" />
</LinearLayout>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceMedium"
android:text="Medium Text"
android:id="@+id/txtexpense"
android:layout_centerVertical="true"
android:layout_toRightOf="@+id/linearLayout"
android:layout_toEndOf="@+id/linearLayout"
android:layout_marginLeft="24dp"
android:layout_marginStart="24dp" />
</RelativeLayout>
</android.support.v7.widget.CardView>
</LinearLayout>
我错过了什么???
最佳答案
这是因为您在 onBindViewHolder
方法中使用了从 onCreateViewHolder
方法传递过来的 ItemViewHolder
。它失败的原因是,您传递了 2 个不同的膨胀 View ,一个包含 id big
的 View 元素,另一个包含 id small
的 View 元素。因此,itemViewHolder.big 或 itemViewHolder.small 变为空。抛出一个 NullPointerException
我认为您处理此问题的方式是正确的。
选项一:这是一种不同的实现方式。
如果你对这两个有完全不同的布局,你必须这样做。但是,如果卡片的布局相同,只是那些大图像和小图像发生了变化,我建议您保持单一布局并在语法上更改 ImageView 。
方案二
你的方法。我建议你坚持下去,因为这是做到这一点的优雅方式。但是你将不得不做一些小的调整。
@Override
public int getItemViewType(int position) {
return items.get(position).getExpenseType();// Assume that this return 1 0r 2
}
我建议您在此处设置值之前检查类型,假设您有一个 TYPE 类变量来保留每个项目的类型。
@Override
public void onBindViewHolder(ItemViewHolder itemViewHolder, int i) {
itemViewHolder.amount.setText(items.get(i).amount);
itemViewHolder.expense.setText(items.get(i).expense);
if(getItemViewType(i) == 1){
TextDrawable drawable = TextDrawable.builder()
.beginConfig()
.withBorder(4)
.textColor(Color.BLACK)
.useFont(Typeface.DEFAULT)
.fontSize(25)
.bold()
.toUpperCase()
.endConfig()
.buildRound("11:00", Color.GRAY);
itemViewHolder.small.setImageDrawable(drawable);
}else{
TextDrawable drawable1 = TextDrawable.builder()
.beginConfig()
.withBorder(4)
.textColor(Color.BLACK)
.useFont(Typeface.DEFAULT)
.fontSize(25)
.bold()
.toUpperCase()
.endConfig()
.buildRound("10 Jan", Color.CYAN);
itemViewHolder.big.setImageDrawable(drawable1);
}
}
这并没有改变我的答案。但这会给你一个好主意。你缺的空腔东西就在这,
public static class ItemViewHolder extends RecyclerView.ViewHolder {
CardView cv;
TextView amount;
TextView expense;
ImageView small;
ImageView big;
ItemViewHolder(View itemView, int viewType) {
super(itemView);
amount = (TextView) itemView.findViewById(R.id.txtAmount);
expense = (TextView) itemView.findViewById(R.id.txtexpense);
cv = (CardView) itemView.findViewById(R.id.card_view);
small = (ImageView) itemView.findViewById(R.id.small);
big=(ImageView)itemView.findViewById(R.id.big);
// cv1 = (CardView) itemView.findViewById(R.id.card_view);
//TextDrawable drawable1 = TextDrawable.builder()
// .buildRound("20 Jan", Color.RED);
}
}
即使你这样做
small = (ImageView) itemView.findViewById(R.id.small);
big=(ImageView)itemView.findViewById(R.id.big);
small 或 big 变量将被分配 null
。但是你必须在调用它的方法之前检查它。否则它会给出一个 NullPointerException
编辑:
或者你可以这样做,
@Override
public ItemViewHolder onCreateViewHolder(ViewGroup viewGroup,int viewType) {
View itemView;
if (getItemViewType(i)==1) {
itemView = LayoutInflater.
from(viewGroup.getContext()).
inflate(R.layout.cardlayout, viewGroup, false);
} else {
itemView = LayoutInflater.from(viewGroup.getContext()).
inflate(R.layout.bigcircle, viewGroup, false);
}
return new ItemViewHolder(itemView,viewType);
}
关于java - 如何膨胀多张卡片 View 布局,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32277124/
让我们开始吧,3 个类(Card、Start、Deckofcards) 1° 卡: public class Card { private String type; private i
我要创建一个二十一点游戏,我正在尝试弄清楚如何发牌并让它显示值和名称。我选择两个属性的原因纯粹是基于逻辑,当涉及到将 A 视为 1 或 11 时。还没有达到这一点,只是想如果有人想知道的话我会包括在内
我正在尝试使用 twitter 元标记(以及 Facebook 等其他网站的 Open Graph)创建 Twitter 卡片。当我看到来自其他人(例如 NPR 新闻)的推特提要时,卡片会默认展开。
我正在开发一个玩基本扑克游戏的程序,但这并不重要。我有一组 52 张牌,包含花色和等级。我想打印 4 行 13 行的值(花色和等级)。这可能是一个简单的问题,但我整天都在努力解决这个问题。因此,我非常
我开发了一个包含三列(两列相等,一列较小)的网格。我的问题是我无法在卡片上设置高度,我在 px 中使用了它们并且它起作用了,但这不是最好的方法。我希望这三列具有相同的高度(页面的 100%)并且一些卡
我在 4 个不同的列中开发了 4 个 Bootstrap 卡。在每张卡片中,我创建了一张包含某种类型信息的新卡片。 我的问题是,当我缩小屏幕尺寸(响应测试)时,文本会从卡片中溢出。我的问题是什么,我该
我怎样才能达到 固定高度 具有垂直可滚动 的 bootstrap 4 卡卡片文字部分? Card title This portion and
在我的程序中,我有一个大 Canvas ,我在其中提取多个选定区域并将这些区域绘制到单独的新小 Canvas 上。 我想使用此 API 将新创建的 Canvas 作为附件发布到 trello POST
我想在卡片 View 中显示联系信息,如果需要,应该调整卡片 View 的大小以包含所有信息。 这是布局部分: 但是 an
这是我的card_view。我已经提到了 card_view:cardElevation。但是仍然没有显示阴影。 我搜索了很多链接。他们在任何地方都提到要使用 card_view:cardElevat
我正在使用此处的框架 - cardsui 如何在卡片顶部添加分享按钮。我已经使用点击方法在 xml 中实现了它,但是当我按下它时应用程序崩溃并说该方法不存在(是的,我将该方法添加到主 java 文件中
我正在将 cardview 与 recycler view 一起使用。但早些时候我使用相同的代码来做事没有任何问题。但现在我正在使用 fragment 。现在我得到卡片 View 之间的距离更大。我的
我的卡片 View 设置如下: android:layout_marginTop="2dp" android:layout_marginLeft="6dp" android:layout_margin
我正在制作一个二十一点游戏,并创建了一个数组来充当用户发牌的手牌。我希望能够对其进行排序,以便手按数字顺序排序,这样可以更简单地确定用户的手的类型。这是我的卡片结构: struct ACard{
我希望在一个运行在 Wordpress 上的网站上实现 Twitter Cards(关于 Twitter Cards 的文档在这里:https://dev.twitter.com/docs/cards
我需要帮助解决这个难题。在 bootstrap 4.1 中使用卡片列和卡片时,当我不想这样做时,行会中断。我将列数设置为 4,当有 4 张卡片时,它看起来很完美。当添加第五张牌时,它会将行分成顶部的
我有一个 android ListView ,它显示类似卡片的 View ,正如您在这张图片中看到的,我的卡片之间有一条灰色细线: 我怎样才能摆脱灰线? 我实现这个卡片 View 的xml是这样的:
我正在尝试添加带有回收站 View 的卡片 View 。但它没有显示任何内容,只是一个空白 View 。 我在这里看到了这方面的问题,它有为回收站 View 和卡片 View 添加依赖项的答案。这出现
我在 android 中通过回收站 View 实现卡片 View ,但我的卡片 View 没有显示。我正在使用自定义适配器将数据填充到卡片 View 。我已经尝试了所有方法,但没有显示卡片 View
在我的应用程序中,我有一个卡片 View ,其中包含一个 TextView 和一个按钮,该按钮最初是隐藏的,当单击卡片 View 时,会显示该按钮。我不知道如何在显示按钮时将其设置为动画。任何人都可以
我是一名优秀的程序员,十分优秀!