我正在开发一个需要在多个图像之间交叉淡入淡出的应用程序,
我拥有:ImageView
和50个drawables(.png),我将从云端下载
我想要的是:50个drawable应该在几秒钟的间隔之间顺序交叉淡入淡出(淡入和淡出)
我尝试过:基于stackoverflow上的一些答案,我尝试了TransitionDrawable技术,但我只能在两个图像之间交叉淡入淡出,而不是更多,而是触摸。
答案 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的支持