Добавление анимации в представление списка в Android - PullRequest
10 голосов
/ 17 января 2012

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

В настоящее время я использую код:

set = new AnimationSet(true);

    animation = new AlphaAnimation(0.0f, 1.0f);
    animation.setDuration(50);
    set.addAnimation(animation);

    animation = new TranslateAnimation(
        Animation.RELATIVE_TO_SELF, 0.0f,Animation.RELATIVE_TO_SELF, 0.0f,
        Animation.RELATIVE_TO_SELF, -1.0f,Animation.RELATIVE_TO_SELF, 0.0f
    );
    animation.setDuration(150);
    set.addAnimation(animation);

    LayoutAnimationController controller = new LayoutAnimationController(set, 1.0f);
    l.setLayoutAnimation(controller);
    l.setAdapter(listAdaptor);

А потом при добавлении предметов через кнопку клик

    l.startLayoutAnimation();

Любые другие предложения для достижения такой анимации.

1 Ответ

14 голосов
/ 20 января 2012

У меня есть решение для этого. Я анимирую каждый добавленный элемент в методе getView моего пользовательского адаптера.

public View getView(int position, View convertView, ViewGroup parent) {

        View v = convertView;

        if (v == null) {
            LayoutInflater vi = (LayoutInflater) getActivity()
                    .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            v = vi.inflate(R.layout.simple_list_item_1, null);
        }

        ListData o = list.get(position);
        TextView tt = (TextView) v.findViewById(R.id.toptext);

        tt.setText(o.content);

        Log.d("ListTest", "Position : "+position);
       if(flag == false) {
        Animation animation = AnimationUtils.loadAnimation(getActivity(), R.anim.slide_top_to_bottom);
        v.startAnimation(animation);}
        return v;
    }

И тем самым достиг анимации, о которой я говорил.

...