Android 重新定位视图时设置动画

Android 重新定位视图时设置动画,android,android-layout,android-animation,android-view,Android,Android Layout,Android Animation,Android View,正如您在所附代码中看到的,linearLayoutLogo包含一个ProgressBar和TextView,linearLayoutReading包含一个ImageView和TextView。当linearLayoutReading可见时,由于android:layout\u centerInParent=“true”,两个布局会围绕中心点重新定位 如何设置linearLayoutLogo的动画,使其在linearLayoutReading可见之前向上移动到新位置?请参阅附件 activity_

正如您在所附代码中看到的,
linearLayoutLogo
包含一个
ProgressBar
TextView
linearLayoutReading
包含一个
ImageView
TextView
。当
linearLayoutReading
可见时,由于
android:layout\u centerInParent=“true”
,两个布局会围绕中心点重新定位

如何设置
linearLayoutLogo
的动画,使其在
linearLayoutReading
可见之前向上移动到新位置?请参阅附件

activity_main.xml

<LinearLayout
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:layout_centerInParent="true"
    android:gravity="center">

    <LinearLayout
        android:id="@+id/linearLayoutLogo"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        android:gravity="center">

        <ImageView
            android:id="@+id/imageViewRLogo"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:src="@drawable/ic_accessibility_black_24dp"
            android:padding="8dp"/>

        <TextView
            android:id="@+id/textViewAppTitle2"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textSize="34sp"
            android:textColor="#CCFFFFFF"
            android:text="AppName"/>

    </LinearLayout>

    <LinearLayout
        android:id="@+id/linearLayoutReading"
        android:orientation="vertical"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingTop="24dp">

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            style="@style/Base.TextAppearance.AppCompat.Large"
            android:text="Reading from device"
            android:textColor="#BF000000" />
        <ProgressBar
            android:id="@+id/progressBarSplash"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="center_horizontal"
            style="@style/Base.Widget.AppCompat.ProgressBar.Horizontal"
            android:paddingBottom="8dp"/>

    </LinearLayout>

</LinearLayout>

在Android Studio上进行了测试。只需将
android:animateLayoutChanges=“true”
包含在最顶端的
LinearLayout
(带有
centerInParent
元素的部分)中即可。

在android Studio上进行了测试。只需将
android:animateLayoutChanges=“true”
包含在最顶部的
LinearLayout
(带有
centerInParent
元素的那一个)中即可。

您是否尝试过使用
android:animateLayoutChanges=“true”
?您是否尝试过使用
android:animateLayoutChanges=“true”
?这确实令人惊讶。一句话正好达到了我的目的!非常感谢。我之前第一次遇到它时的反应与之完全相同。干杯这确实令人惊讶。一句话正好达到了我的目的!非常感谢。我之前第一次遇到它时的反应与之完全相同。干杯D
public class MainActivity extends AppCompatActivity {
public ProgressBar progressBarSplash;
public LinearLayout linearLayoutReading;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    linearLayoutReading = (LinearLayout)findViewById(R.id.linearLayoutReading);
    linearLayoutReading.setVisibility(View.GONE);

    new CountDownTimer(5000, 1000) {

        public void onTick(long millisUntilFinished) {
        }

        public void onFinish() {
            linearLayoutReading.setVisibility(View.VISIBLE);
            progressBarSplash = (ProgressBar)findViewById(R.id.progressBarSplash);
            progressBarSplash.setEnabled(true);
            progressBarSplash.setIndeterminate(true);
        }
    }.start();
}
}