Фоновые данные фрагмента асинхронной задачи - PullRequest
0 голосов
/ 18 июня 2019

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

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

Я хочу иметь возможность вернуть ArrayList из фоновой задачи, взять этот заполненный массив и передать его в качестве моего адаптера для просмотра переработчика. Вот фрагмент, который содержит и AsyncTask, и код повторного просмотра:

public class LoadJSONAsyncTask extends AsyncTask<String, String, ArrayList<String>>
    {

        protected void onPreExecute()
        {


        }

        public String getJSONFromURL(String inUrl) throws IOException
        {
            URL url2 = new URL(inUrl);
            HttpURLConnection urlConnection = (HttpURLConnection) url2.openConnection();
            StringBuilder total = new StringBuilder();

            try
            {
                InputStream in = new BufferedInputStream(urlConnection.getInputStream());
                BufferedReader r = new BufferedReader(new InputStreamReader(in));

                for(String line; (line = r.readLine()) != null;)
                {
                    total.append(line).append('\n');
                }
            }
            catch(Exception e)
            {
                e.printStackTrace();
            }

            finally
            {
                urlConnection.disconnect();
            }

            return total.toString();
        }

        @Override
        protected ArrayList<String> doInBackground(String... params)
        {
            LoadJSONAsyncTask jParser = new LoadJSONAsyncTask();
            JSONArray array = null;
            JSONObject json = null;
            String url = "https://baconipsum.com/api/?type=meat-and-filler";

            StringBuilder returnMe = new StringBuilder();
            results = new ArrayList<>();

            try {
                array = new JSONArray(jParser.getJSONFromURL(url));
                for(int n = 0; n < array.length(); n++)
                {
                    try {
                        json = new JSONObject();

                        json.put("name", jParser.getJSONFromURL(url));
                        results.add(jParser.getJSONFromURL(url));
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                }

            } catch (JSONException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }



            return results;
        }

        protected void onPostExecute()
        {

        }

    }

В моем методе onCreateView () из моего фрагмента представление переработчика определяется следующим образом:

@Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // Inflate the layout for this fragment
        try
        {
            results = new LoadJSONAsyncTask().execute(url).get();
            for(int i = 0; i < results.size(); i++)
            {
                newsFeedList.add(new NewsFeed(results.get(i)));
            }
        } catch (ExecutionException e) {

        } catch (InterruptedException e) {e.printStackTrace();
            e.printStackTrace();
        }
        View view = inflater.inflate(R.layout.fragment_feeds, container, false);

        newsFeedList = new ArrayList<>();

        recyclerView = (RecyclerView) view.findViewById(R.id.recyclerView);
        recyclerView.setHasFixedSize(true);
        recyclerView.setLayoutManager(new LinearLayoutManager(getActivity()));


        final NewsAdapter mAdapter = new NewsAdapter(getActivity(), newsFeedList);
        recyclerView.setAdapter(mAdapter);


        return view;
    }

У меня есть ощущение, что в моем методе onCreateView () способ, которым я вызываю массив для выполнения данных, - это то, что вешает данные в потоке. Я хотел бы получить четкое объяснение и пример!

Ответы [ 2 ]

1 голос
/ 18 июня 2019

Переопределите onPostExecute вашего LoadJSONAsyncTask и поместите туда все свои обновления пользовательского интерфейса.

@Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // Inflate the layout for this fragment

        View view = inflater.inflate(R.layout.fragment_feeds, container, false);

        newsFeedList = new ArrayList<>();

        recyclerView = (RecyclerView) view.findViewById(R.id.recyclerView);
        recyclerView.setHasFixedSize(true);
        recyclerView.setLayoutManager(new LinearLayoutManager(getActivity()));

        final NewsAdapter mAdapter = new NewsAdapter(getActivity(), newsFeedList);
        recyclerView.setAdapter(mAdapter);

        LoadJSONAsyncTask asyncTask = new LoadJSONAsyncTask() {
        @Override
        void onPostExecute(ArrayList<String> results) {
                // update your adapter here with the result

                for(int i = 0; i < results.size(); i++)
                {
                    newsFeedList.add(new NewsFeed(results.get(i)));
                }

                // notify adapter here to update the view
                mAdapter.notifyDataSetChanged()
            }
        }

        asyncTask.execute(url);

        return view;
    }

.get() вешает ваш основной поток.

Вот как правильноиспользуйте AsyncTask.https://developer.android.com/reference/android/os/AsyncTask

0 голосов
/ 18 июня 2019

Фрагмент вызова после завершения LoadJSONAsyncTask

...