ObjectAnimator onAnimationEnd прослушиватель вызывается до завершения анимации

его странно и странно, но похоже, что когда я присоединяю AnimatorListener к ObjectAnimator, который я использую для анимации транзакций фрагментов, обратный вызов фактически называется немного до завершения анимации. Я использую прослушиватель для заполнения контента во фрагменте (из БД). Операция может занимать довольно много времени (~ 200 мс), иногда, когда я делаю это в onCreate или так, она просто разрушает анимацию, потому что содержимое возвращается и отображается во время анимации... тогда есть много мусора и заикания., Поэтому, когда я добавляю заполненный вызов в слушатель, он работает, когда выбор БД занимает много времени. Но иногда это почти мгновенно, и в этом случае у меня проблема, когда обратный вызов вызывается до конца анимации. Зазор между обратным вызовом и конечным концом длинный, чтобы вернуть данные из БД и снова уничтожить текучесть анимации:/

Вы, ребята, знаете, как решить эту проблему? Ниже представлен почти весь код этого фрагмента.

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

И есть один дополнительный способ, который мне не нравится. Я могу создать обработчик и вызвать postDelayed..awful solution:)

public class ImportantContactsFragment extends Fragment {

public static final String TAG = ImportantContactsFragment.class.getSimpleName();


private ListView list;
private Spinner departmentsSwitcher;
private Spinner facultiesSwitcher;
private ContactsAdapter adapter;
private ArrayList<ImportantContact> currentListOfPeople;
private int currentFaculty = 1;
private Department currentDeparment = Department.STUDY_DEPARTMENT;
private PullToRefreshAttacher mPullToRefreshAttacher;
private boolean boot = true;
private AsyncTask<Integer, ArrayList<ImportantContact>, ArrayList<ImportantContact>> task;


private ArrayList<Faculty> faculties;


private SpinnerAdapter departmentsSpinnerAdapter;
private SpinnerAdapter facultiesSpinnerAdapter;

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
    currentListOfPeople = new ArrayList<ImportantContact>();
    faculties = new ArrayList<Faculty>(2);
    currentDeparment = Department.STUDY_DEPARTMENT;

    faculties.add(Faculty.getFEL());
    faculties.add(Faculty.getFIT());

    FrameLayout view = (FrameLayout) inflater.inflate(R.layout.important_contacts_fragment_list_layout, container, false);
    departmentsSwitcher = (Spinner) view.findViewById(R.id.departmentsSpinner);
    facultiesSwitcher = (Spinner) view.findViewById(R.id.facultiesSpinner);


    facultiesSpinnerAdapter = new ArrayAdapter<Faculty>(getActivity(), R.layout.spinner_text_view, faculties);
    departmentsSpinnerAdapter = new ArrayAdapter<Department>(getActivity(), R.layout.spinner_text_view, Department.values());


    departmentsSwitcher.setAdapter(departmentsSpinnerAdapter);
    facultiesSwitcher.setAdapter(facultiesSpinnerAdapter);

    list = (ListView) view.findViewById(R.id.list);
    adapter = new ContactsAdapter(getActivity(), R.layout.important_contacts_list_item, currentListOfPeople, list);
    list.setAdapter(adapter);
    list.requestFocus();
    departmentsSwitcher.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
        @Override
        public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
            currentDeparment = (Department) departmentsSpinnerAdapter.getItem(position);
            fillAdapterWithData(currentFaculty, currentDeparment);
        }

        @Override
        public void onNothingSelected(AdapterView<?> parent) {
        }
    });
    facultiesSwitcher.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
        @Override
        public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
            currentFaculty = position + 1;
            fillAdapterWithData(currentFaculty, currentDeparment);
        }

        @Override
        public void onNothingSelected(AdapterView<?> parent) {

        }
    });

    return view;
}


@Override
public void onResume() {
    super.onResume();
    Tracking.onResume(this);
//        fillAdapterWithData(currentFaculty, currentDeparment);

}

@Override
public void onPause() {
    super.onPause();
    if (task != null) {
        task.cancel(true);
    }
}


@Override
public void onViewCreated(View view, Bundle savedInstanceState) {
    super.onViewCreated(view, savedInstanceState);




}

@Override
public void onActivityCreated(Bundle savedInstanceState) {
    super.onActivityCreated(savedInstanceState);
    getActivity().getActionBar().setTitle(getString(R.string.important_contacts));
}

public void fillAdapterWithData(int facultyId, Department department) {
    if (boot) {
        boot = false;
        return;
    }
    currentListOfPeople.clear();
    if (task != null) {
        task.cancel(true);
    }
    task = new AsyncTask<Integer, ArrayList<ImportantContact>, ArrayList<ImportantContact>>() {
        @Override
        protected ArrayList<ImportantContact> doInBackground(Integer... params) {
            return Controller.peopleDBController.getListOfImportantContactFromListOfContact(Controller.contactsDBController.searchRows(params[0], params[1]));
        }


        @Override
        protected void onPostExecute(ArrayList<ImportantContact> importantContacts) {

//          adapter.notifyDataSetChanged();
            adapter.addAll(importantContacts);


        }
    };
//        getActivity().setProgressBarVisibility(true);

    task.execute(facultyId, department.ordinal());
    adapter.addAll(Controller.peopleDBController.getListOfImportantContactFromListOfContact(Controller.contactsDBController.searchRows(facultyId, department.ordinal())));

}

@Override
public Animator onCreateAnimator(int transit, boolean enter, int nextAnim) {
    if(enter){
        Animator animator = AnimatorInflater.loadAnimator(getActivity(), R.anim.fragment_slide_anim);
        if(animator!=null){
        animator.addListener(new Animator.AnimatorListener() {
            @Override
            public void onAnimationStart(Animator animation) {

            }

            @Override
            public void onAnimationEnd(Animator animation) {
//                    fillAdapterWithData(currentFaculty, currentDeparment);
            }

            @Override
            public void onAnimationCancel(Animator animation) {

            }

            @Override
            public void onAnimationRepeat(Animator animation) {

            }
        });
        }
        return  animator;
    }
    else{
        return super.onCreateAnimator(transit, enter, nextAnim);
    }



}