Ton*_*ong 10 layout animation android android-3.0-honeycomb
我LayoutTransition在Honeycomb 尝试新课程.我已经设置了一个动画,View当它添加到一个时,它会滑动到位ViewGroup.我注意到视图首次渲染和LayoutTransition.APPEARING动画开始之间有一点延迟(大约20ms).换句话说,在屏幕上出现视图后,它会在空中停留片刻,然后开始动画到位.您甚至可以在ApiDemos示例项目中注意到这一点.在布局动画示例中,在ViewGroup开始播放动画之前总会有延迟.我甚至尝试将其他LayoutTransition动画设置为null,或者最终给它们设置非常短的持续时间,但APPEARING动画仍然会延迟.这是我的代码:
public class DebugExampleFour extends Activity {
private int numButtons = 1;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.debug_example_four);
final ViewGroup frame = (ViewGroup) findViewById(R.id.frame_container);
LayoutTransition transitioner = new LayoutTransition();
Animator appearingAnimation = ObjectAnimator.ofFloat(null, "translationX", 600, 0);
appearingAnimation.setDuration(45);
appearingAnimation.setStartDelay(0);
appearingAnimation.setInterpolator(new DecelerateInterpolator());
appearingAnimation.addListener(new AnimatorListenerAdapter() {
public void onAnimationEnd(Animator anim) {
View view = (View) ((ObjectAnimator) anim).getTarget();
view.setTranslationX(0f);
}
});
transitioner.setAnimator(LayoutTransition.APPEARING, appearingAnimation);
Animator dummyAnimation = ObjectAnimator.ofInt(0, 1);
dummyAnimation.setDuration(1);
dummyAnimation.setStartDelay(0);
transitioner.setAnimator(LayoutTransition.CHANGE_APPEARING, dummyAnimation);
transitioner.setAnimator(LayoutTransition.CHANGE_DISAPPEARING, dummyAnimation);
transitioner.setAnimator(LayoutTransition.DISAPPEARING, dummyAnimation);
frame.setLayoutTransition(transitioner);
Button addButton = (Button) findViewById(R.id.addNewButton);
addButton.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
Button newButton = new Button(DebugExampleFour.this);
newButton.setText("Click To Remove " + (numButtons++));
newButton.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
frame.removeView(v);
}
});
frame.addView(newButton, new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
}
});
}
}
Run Code Online (Sandbox Code Playgroud)
这是与示例一起的布局文件:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent" android:layout_height="match_parent"
android:orientation="vertical">
<Button android:layout_width="wrap_content"
android:layout_height="wrap_content" android:text="Add Button"
android:id="@+id/addNewButton" />
<LinearLayout android:orientation="vertical"
android:layout_width="match_parent" android:layout_height="match_parent"
android:id="@+id/frame_container" android:animateLayoutChanges="true" />
</LinearLayout>
Run Code Online (Sandbox Code Playgroud)
如何消除APPEARING动画前的延迟?
Che*_*ase 28
对 - 两个级别都有延迟.当您在LayoutTransition的上下文中运行Animator时,您希望在LayoutTransition对象上设置duration和startDelay,而不是在底层Animator上设置(因为转换对象将为这些属性提供自己的值给动画师它运行).
原因是LayoutTransition通常是在容器内的对象上运行的一系列动画.因此,例如,如果您希望对象在容器中"显示",则转换将首先为其他对象设置动画,然后将新对象设置为动画.想象一下,将一个项目添加到一组对象的中间(就像你在ApiDemos应用程序中看到的那样); 它先制作空间,然后淡化物体.
对于上面的原始代码,您希望显示的动画立即运行,因此您应该将APPEARING的转换startDelay设置为0(正如您在上面的答案中所做的那样).
另一方面,默认情况下DISAPPEARING动画没有startDelay,但是CHANGE_DISAPPEARING动画的startDelay等于DISAPPEARING动画的持续时间,假设你首先要删除一个项目,然后将容器中的其他项目设置为动画.新的地方.
由于这些假设并不一定适用于所有情况,因此LayoutTransition上有duration/startDelay属性可根据您在特定情况下的工作方式来控制行为.
另请注意,如果您不想运行其中一种动画类型,则应将该动画设置为null(请参阅LayoutTransition.setAnimator(int,Animator)的文档).将它设置为dummyAnimator将不会产生相同的效果.首先,即使您为这些动画提供自定义动画制作工具,LayoutTransition上的默认持续时间/ startDelay值仍将适用.
还需要注意的是:基础计时机制(对于Android,但对于我曾经研究过的大多数其他平台)也会有一些最低分辨率.因此,您将持续时间设置为"1",这可能不会导致该动画以1毫秒结束.相反,它将运行一帧,然后在下一帧(通常是一个表现良好的应用程序中的设备的刷新率,如果系统没有陷入困境)它将看到动画应该结束.
原来,这两个Animator和LayoutTransition每个人都有一个启动延迟值.在Animator启动延时已经是零,因此没有帮助改变.奇怪的是,启动延迟LayoutTransition似乎大于零,至少在这种情况下是这样LayoutTransition.APPEARING.这是工作代码:
public class DebugExampleFour extends Activity {
private int numButtons = 1;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.debug_example_four);
final ViewGroup frame = (ViewGroup) findViewById(R.id.frame_container);
LayoutTransition transitioner = new LayoutTransition();
Animator appearingAnimation = ObjectAnimator.ofFloat(null, "translationX", 600, 0);
appearingAnimation.addListener(new AnimatorListenerAdapter() {
public void onAnimationEnd(Animator anim) {
View view = (View) ((ObjectAnimator) anim).getTarget();
view.setTranslationX(0f);
}
});
transitioner.setAnimator(LayoutTransition.APPEARING, appearingAnimation);
transitioner.setDuration(LayoutTransition.APPEARING, 300);
transitioner.setStartDelay(LayoutTransition.APPEARING, 0);
frame.setLayoutTransition(transitioner);
Button addButton = (Button) findViewById(R.id.addNewButton);
addButton.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
Button newButton = new Button(DebugExampleFour.this);
newButton.setText("Click To Remove " + (numButtons++));
newButton.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
frame.removeView(v);
}
});
frame.addView(newButton, new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
}
});
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
10468 次 |
| 最近记录: |