Welcome to the Treehouse Community
Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.
Looking to learn something new?
Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.
Start your free trialLukas Baumgartner
14,817 Points[SOLVED] - OnLongClickListener not working
Hy! I'm working on an App, when you click an item of a recyclerview long enough it should display an option to delete the selected item.
But it's not working and i don't know why...
here is the code of the project
Adapter:
public class RecyclerViewAdapter extends RecyclerView.Adapter {
private final MainFragment.OnListItemSelectedInterface mListener;
private final MainFragment.OnListItemLongSelectedInterface mLongListener;
public RecyclerViewAdapter(MainFragment.OnListItemSelectedInterface listener, MainFragment.OnListItemLongSelectedInterface longListener) {
mListener = listener;
mLongListener = longListener;
}
public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.llist_item_vertical, parent, false);
return new ListViewHolder(view);
}
@Override
public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {
((ListViewHolder)holder).bindView(position);
}
@Override
public int getItemCount() {
//change to how many items are in the list or should be displayed in the list
return Exercises.mainList.length;
}
private class ListViewHolder extends RecyclerView.ViewHolder implements View.OnClickListener, View.OnLongClickListener{
private TextView mTextView1;
private ImageView mImageView;
private int mIndex;
public ListViewHolder(View itemView) {
super(itemView);
mTextView1 = (TextView) itemView.findViewById(R.id.textView);
itemView.setOnClickListener(this);
}
public void bindView(int position){
mTextView1.setText(Exercises.mainList[position]);
mIndex = position;
}
@Override
public void onClick(View v) {
mListener.onItemSelected(mIndex);
}
@Override
public boolean onLongClick(View v) {
mLongListener.onItemLongSelected(mIndex);
return true;
}
}
}
Fragment:
public interface OnListItemLongSelectedInterface{
void onItemLongSelected(int index);
}
public interface OnListItemSelectedInterface {
void onItemSelected(int index);
}
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
OnListItemSelectedInterface listener = (OnListItemSelectedInterface)getActivity();
OnListItemLongSelectedInterface longlistener = (OnListItemLongSelectedInterface)getActivity();
View view = inflater.inflate(R.layout.fragment_main, container, false);
RecyclerView recyclerView = (RecyclerView) view.findViewById(R.id.listRecyclerView);
RecyclerViewAdapter recyclerViewAdapter = new RecyclerViewAdapter(listener, longlistener);
recyclerView.addItemDecoration(new Divider(getActivity()));
recyclerView.setAdapter(recyclerViewAdapter);
RecyclerView.LayoutManager layoutManager = new LinearLayoutManager(getActivity());
recyclerView.setLayoutManager(layoutManager);
And here's the main activity:
@Override
public void onItemLongSelected(int index) {
Toast.makeText(this, "Delete selected item with prompt message " + index, Toast.LENGTH_SHORT).show();
}
1 Answer
Lukas Baumgartner
14,817 PointsI've found it :)
I forgott to set the onLonClickListener to the item.
private class ListViewHolder extends RecyclerView.ViewHolder implements View.OnClickListener, View.OnLongClickListener {
private TextView mTextView1;
private int mIndex;
public ListViewHolder(View itemView) {
super(itemView);
mTextView1 = (TextView) itemView.findViewById(R.id.textView);
itemView.setOnClickListener(this);
itemView.setOnLongClickListener(this);
}
public void bindView(int position){
mTextView1.setText(Exercises.mainList[position]);
mIndex = position;
}
@Override
public void onClick(View v) {
mListener.onItemSelected(mIndex);
}
@Override
public boolean onLongClick(View v) {
mLongListener.onItemLongSelected(mIndex);
return true;
}
}
Now it works :)
Jason Anders
Treehouse Moderator 145,860 PointsJason Anders
Treehouse Moderator 145,860 PointsVery happy to hear you solved it! :)
I've edited your post to mark it as solved.