画面全体でアニメーション化される3つの画像があるアニメーションを作成しています。中央の画像が画面の中央に到達すると、フェードインします。
最初の画像が真ん中に当たったときだけフェードインし、2 番目と 3 番目の画像が真ん中に当たったときはフェードインしないことを除いて、すべて正常に動作しています。
すべての画像には独自のビューがあります。フェードイン メソッドはすべて同じビューで実行されます。
以下のコードを参照してください。さらに情報が必要な場合はお知らせください。
画面上を移動するスライドをシミュレートするプロセスは次のとおりです。moveThree はフェードイン アニメーションです。moveOne と moveTwo は、画面上の画像の翻訳です。
public static int secondProcess(AnimationListener activity, View apa1,View apa2, View apa3,int animationmove)
{
Log.d("2", "SECOND PROCESS");
moveOne(activity, apa2);
moveTwo(activity,apa1);
animationmove = 3;
return animationmove;
}
public static int thirdProcess(AnimationListener activity, View apa1,View apa2,View apa3, int animationmove)
{
Log.d("3", "THIRD PROCESS");
moveThree(activity,apa1);
animationmove = 4;
return animationmove;
}
public static int fourthProcess(AnimationListener activity, View apa1, View apa2,View apa3,int animationmove)
{
Log.d("4", "FOURTH PROCESS");
moveOne(activity, apa3);
moveTwo(activity, apa2);
moveFour(activity,apa1);
animationmove = 5;
return animationmove;
}
public static int fifthProcess(AnimationListener activity, View apa1,View apa2,View apa3, int animationmove)
{
Log.d("5", "FIFTH PROCESS");
moveThree(activity,apa2);//IN THE SECOND VIEW HERE THE IMAGE IS NOT FADING
animationmove = 6;
return animationmove;
}
moveThree メソッド:
private static void moveThree(AnimationListener activity, View apa)
{
Log.v("MOVETHREE", "Started move3");
AnimationSet picMov3 = new AnimationSet(true);
picMov3.setAnimationListener(activity);
AlphaAnimation fadein = new AlphaAnimation((float) 0.3, 1);
fadein.setFillAfter(true);
fadein.setDuration(duration);
picMov3.addAnimation(fadein);
TranslateAnimation trans1 = new TranslateAnimation(-500, -500, 0, 0);
trans1.setDuration(duration);
picMov3.setFillAfter(true);
picMov3.setInterpolator(interpolator);
picMov3.addAnimation(trans1);
apa.startAnimation(picMov3);
}