не обновляется после повторного уведомления - PullRequest
0 голосов
/ 10 июня 2018

У меня есть фрагмент чата, который поддержан реселлером.Когда я вхожу в экран чата вручную, чтобы отправить или получить сообщение, он работает нормально.но когда я закрыл приложение и зашел в приложение из уведомления о сообщении, оно отправляет сообщение другому пользователю, но не обновляет собственное окно просмотра.

Фрагмент чата

public class Chat_Screen_Fragment extends Fragment implements View.OnClickListener, ChildEventListener{

    public static final String TAG = "###CHAT SCREEN###";

    List<Chat_Wrapper> message = new ArrayList<>();


    Chat_Adapter adapter;
    RecyclerView recyclerView;
    LinearLayoutManager layoutManager;


    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, Bundle savedInstanceState) {
        View v=inflater.inflate(R.layout.chat_screen_main_fragment,container,false);
        setRetainInstance(true);



        // GET INTENT VALUES FROM USER PROFILE CLASS

        UserName_Intent = getArguments().getString("Get_Name");
        UserImage_Intent = getArguments().getString("Get_Image");
        UserPhone_Intent = getArguments().getString("Get_Phone");
        UserID_Intent = getArguments().getString("Get_ID");
        FirebaseToken_Intent = getArguments().getString("Get_Token"); //Firebase Token of other person
        Room_Name_Intent = getArguments().getString("Get_Other"); // Room Name of chat
        UserLastSeen_Intent=getArguments().getString("LastSeen");
        //Sender_FCMToken = Session.getFirebaseID();







        // RECYCLER VIEW
        recyclerView = v.findViewById(R.id.Chat_Screen_Message_List);
        layoutManager = new LinearLayoutManager(getActivity());
        layoutManager.setStackFromEnd(true);
        recyclerView.setHasFixedSize(true);
        recyclerView.setLayoutManager(layoutManager);
databaseReference = FirebaseDatabase.getInstance().getReference().child(Room_Name_Intent);
        databaseReference.addChildEventListener(this);

        adapter = new Chat_Adapter(getActivity(), message);
        recyclerView.setAdapter(adapter);
        // FETCH OLD MESSAGE FROM DATABASE
        chatDatabase();
        return v;
    }



    // FIREBASE REAL TIME DATABASE WHICH FETCH ALL MESSAGES (SYNC) FROM ONLINE DATABASE
    @Override
    public void onChildAdded(DataSnapshot dataSnapshot, String s) {
        append_chat_conversation(dataSnapshot);
    }

    @Override
    public void onChildChanged(DataSnapshot dataSnapshot, String s) {
        append_chat_conversation(dataSnapshot);
    }

    @Override
    public void onChildRemoved(DataSnapshot dataSnapshot) {

    }

    @Override
    public void onChildMoved(DataSnapshot dataSnapshot, String s) {

    }

    @Override
    public void onCancelled(DatabaseError databaseError) {

    }




    //THIS METHOD WILL FETCH ADD ALL MESSAGES FROM FIREBASE DATABASE AND ALSO SEARCH RESULT
    private synchronized void append_chat_conversation(DataSnapshot dataSnapshot) {
        iterator = dataSnapshot.getChildren().iterator();


        while (iterator.hasNext()) {
            // NOW GET ALL DATA FROM FIREBASE DATABASE AND SAVE IT INTO STRINGS THEN CHECK EACH BY ITS MESSAGE TYPE
            Chat_Msg = (String) ((DataSnapshot) iterator.next()).getValue();
            Chat_FROM = (String) ((DataSnapshot) iterator.next()).getValue();
            Chat_FCM_TO= (String) ((DataSnapshot) iterator.next()).getValue();

            Chat_Database tempChatDatabase = new Chat_Database(getActivity());
            boolean hasValue=tempChatDatabase.CheckValueExist(_ID);


            if (!hasValue) {
                Log.d(TAG,"Chat Message "+Chat_Msg);


                    long id=chat_database.Insert_Chat(Session.getUserID(),Room_Name_Intent, UserID_Intent, "Text", Chat_Msg, Chat_FROM, Chat_TO, Chat_TimeStamp, Chat_FCM_FROM, Chat_FCM_TO, Session.getPhoneNO(), UserPhone_Intent,Random_ID,UserImage_Intent,UserLastSeen_Intent,Chat_FROM_ID);

                    //Adding Chat Data Into Database
                    Log.d(TAG,"Database Entry ID "+id);
                    if (id==0){
                        Log.d(TAG,"Database Already Has Value Of This Random Id ");
                        return;
                    }
                    Chat_Wrapper chat_wrapper = new Chat_Wrapper(Chat_Msg, null, null, null, null, null, null, Chat_TimeStamp, User_Intent, UserImage_Intent, Chat_FROM, null,null,id);
                    message.add(chat_wrapper);
                  adapter.notifyDataSetChanged();
                Log.d(TAG, "FIREBASE STORAGE PHOTO-3-MESSAGE ARRAY SIZE " + message.size());
                recyclerView.post(new Runnable() {
                    @Override
                    public void run() {
                        Log.d(TAG, "Moving to Bottom");
                        recyclerView.smoothScrollToPosition(adapter.getItemCount());

                    }
                });

                }               

                }

            }

            Log.d(TAG, "MESSAGE ARRAY SIZE " + message.size());

            tempChatDatabase.isDatabaseClose();
        }

        adapter.notifyDataSetChanged();
        recyclerView.post(new Runnable() {
            @Override
            public void run() {
                Log.d(TAG, "Moving to Bottom");
                recyclerView.smoothScrollToPosition(message.size()-1);
                //recyclerView.smoothScrollToPosition(adapter.getItemCount());

            }
        });
    }



    private void chatDatabase(){
        //Database Init and Filling Adapter
        Log.d(TAG,"Chat Database Function");
        chat_database=new Chat_Database(getActivity());
        chatCursor=chat_database.getUserChat(UserID_Intent);
        boolean checkDB_Exist=functions.DatabaseExist(getActivity(),"CHAT_DATABASE.DB");
        boolean chatItemsCounts=chatCursor.getCount()>0;
        chatCursor.moveToFirst();
        Log.d(TAG,"Value At Chat Database "+ checkDB_Exist+" "+chatItemsCounts);
        if (checkDB_Exist && chatCursor.getCount()>0 && chatCursor.getString(chatCursor.getColumnIndex("RECEIVER_USER_ID")).equals(UserID_Intent)){

            Log.d(TAG,"Database Exist Chat Database");
            message.clear();
            chatCursor.moveToFirst();
            do {
                database_rowID=chatCursor.getInt(chatCursor.getColumnIndex("ID"));
                database_userID=chatCursor.getString(chatCursor.getColumnIndex("USER_ID"));
                database_RoomName =chatCursor.getString(chatCursor.getColumnIndex("ROOM_NAME"));
                database_ReceiverID=chatCursor.getString(chatCursor.getColumnIndex("RECEIVER_USER_ID"));
                database_MessageType=chatCursor.getString(chatCursor.getColumnIndex("MESSAGE_TYPE"));
                database_Message=chatCursor.getString(chatCursor.getColumnIndex("USER_MESSAGE"));
                database_MsgFrom=chatCursor.getString(chatCursor.getColumnIndex("SENDER_NAME"));
                database_MsgTo=chatCursor.getString(chatCursor.getColumnIndex("RECEIVER_NAME"));
                database_TimeStamp=chatCursor.getString(chatCursor.getColumnIndex("TIME_STAMP"));
                database_FCMfrom=chatCursor.getString(chatCursor.getColumnIndex("SENDER_TOKEN"));
                database_FCMto=chatCursor.getString(chatCursor.getColumnIndex("RECEIVER_TOKEN"));
                database_LocalPath=chatCursor.getString(chatCursor.getColumnIndex("DOWNLOADED_AT"));
                database_PhoneFrom=chatCursor.getString(chatCursor.getColumnIndex("MY_PHONE"));
                database_PhoneTo=chatCursor.getString(chatCursor.getColumnIndex("OTHER_PHONE"));

                Log.d(TAG,"Value Of Database Message String = "+database_Message);
                Log.d(TAG,"Row ID of Database "+database_rowID);
                // Check Message Type


                    Log.d(TAG,"Message Type Is Text");
                    Chat_Wrapper text = new Chat_Wrapper(database_Message, null, null, null, null, null, null, database_TimeStamp, database_PhoneTo, UserImage_Intent, database_MsgFrom,null,null,database_rowID);
                    message.add(text);



            }
            while(chatCursor.moveToNext());

            Room_Name_Intent = database_RoomName;
            layoutManager = new LinearLayoutManager(getActivity());
            recyclerView.setLayoutManager(layoutManager);
            adapter.notifyDataSetChanged();
            chatCursor.close();
            boolean value = chat_database.isDatabaseClose();
            recyclerView.post(new Runnable() {
                @Override
                public void run() {
                    Log.d(TAG, "Moving to Bottom");
                    recyclerView.smoothScrollToPosition(message.size()-1);

                }
            });
            Log.d(TAG,"Value Of Database Close or Not "+value);

        }
    }
}

