Асинхронная задача не загружает данные - PullRequest
0 голосов
/ 29 октября 2018

Код

    public class ContactSettings extends Fragment {
    private RecyclerView contactsList;
    private List<ContactsHelper> contacts = new ArrayList<>();
    private LinearLayoutManager linearLayoutManager;
    private ContactsAdapter mAdapter;
       View rootView;
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // Inflate the layout for this fragment
        rootView = inflater.inflate(R.layout.settings_contact, container, false);



        contactsList = (RecyclerView) rootView.findViewById(R.id.usersList);
        //Add the data first
        linearLayoutManager = new LinearLayoutManager(getActivity());
        //and then create a object and pass the lis
        mAdapter = new ContactsAdapter(contacts);

        contactsList.setHasFixedSize(true);
        contactsList.setLayoutManager(linearLayoutManager);
        contactsList.setAdapter(mAdapter);
        mAdapter.notifyDataSetChanged();

        COntacts runner = new COntacts();


        return rootView;
    }

    @Override
    public void onStart(){
        super.onStart();
    }

    private class COntacts extends AsyncTask<String, Void, String> {
        @Override
        protected String doInBackground(String... urls) {
            ContentResolver contentResolver = getActivity().getContentResolver();
            Cursor cursor = contentResolver.query(ContactsContract.Contacts.CONTENT_URI, null, null, null, ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME + " ASC");
            if (cursor != null) {
                if (cursor.getCount() > 0) {
                    while (cursor.moveToNext()) {
                        int hasPhoneNumber = Integer.parseInt(cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.HAS_PHONE_NUMBER)));
                        if (hasPhoneNumber > 0) {
                            String id = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts._ID));
                            String name = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME));
                            Cursor phoneCursor = contentResolver.query(
                                    ContactsContract.CommonDataKinds.Phone.CONTENT_URI,
                                    null,
                                    ContactsContract.CommonDataKinds.Phone.CONTACT_ID + " = ?", new String[]{id},
                                    null);
                            if (phoneCursor != null) {
                                if (phoneCursor.moveToNext()) {
                                    String phoneNumber = phoneCursor.getString(phoneCursor.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER));

                                    contacts.add(new ContactsHelper(name, phoneNumber));
                                    phoneCursor.close();
                                }
                            }
                        }
                    }
                }
                cursor.close();
            }
            return "Download failed";
        }


        @Override
        protected void onPostExecute(String result) {
        }
    }

    public void onClick(View view) {

    }
}

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

1 Ответ

0 голосов
/ 29 октября 2018

Как я вижу в коде, вы не использовали параметр urls в doInBackground. И вам нужно передать contacts в onPostExecute, который работает в UI Thread:

private class COntacts extends AsyncTask<Void, Void, List<ContactsHelper>> {

@Override
protected List<ContactsHelper> doInBackground(Void... urls) {
   List<ContactsHelper> contacts = new ArrayList<>();
   ...
   return contacts
}

@Override
protected void onPostExecute(List<ContactsHelper> result) {
    contacts.addAll(result);
    mAdapter.notifyDataSetChanged();
}

Вам необходимо выполнить runner объект в вашем коде:

runner.execute()
...