Recyclerview не будет анимироваться с большим набором данных - PullRequest
0 голосов
/ 19 мая 2018

Я создаю приложение, в котором есть несколько экранов фильмов, один из которых загружен из скребка из списка 250 лучших фильмов imdbs за все время.Я пытался реализовать анимацию, когда карты загружаются, но безрезультатно.В конце концов я сузил проблему до факта, что набор данных был настолько большим.Когда я изменяю переменную loadHowMany на 25 или меньше, анимация загружается нормально.Нужно ли реализовывать какую-то функцию бесконечной прокрутки или есть способ анимировать этот большой набор данных?

Top250Activity.java

public class Top250Activity extends BaseActivity {

    private RecyclerView mListView;
    JSONArray array;
    Movie[] searchResults;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_top250);

        mListView = findViewById(R.id.top250list);
        mListView.setNestedScrollingEnabled(false);


        try {
            getResults(new Runnable() {
                @Override
                public void run() {

                    final MovieCardAdapter adapter = new MovieCardAdapter(getApplicationContext(), searchResults);

                    runOnUiThread(new Runnable() {
                        @Override
                        public void run() {

                            LinearLayoutManager lLayout;

                            mListView.setNestedScrollingEnabled(false);
                            Animation animation = AnimationUtils.loadAnimation(getApplicationContext(), R.anim.item_animation_fall_down);
                            mListView.setAnimation(animation);
                            lLayout = new GridLayoutManager(Top250Activity.this, 2);
                            mListView.setHasFixedSize(true);
                            mListView.setLayoutManager(lLayout);
                            mListView.setAdapter(adapter);

                        }
                    });

                }
            });

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

    private void getResults(final Runnable runnable) throws JSONException {
        final String apiKey = #######;
        final int loadHowMany = 100;
        String theURL = "https://api.morph.io/btrav528/imdb-top-250/data.json?key=#############&query=select%20*%20from%20%22data%22%20limit%20" + loadHowMany;
        final OkHttpClient client = new OkHttpClient();
        Request request = new Request.Builder().url(theURL).build();

        client.newCall(request).enqueue(new Callback() {
            @Override
            public void onFailure(@NonNull Call call, IOException e) {
                e.printStackTrace();
            }

            @Override
            public void onResponse(@NonNull Call call, @NonNull Response response) throws IOException {
                final String jsonData = response.body().string();

                JSONObject results;

                try {
                    array = new JSONArray(jsonData);
                    searchResults = new Movie[array.length()];
                    for (int i = 0; i < array.length(); i++) {
                        JSONObject jsonResult = array.getJSONObject(i);
                        final Movie movie = new Movie();

                        String html = jsonResult.getString("name");
                        String title = Html.fromHtml(html).toString();
                        movie.setTitle(title);
                        movie.setYear(jsonResult.getString("year"));
                        Uri uri = Uri.parse(jsonResult.getString("link"));
                        String path = uri.getPath();
                        Log.d("taggie", path);
                        String[] segments = uri.getPath().split("/");
                        String idStr = segments[segments.length-1];
                        Log.d("taggieidstr", idStr);

                        String posterUrl = "http://img.omdbapi.com/?i=" + idStr + "&h=600&apikey=" + apiKey;

                        movie.setPosterURL(posterUrl);
                        movie.setImdbID(idStr);

                        searchResults[i] = movie;
                    }
                    runnable.run();

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

}

item_animation_fall_down.xml

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
     android:duration="@integer/config_shortAnimTime">

    <translate
        android:fromYDelta="-20%"
        android:toYDelta="0"
        android:interpolator="@android:anim/decelerate_interpolator"
        />

    <alpha
        android:fromAlpha="0"
        android:toAlpha="1"
        android:interpolator="@android:anim/decelerate_interpolator"
        />

    <scale
        android:fromXScale="105%"
        android:fromYScale="105%"
        android:toXScale="100%"
        android:toYScale="100%"
        android:pivotX="50%"
        android:pivotY="50%"
        android:interpolator="@android:anim/decelerate_interpolator"
        />

</set>

1 Ответ

0 голосов
/ 19 мая 2018

Полагаю, лучше реализовать его бесконечной прокруткой.полезная ссылка: https://camposha.info/source/android-sqlite-recyclerview-infiniteendless-paginationload-serverside

...