- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个卡片 View ,它显示即将举行的 Activity ,包括标题、日期等,并且有两个 ImageView 应充当按钮:如果单击其中一个,则应转到参与确认 Activity ,如果单击另一个,则应转到参与确认 Activity 详细 Activity 。这两者还应该使用 Intent (名称、日期、用户 ID、 token )传递信息。我已关注this tutorial ,因为这是最接近我的问题的解决方案,但它仍然不起作用。无论我如何更改,这些都是我得到的错误:尝试在空对象引用上调用虚拟方法 'void android.widget.ImageView.setOnClickListener(android.view.View$OnClickListener)' (这是我调用 setButtons 函数时给出的) ,或者如果 onclick 以某种方式工作, Intent 不会被传递,并且我得到一个 nullpointerException。我确保我使用了正确的 ID 和名称。附加信息:我正在使用 Laravel 和改造。 Activity Activity :
public class EventsActivity extends AppCompatActivity {
private static final String TAG = "EventsActivity";
private static final int ACTIVITY_NUM = 1;
private static final String PREFS_NAME = "LoginPrefs";
public static final String EVENT_DETAIL = "EVENT_DETAIL";
private Context mContext = EventsActivity.this;
private Event mEvent = new Event();
private String token, name;
private int id;
private EventAdapter adapter;
private RecyclerView recyclerView;
private List<Event> eventList = new ArrayList<>();
private List<Response> result;
private TextView noEvents;
private Button add, more;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_events);
//Get token and id from shared preferences
SharedPreferences settings = getSharedPreferences(PREFS_NAME, 0);
token = settings.getString("token", "");
id = settings.getInt("id", 0);
Log.d(TAG, "onResponse: id " + id + "token " + token);
noEvents = findViewById(R.id.noEvents);
recyclerView = findViewById(R.id.event_recyclerview);
RecyclerView.LayoutManager layoutManager = new LinearLayoutManager(mContext);
recyclerView.setLayoutManager(layoutManager);
adapter = new EventAdapter(mContext, eventList);
recyclerView.setAdapter(adapter);
adapter.setOnItemClickListener(new EventAdapter.OnItemClickListener() {
@Override
public void onAddClicked(int position) {
addClick(position);
}
@Override
public void onMoreClicked(int position) {
moreClick(position);
}
});
loadData();
setButtons();
}
public void addClick(int position){
final Event event = eventList.get(position);
Intent i = new Intent(EventsActivity.this, EventInvitationActivity.class);
i.putExtra("name", event.getName());
i.putExtra("name", event.getDescription());
i.putExtra("name", event.getDate());
i.putExtra("name", event.getLocation());
Log.i("hello", event.getName());
startActivity(i);
}
public void moreClick(int position){
final Event event = eventList.get(position);
Intent i = new Intent(EventsActivity.this, EventDetailActivity.class);
i.putExtra("name", event.getName());
Log.i("hello", event.getName());
startActivity(i);
}
void setButtons() {
add = findViewById(R.id.add_icon);
more = findViewById(R.id.more_icon);
Log.d(TAG, "setButtons: called");
add.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Log.d(TAG, "onClick: add onclicklistener");
int position = Integer.parseInt(v.getTag().toString());
addClick(position);
}
});
more.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
int position = Integer.parseInt(v.getTag().toString());
moreClick(position);
}
});
}
//Listing events
private void loadData(){
ApiEvents service = RetrofitBuilder.getRetrofitInstance().create(ApiEvents.class);
Call<List<Event>> call = service.listEvents("Bearer" + token, id);
call.enqueue(new Callback<List<Event>>() {
@Override
public void onResponse(@NonNull Call<List<Event>> call, @NonNull Response<List<Event>> response) {
if (response.isSuccessful() && response.body()!=null) {
Log.d(TAG, "onResponse: loadData called");
eventList = response.body();
adapter = new EventAdapter(mContext, eventList);
recyclerView.setAdapter(adapter);
adapter.setOnItemClickListener(new EventAdapter.OnItemClickListener() {
@Override
public void onAddClicked(int position) {
addClick(position);
}
@Override
public void onMoreClicked(int position) {
moreClick(position);
}
});
}
else if(response.body() == null){
noEvents.setVisibility(View.VISIBLE);
}
else{
Log.d(TAG, "onResponse: " + response.body());
}
}
@Override
public void onFailure(@NonNull Call<List<Event>> call, @NonNull Throwable t) {
Log.d("Response", "onFailure: " + t.toString());
}
});
}
}
事件适配器
public class EventAdapter extends RecyclerView.Adapter<EventAdapter.MyViewHolder> {
private Context mContext;
private List<Event> eventList;
private static final String TAG = "EventDetailActivity";
private OnItemClickListener clickListener;
public EventAdapter(Context mContext, List<Event> eventList){
this.mContext = mContext;
this.eventList = eventList;
}
public interface OnItemClickListener {
void onAddClicked(int position);
void onMoreClicked(int position);
}
public void setOnItemClickListener(OnItemClickListener clickListener) {
this.clickListener = clickListener;
}
@NonNull
@Override
public MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.event_layout, parent,
false);
return new MyViewHolder(view);
}
@Override
public void onBindViewHolder(@NonNull final MyViewHolder holder, int position) {
Event event = eventList.get(position);
holder.itemView.setTag(event);
holder.title.setText(eventList.get(position).getName());
holder.description.setText(eventList.get(position).getDescription());
holder.date.setText(eventList.get(position).getDate());
holder.location.setText(eventList.get(position).getLocation());
holder.add.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if(clickListener != null){
int position = (int)v.getTag();
clickListener.onAddClicked(position);
final Event event = (Event)v.getTag();
if(event!= null){
Intent i = new Intent(mContext, EventInvitationActivity.class);
i.putExtra("EVENT_DETAIL", event);
v.getContext().startActivity(i);
}
}
}
});
holder.more.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if(clickListener != null){
int position = (int)v.getTag();
clickListener.onMoreClicked(position);
final Event event = (Event)v.getTag();
if(event!= null){
Intent i = new Intent(mContext, EventDetailActivity.class);
i.putExtra("EVENT_DETAIL", event);
v.getContext().startActivity(i);
}
}
}
});
@Override
public int getItemCount() {
return eventList.size();
}
public class MyViewHolder extends RecyclerView.ViewHolder {
TextView title, description, date, location;
Button add, more;
public MyViewHolder(@NonNull View itemView) {
super(itemView);
title = itemView.findViewById(R.id.event_name);
description = itemView.findViewById(R.id.event_description);
date = itemView.findViewById(R.id.event_date);
location = itemView.findViewById(R.id.event_location);
add = itemView.findViewById(R.id.add_icon);
}
}
这就是我试图在两个 Activity 中获取传递 Intent 的方式:
//Getting resources
mName = findViewById(R.id.eventName);
mDescription = findViewById(R.id.description);
mLocation = findViewById(R.id.location);
mDate = findViewById(R.id.date);
mEvent = Objects.requireNonNull(getIntent().getExtras()).getParcelable(EVENT_DETAIL);
if(mEvent != null){
mName.setText(mEvent.getName());
mDescription.setText(mEvent.getDescription());
mLocation.setText(mEvent.getLocation());
mDate.setText(mEvent.getDate());
}
这是卡片 View 中的按钮示例:
<Button
android:id="@+id/add_icon"
android:layout_width="80dp"
android:layout_height="40dp"
android:layout_below="@+id/image"
android:layout_gravity="center_horizontal"
android:layout_marginTop="5dp"
android:layout_toEndOf="@id/event_description"
android:drawableStart="@drawable/ic_add_black_24dp"
android:scaleType="centerCrop"
android:transitionName="img"
android:visibility="visible"
android:textColor="@color/colorAccent"
/>
所以问题是,我怎样才能做到这一点?
编辑我已经弄清楚问题是什么:添加和更多 ImageView 作为 CardView 的一部分位于 event_layout 上,而不是程序正在寻找它们的 Activity_events 上。但是,当这两个按钮放置在 CardView 上时,我真的不知道如何使它们工作。
最佳答案
在您的MyViewHolder
构造函数中,您没有初始化more
,因此它将为空,因此会抛出空引用异常
关于java - 如何处理卡片 View 中不同的按钮 onclick 并传递 Intent ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62115098/
让我们开始吧,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 时,会显示该按钮。我不知道如何在显示按钮时将其设置为动画。任何人都可以
我是一名优秀的程序员,十分优秀!