当前位置: 首页 > 知识库问答 >
问题:

仅使用一个布局文件对constraintlayout转换进行动画化

郎飞航
2023-03-14

我一直使用两个布局文件使用constraintlayout动画

private void animate() {
        ConstraintSet set1 = new ConstraintSet();
        set1.clone(root);

        ConstraintSet set2 = new ConstraintSet();
        set2.clone(this, R.layout.layout_file_2);

        TransitionManager.beginDelayedTransition(root, transition);
        set2.applyTo(root);
}

然而,在布局中,我只更改了两个约束。我决定尝试以编程方式这样做,并且这样做了,这起作用了。

private void showHidden() {
        ConstraintLayout parentLayout = findViewById(R.id.root_constraint_layout);
        ConstraintSet constraintSet = new ConstraintSet();
        constraintSet.clone(parentLayout);
        constraintSet.connect(R.id.search_layout, ConstraintSet.TOP, R.id.toolbar_layout, ConstraintSet.BOTTOM);
        constraintSet.connect(R.id.search_layout, ConstraintSet.BOTTOM, R.id.root_constraint_layout, ConstraintSet.BOTTOM);
        constraintSet.applyTo(parentLayout);
}

然而,这不是动画。我试着像之前在第一个中那样进行动画(这次只使用了一个布局文件),结果是这样的

private void animate2() {
        ConstraintLayout parentLayout = findViewById(R.id.root_constraint_layout);
        ConstraintSet set1 = new ConstraintSet();
        set1.clone(parentLayout);

        ConstraintSet set2 = new ConstraintSet();
        set2.clone(parentLayout);

        set2.connect(R.id.search_layout, ConstraintSet.TOP, R.id.toolbar_layout, ConstraintSet.BOTTOM);
        set2.connect(R.id.search_layout, ConstraintSet.BOTTOM, R.id.root_constraint_layout, ConstraintSet.BOTTOM);

        Transition transition = new Slide(Gravity.END).setDuration(500);
        TransitionManager.beginDelayedTransition(parentLayout, transition);

        set2.applyTo(parentLayout);
 }

这与第二个一样工作,但没有显示动画,新的约束立即跳入适当的位置。有没有什么方法可以让动画工作不使用两个layoyuts?还是我做错了什么?多谢了。

共有1个答案

沈宇定
2023-03-14

您没有清除应用约束集得视图侧得约束.您可以使用

constraintSet.clear(view.Layout.id, ConstraintSet.LEFT) //You can change LEFT with whatever side you are choosing 

使用connect功能连接布局侧之前。

以下是以更好的方式获得它的完整代码:-

val constraintSet = ConstraintSet()
    constraintSet.clone(view.rootLayout)
    view.layout.animate().alpha(1f).duration = 700
    constraintSet.clear(view.layout.id, ConstraintSet.LEFT)
    constraintSet.connect(
        view.layout.id,
        ConstraintSet.RIGHT,
        ConstraintSet.PARENT_ID,
        ConstraintSet.RIGHT
    )
    view.layout.animate().translationX(resources.getDimension(R.dimen.zeroDP))
    val transition: Transition = ChangeBounds()
    transition.interpolator = EasingInterpolator(Ease.QUINT_OUT)
    transition.duration = 700
    TransitionManager.beginDelayedTransition(view.rootLayout, transition)
    constraintSet.applyTo(view.rootLayout)
 类似资料:
  • 我正在创建一个我想要的相对布局,应该从上面滑到布局,所以这里是我所做的 使布局不可见 在oncreate中将屏幕上方的布局动画化 在onWindowsFocusChanged()中,我调用了动画,使布局可见,并希望布局滑入屏幕 但是 当视图被创建时,布局在其正确的位置,显示任何来自屏幕顶部的滑动效果 布局 这是activity的主题

  • 我总是使用以下代码在一个视图和另一个视图之间制作翻转动画: 这工作得很好,给人一种自然的感觉。 但是,当我在使用自动布局在故事板上定义的视图上使用它时,事情开始变得一团糟——在这个动画之后,视图被调整大小并移动。 有没有办法通过设置约束动画来设置这种翻转的动画?

  • 我有一个自定义视图CustomLayout(蓝色,自定义UIView),该视图包含3个子视图,通过使用约束(布局锚定)垂直对齐,每个视图按照以下顺序对齐: 1视图:幻灯片(红色,自定义UIView) 我想,当我单击按钮(黄色)时,如果使用动画打开,SlideLayout(红色)的高度大小会增加,如果关闭,则会减少。和其他视图必须在动画期间更改位置,如果SlideLayout增加/减少,则父视图(C

  • 问题内容: 我有一个小部件,当切换选项时,它会改变。这会使所有布局和小部件失效。我保留所有布局的列表,因此可以使用类似于以下答案的方法删除它们: 如何摆脱旧的布局并设置新的布局? 该文档非常简洁,显然不适用于python: QWidget.setLayout(self,QLayout) QLayout参数将其所有权转移到Qt。 将此窗口小部件的布局管理器设置为布局。 如果此小部件上已经安装了布局管

  • 本文向大家介绍HTML5画布转换,包括了HTML5画布转换的使用技巧和注意事项,需要的朋友参考一下 HTML5 canvas提供了允许直接修改转换矩阵的方法。转换矩阵最初必须是身份转换。然后可以使用转换方法对其进行调整。 示例 让我们看一个画布转换的例子:

  • 本文向大家介绍使用HTML5画布进行投影,包括了使用HTML5画布进行投影的使用技巧和注意事项,需要的朋友参考一下 HTML5 canvas提供了在图纸周围创建漂亮阴影的功能。所有绘图操作均受四个全局阴影属性影响。 序号 属性和说明 1 shadowColor [=值] 此属性返回当前阴影颜色,可以对其进行设置以更改阴影颜色。 2 shadowOffsetX [=值] 此属性返回当前阴影偏移量X,