【发布时间】:2015-01-19 16:38:16
【问题描述】:
我有这样的布局:
<LinearLayout
android:id="@+id/buttonLayout"
android:orientation="horizontal"
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<Button
android:id="@+id/btnNl"
android:layout_width="65dp"
android:layout_height="65dp"
android:background="@drawable/splashBtnOrange"
android:layout_marginRight="5.50dp" />
<Button
android:id="@+id/btnNoLanguage"
android:layout_width="65dp"
android:layout_height="65dp"
android:background="@drawable/splashBtnWhite"
android:layout_marginRight="5.50dp" />
<Button
android:id="@+id/btnFr"
android:layout_width="65dp"
android:layout_height="65dp"
android:background="@drawable/splashBtnGreen" />
还有这样的代码:
void HandleBtnNlClick (object sender, EventArgs e)
{
controller.SaveSetting("language","nl");
TranslateAnimation anim2 = new TranslateAnimation(0,-((int)(btnFr.GetX() - btnNoLanguage.GetX())), 0, 0);
anim2.Duration = 1000;
anim2.FillAfter = true;
TranslateAnimation anim1 = new TranslateAnimation(0, btnNoLanguage.GetX()-btnNl.GetX(), 0, 0);
anim1.Duration = 1000;
anim1.FillAfter = true;
btnNl.StartAnimation (anim1);
btnFr.StartAnimation (anim2);
//_initModel.gotoNextScreen ();
}
void HandleBtnFrClick (object sender, EventArgs e)
{
controller.SaveSetting("language","fr");
TranslateAnimation anim1 = new TranslateAnimation(0, btnNoLanguage.GetX()-btnNl.GetX(), 0, 0);
anim1.Duration = 1000;
anim1.FillAfter = true;
TranslateAnimation anim2 = new TranslateAnimation(0,-((int)(btnFr.GetX() - btnNoLanguage.GetX())), 0, 0);
anim2.Duration = 1000;
anim2.FillAfter = true;
btnNl.StartAnimation (anim1);
btnFr.StartAnimation (anim2);
}
当 btnFr 被推动时,btnFr 和 BtnNl 必须移动到中间 (noLanguageBtn 在哪里)。
一切正常,唯一的问题是当 BtnFr 被推送时, 它必须移动到 BtnNl 之上。当 BtnNl 被推送时,它必须移动到 BtnFr 之上。我怎样才能做到这一点?目前 btnFr 总是在 BtnNl 之上 因为它是稍后在布局中定义的...
【问题讨论】:
标签: android animation button move