gpt4 book ai didi

android - ViewGroups 的一个 Animate Layout 属性是如何实现的?

转载 作者:塔克拉玛干 更新时间:2023-11-02 08:57:50 25 4
gpt4 key购买 nike

我有以下布局:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_height="match_parent"
android:layout_width="match_parent">

<FrameLayout android:id="@+id/viewgroup_left"
android:layout_height="match_parent"
android:layout_weight="2"
android:layout_width="0dp">

... children ...

</FrameLayout>

<LinearLayout android:id="@+id/viewgroup_right"
android:layout_height="match_parent"
android:layout_weight="1"
android:layout_width="0dp"
android:orientation="vertical">

... children ...

</LinearLayout>

</LinearLayout>

我最终得到这样的东西:

  +------------------------+------------+
| | |
| | |
| Left | Right |
| | |
| | |
+------------------------+------------+

当切换某个开关时,我想为 Left 设置动画,使其宽度扩大以填满整个屏幕。同时,我想为 Right 的宽度设置动画,使其缩小为零。稍后,当切换再次切换时,我需要将东西恢复到上述状态。

我已经尝试编写自己的调用 View.getWidth() 的动画但是当我动画回到那个值时(通过设置 View.getLayoutParams().width ) 它比开始时更宽。我怀疑我只是做错了。我还阅读了有关 Honeycomb 动画内容的所有文档,但我不想平移或缩放...我想为布局宽度属性设置动画。我找不到这方面的例子。

正确的做法是什么?

最佳答案

因为还没有人帮助过你,而且我的第一个答案很乱,这次我会尽量给你正确的答案;-)

实际上我喜欢这个想法,我认为这是一个很棒的视觉效果,可能对很多人都有用。我会实现右 View 的溢出(我认为收缩看起来很奇怪,因为文本正在扩展到底部)。

但无论如何,这里的代码工作得非常好(您甚至可以在动画时切换)。

快速解释:
你用一个 bool 值来调用 toggle 你的方向,这将启动一个处理程序动画调用循环。这将根据方向和过去的时间增加或减少两个 View 的权重(为了平滑的计算和动画)。只要尚未到达开始或结束位置,动画调用循环就会调用自身。

布局:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="horizontal"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:weightSum="10"
android:id="@+id/slide_layout">
<TextView
android:layout_weight="7"
android:padding="10dip"
android:id="@+id/left"
android:layout_width="0dip"
android:layout_height="fill_parent"></TextView>
<TextView
android:layout_weight="3"
android:padding="10dip"
android:id="@+id/right"
android:layout_width="0dip"
android:layout_height="fill_parent"></TextView>
</LinearLayout>

Activity :

public class TestActivity extends Activity {

private static final int ANIMATION_DURATION = 1000;

private View mSlidingLayout;
private View mLeftView;
private View mRightView;

private boolean mAnimating = false;
private boolean mLeftExpand = true;
private float mLeftStartWeight;
private float mLayoutWeightSum;
private Handler mAnimationHandler = new Handler();
private long mAnimationTime;

private Runnable mAnimationStep = new Runnable() {
@Override
public void run() {
long currentTime = System.currentTimeMillis();
float animationStep = (currentTime - mAnimationTime) * 1f / ANIMATION_DURATION;
float weightOffset = animationStep * (mLayoutWeightSum - mLeftStartWeight);

LinearLayout.LayoutParams leftParams = (LinearLayout.LayoutParams)
mLeftView.getLayoutParams();
LinearLayout.LayoutParams rightParams = (LinearLayout.LayoutParams)
mRightView.getLayoutParams();

leftParams.weight += mLeftExpand ? weightOffset : -weightOffset;
rightParams.weight += mLeftExpand ? -weightOffset : weightOffset;

if (leftParams.weight >= mLayoutWeightSum) {
mAnimating = false;
leftParams.weight = mLayoutWeightSum;
rightParams.weight = 0;
} else if (leftParams.weight <= mLeftStartWeight) {
mAnimating = false;
leftParams.weight = mLeftStartWeight;
rightParams.weight = mLayoutWeightSum - mLeftStartWeight;
}

mSlidingLayout.requestLayout();

mAnimationTime = currentTime;

if (mAnimating) {
mAnimationHandler.postDelayed(mAnimationStep, 30);
}
}
};

private void toggleExpand(boolean expand) {
mLeftExpand = expand;

if (!mAnimating) {
mAnimating = true;
mAnimationTime = System.currentTimeMillis();
mAnimationHandler.postDelayed(mAnimationStep, 30);
}
}

@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.slide_test);

mLeftView = findViewById(R.id.left);
mRightView = findViewById(R.id.right);
mSlidingLayout = findViewById(R.id.slide_layout);

mLeftStartWeight = ((LinearLayout.LayoutParams)
mLeftView.getLayoutParams()).weight;
mLayoutWeightSum = ((LinearLayout) mSlidingLayout).getWeightSum();
}
}

关于android - ViewGroups 的一个 Animate Layout 属性是如何实现的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7519479/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com