Reputation: 2644
I am using recyclerview to show all my message in my app. But it always showing the messages in the left side of the chat room.
How can I achieve this?
This is my code:
Here my adapter always goes to the else part and listing all the message in the left side of the screen(i.e) other user messages
Adapter:
public class ChatMessageAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder> {
private List<Messages> msgDtoList;
private final List<Messages> mData;
public static final int VIEW_TYPE_SENDER = 1;
public static final int VIEW_TYPE_RECEIVER = 2;
public ChatMessageAdapter(List<Messages> msgDtoList) {
this.msgDtoList = msgDtoList;
mData = msgDtoList;
}
public void setData(@Nullable Messages[] data) {
msgDtoList.clear();
for (Messages model : data) {
if (model instanceof Messages) {
mData.add(model);
continue;
}
}
@Override
public int getItemViewType(int position) {
Messages msgDto = this.msgDtoList.get(position);
if (msgDto.getmSender().getId() == Profile.getInstance().getId()) {
return VIEW_TYPE_SENDER;
}
else {
return VIEW_TYPE_RECEIVER;
}
}
@Override
public int getItemCount() {
return msgDtoList.size();
}
@Override
public void onBindViewHolder(@NonNull RecyclerView.ViewHolder holder, int position) {
View v;
if(mMessages.getmSender().getId() == Profile.getInstance().getId()) {
sentViewHolder(holder, position);
} else if (msgDto.getmSender().getId() != Profile.getInstance().getId()) {
receivedViewHolder(holder, position);
}
}
@SuppressLint("ResourceAsColor")
private void sentViewHolder(RecyclerView.ViewHolder holder, int position) {
Messages msgDto = this.msgDtoList.get(position);
((SenderMessageHolder)holder).rightMsgTextView.setText(msgDto.getmMSg());
((SenderMessageHolder)holder).mDateTimestamp.setText(msgDto.getmTimestamp());
((SenderMessageHolder)holder).rightMsgTextView.setTextColor(R.color.yellow);
((SenderMessageHolder)holder).rightMsgTextView.setGravity(Gravity.CENTER_VERTICAL | Gravity.RIGHT);
}
@SuppressLint("ResourceAsColor")
private void receivedViewHolder(RecyclerView.ViewHolder holder, int position) {
Messages msgDto = this.msgDtoList.get(position);
((ReceiverMessageHolder)holder).leftMsgTextView.setText(msgDto.getmMSg());
((ReceiverMessageHolder)holder).mDateTimestamp.setText(msgDto.getmTimestamp());
((ReceiverMessageHolder)holder).leftMsgTextView.setTextColor(R.color.red);
((ReceiverMessageHolder)holder).leftMsgTextView.setGravity(Gravity.CENTER_VERTICAL | Gravity.LEFT);
}
@Override
public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
Messages msgDto = this.msgDtoList.get(viewType);
if (msgDto.getmSender().getId() == Profile.getInstance().getId() ) {
View view = LayoutInflater.from(parent.getContext())
.inflate(R.layout.sender_message_layout, parent, false);
return new SenderMessageHolder(view);
} else {
View view = LayoutInflater.from(parent.getContext())
.inflate(R.layout.receiver_message_layout, parent, false);
return new ReceiverMessageHolder(view);
}
}
}
}
In ChatFragment.java
@Override
public void onViewCreated(View v, @Nullable Bundle b) {
super.onViewCreated(v, b);
mChat = (TextView) v.findViewById(R.id.chat_messages);
mSendMsgInputBox = (EditText) v.findViewById(R.id.chat_input_msg);
mSendMsg = (ImageView) v.findViewById(R.id.chat_send_msg);
mChatMessageRecyclerView = (RecyclerView) v.findViewById(R.id.recycler_view);
LinearLayoutManager linearLayoutManager = new LinearLayoutManager(getActivity());
linearLayoutManager.setOrientation(LinearLayoutManager.VERTICAL);
linearLayoutManager.setStackFromEnd(true);
linearLayoutManager.setSmoothScrollbarEnabled(true);
mChatMessageRecyclerView.setLayoutManager(linearLayoutManager);
final List<Messages> msgDtoList = new ArrayList<LastMessageContent>();
int newMsgPosition = msgDtoList.size() - 1;
mChatMessageRecyclerView.scrollToPosition(0);
mChatMessageRecyclerView.setLayoutManager(new LinearLayoutManager(getActivity(), LinearLayoutManager.VERTICAL, false));
mChatMessageRecyclerView.setHasFixedSize(true);
mChatMessageRecyclerView.setAdapter(mAdapter);
ArrayList<Messages> messagesList = new ArrayList<>();
for (int i=0;i<10;i++) {
// messagesList.add(new LastMessageContent( mSendMsgInputBox.getText().toString(), Profile.getInstance().getId() == mChatMessage.getmSender().getId() ? ChatMessageAdapter.VIEW_TYPE_SENDER : ChatMessageAdapter.VIEW_TYPE_RECEIVER));
}
List<List<Messages>> itemList = new ArrayList<>();
mSendMsg.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
String msgContent = mSendMsgInputBox.getText().toString();
if(!TextUtils.isEmpty(msgContent))
{
Messages msgDto = mChatMessage.getmessages();
msgDtoList.add(msgDto);
itemList.add(msgDtoList);
mAdapter.notifyDataSetChanged();
if (mSendMsgInputBox.toString() != "") {
LastMessageContent msgDto1 = new LastMessageContent(mChatMessage.getmLastMessageContent().getmMSg(), mChatMessage.getId());
System.out.println("msgDto1msgDto1 ==" + msgDto1);
msgDtoList.add(msgDto1);
}
mAdapter.registerAdapterDataObserver(new RecyclerView.AdapterDataObserver() {
@Override
public void onItemRangeInserted(int positionStart, int itemCount) {
super.onItemRangeInserted(positionStart, itemCount);
int messageCount = mAdapter.getItemCount();
int lastVisiblePosition =
linearLayoutManager.findLastCompletelyVisibleItemPosition();
// If the recycler view is initially being loaded or the
// user is at the bottom of the list, scroll to the bottom
// of the list to show the newly added message.
if (lastVisiblePosition == -1 ||
(positionStart >= (friendlyMessageCount - 1) &&
lastVisiblePosition == (positionStart - 1))) {
mChatMessageRecyclerView.scrollToPosition(positionStart);
}
}
});
}
}
Upvotes: 1
Views: 209
Reputation: 1171
you are checking your viewType twice. you should not check it again in onCreateViewHolder.
try something like this:
@Override
public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
if (viewType == VIEW_TYPE_SENDER) {
View view = LayoutInflater.from(parent.getContext())
.inflate(R.layout.sender_message_layout, parent, false);
return new SenderMessageHolder(view);
} else {
View view = LayoutInflater.from(parent.getContext())
.inflate(R.layout.receiver_message_layout, parent, false);
return new ReceiverMessageHolder(view);
}
}
Upvotes: 1