Android - 在ImageView中交叉淡化多个图像

时间:2013-08-15 08:58:49

标签: java android android-imageview android-animation

我正在开发一个需要在多个图像之间交叉淡入淡出的应用程序,

我拥有:ImageView和50个drawables(.png),我将从云端下载

我想要的是:50个drawable应该在几秒钟的间隔之间顺序交叉淡入淡出(淡入和淡出)

我尝试过:基于stackoverflow上的一些答案,我尝试了TransitionDrawable技术,但我只能在两个图像之间交叉淡入淡出,而不是更多,而是触摸。

我提到的视频:https://www.youtube.com/watch?v=atH3o2uh_94

2 个答案:

答案 0 :(得分:10)

执行此操作的自定义视图:

public class FadeView extends FrameLayout {
    private long mFadeDelay = 1000;
    private ImageView mFirst;
    private ImageView mSecond;
    private boolean mFirstShowing;

    public FadeView(Context context) {
        super(context);
        init(context);
    }

    public FadeView(Context context, AttributeSet attrs) {
        super(context, attrs);
        init(context);
    }

    public FadeView(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
        init(context);
    }

    private void init(Context c){
        mFirst = new ImageView(c);
        mSecond = new ImageView(c);

        mFirst.setAlpha(1.0f);
        mSecond.setAlpha(0.0f);

        mFirstShowing = true;

        addView(mFirst);
        addView(mSecond);
    }

    public void setFadeDelay(long fadeDelay) {
        mFadeDelay = fadeDelay;
    }

    public void ShowImage(Drawable d){
        if(mFirstShowing){
            mSecond.setImageDrawable(d);
            mSecond.animate().alpha(1.0f).setDuration(mFadeDelay);
            mFirst.animate().alpha(0.0f).setDuration(mFadeDelay);
        }else {
            mFirst.setImageDrawable(d);
            mSecond.animate().alpha(0.0f).setDuration(mFadeDelay);
            mFirst.animate().alpha(1.0f).setDuration(mFadeDelay);
        }

        mFirstShowing = !mFirstShowing;
    }
}

用法:

public class test extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        final FadeView fw = new FadeView(this);
        setContentView(fw);

        fw.setOnClickListener(new View.OnClickListener() {
            Drawable d1 = getResources().getDrawable(android.R.drawable.ic_dialog_alert);
            Drawable d2 = getResources().getDrawable(android.R.drawable.ic_dialog_info);
            boolean flag;

            @Override
            public void onClick(View view) {
                if(flag){
                    fw.ShowImage(d1);
                }else {
                    fw.ShowImage(d2);
                }
                flag = !flag;
            }
        });
    }


}

答案 1 :(得分:-1)

然后创建自定义Drawable,绘制两个具有更改alpha值的Drawable,当然,当您需要支持多个Drawable时,您需要添加对Drawables的支持