Я очень новичок и запутался в том, как загрузить множество шаблонных данных 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 () способ, которым я вызываю массив для выполнения данных, - это то, что вешает данные в потоке. Я хотел бы получить четкое объяснение и пример!