Адаптер чата

public class Chat_Adapter extends RecyclerView.Adapter<Chat_Adapter.ViewHolder> {

public static final String TAG="###CHAT_ADAPTER###";
private Context context;
Chat_Database database;
Chat_Wrapper chat_wrapper;


public Chat_Adapter(Context context, List<Chat_Wrapper> message) {
    this.context = context;
    this.arrayList_message = message;

}


@Override
public Chat_Adapter.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
    View Layout;
    Log.d(TAG,"On Create View Holder Calling ");
    if (viewType==1){
        Log.d(TAG,"View Tyoe Is "+viewType);
        Layout=LayoutInflater.from(parent.getContext()).inflate(R.layout.chat_screen_message_item,parent,false);
      //  ImagePath=Session.getUserImage();
    }
    else {
        Log.d(TAG,"View Type Is "+viewType);
        Layout=LayoutInflater.from(parent.getContext()).inflate(R.layout.chat_screen_message_item_other,parent,false);
       // ImagePath=chat_wrapper.getImageView();
    }

    return new ViewHolder(Layout);
}

@Override
 public void onBindViewHolder(final Chat_Adapter.ViewHolder holder, final int position) {
    chat_wrapper=arrayList_message.get(position);
    database=new Chat_Database(context);

        holder.Message.setVisibility(View.VISIBLE);
        holder.TimeStamp.setVisibility(View.VISIBLE);
        holder.User_Image.setVisibility(View.VISIBLE);

        //CHECK SENDER IS SAME AS LOGGED IN USER
        if ((Session.getUserFname()+" "+Session.getUserLname()).equals(chat_wrapper.getSender_UserName())){
            ImagePath=Session.getUserImage();
            Log.d(TAG,"Session.getUserImage() "+Session.getUserImage());
            Log.d(TAG,"Value Of Message Running ImagePath "+ImagePath);

        }
        else {
            //String filePath="/data/data/com.boysjoys.com.pro_working1/my_picture.jpg"
            ImagePath=chat_wrapper.getImageView();

            Log.d(TAG,"Value Of Message Running ImagePath "+ImagePath);
        }

        holder.Message.setText(chat_wrapper.getMessage());
        holder.TimeStamp.setText(chat_wrapper.getTimestamp());
        holder.TimeStamp.setVisibility(View.GONE);
        Glide.with(MyApplication.getmContext())
                .load(ImagePath)
                .apply(new RequestOptions()
                        .diskCacheStrategy(DiskCacheStrategy.ALL)
                        .fitCenter().skipMemoryCache(false))
                .into(holder.User_Image);


        //Make TimeStamp Visible or Hidden
        holder.Message.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Log.d(TAG,"On Click Text View Message");

                if (isShowing){
                    holder.TimeStamp.setVisibility(View.VISIBLE);
                    Log.d(TAG,"Is Showing Is True");
                    isShowing=false;
                }
                else {
                    holder.TimeStamp.setVisibility(View.GONE);
                    isShowing=true;
                }

            }
        });

    }

}
@Override
public long getItemId(int position) {
    return position;
}

@Override
public int getItemCount() {
    Log.d(TAG,"GET ITEM COUNT--Array Message List Size "+arrayList_message.size());
    return arrayList_message.size();
}

public class ViewHolder extends RecyclerView.ViewHolder {
    TextView Message;
    TextView TimeStamp;

    ImageView User_Image;


    public ViewHolder(View itemView) {
        super(itemView);
        Log.d(TAG,"View Holder Constructor Calling. Now Inflating Layout Items");
        Message = itemView.findViewById(R.id.Single_Item_Chat_Message);
        TimeStamp = itemView.findViewById(R.id.Single_Item_Chat_TimeStamp);
        User_Image = itemView.findViewById(R.id.Single_Item_Chat_ImageView);




    }
}

Всякий раз, когда я получал сообщение в качестве уведомления после нажатия на уведомление, он открывает тот же самый экран чата (Сначала загрузите все предыдущее сообщение), и когда я нажимаю кнопку отправки, чтобы отправить сообщение, оно отправляется другому пользователю, но не обновляется мое окно просмотра.

ОБНОВЛЕНИЕ : Я только что обнаружил проблему с загрузкой более ранних сообщений из локальной базы данных, когда я комментирую функцию chatDatabase(), она работает нормально.но все еще не может решить проблему.

Ответы [ 2 ]

0 голосов
/ 10 июня 2018

Почему бы вам не позвонить

adapter.notifyDataSetChanged();

после

Chat_Wrapper chat_wrapper = new Chat_Wrapper(Chat_Msg, null, null, null, null, null, null, Chat_TimeStamp, User_Intent, UserImage_Intent, Chat_FROM, null,null,id);
                message.add(chat_wrapper);

, так как

notifyDataSetChanged работает, только если вы используете add (), вставьте(), удалить () и очистить () на адаптере.

0 голосов
/ 10 июня 2018

Когда вы добавляете новый элемент в список методом append_chat_conversation, вы не уведомляете об этом адаптер.Я не знаю, как работает эта инфраструктура, но вы должны уведомлять адаптер о любых изменениях в наборе данных, используя notifyDataSetChaged на адаптере или лучше, используя специальные методы вставки / изменения / удаления уведомлений для повышения производительности.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...