以编程方式设置Android圆形约束半径。

7

我开始使用 ConstraintLayout 的 "新" 约束选项,即 环形约束

我希望能够通过编程的方式为 layout_constraintCircleRadius 属性应用值,因为我将会以编程方式计算视图的半径。

我尝试了很多不同的方式,使用了从 文档 中描述的 public void constrainCircle (int viewId,int id,int radius,float angle) 方法。

我也在许多论坛上搜索过,但是没有找到任何相关信息。是否有人曾经遇到过这样的问题?

<android.support.constraint.ConstraintLayout
    android:id="@+id/circle_constraint"
    android:layout_width="0dp"
    android:layout_height="0dp"
    app:layout_constraintTop_toTopOf="parent"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintWidth_percent="0.8"
    app:layout_constraintDimensionRatio="W,1:1"
    android:background="@drawable/circle">

    <View
        android:id="@+id/circle_center"
        android:layout_width="20dp"
        android:layout_height="20dp"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        android:background="#ff0000"/>

    <View
        android:id="@+id/circle_position_0"
        android:layout_width="30dp"
        android:layout_height="27dp"
        android:background="#000000"
        app:layout_constraintCircle="@id/circle_center"/>
</android.support.constraint.ConstraintLayout>

圆心将保持在主约束视图的中心位置,我想通过编程方式将半径和角度应用于circle_position_0。
谢谢!

你能分享一下你的代码吗?我猜你没有克隆和应用 ConstraintSet 是你的问题(从你的代码中可以看出更多)。 - Jeel Vankhede
我刚刚更新了我的代码问题! - Lajos Neto
你能否提供在activity/fragment中添加ConstraintSet的位置? - Jeel Vankhede
2个回答

10
如果您想修改circleRadius的值,可以从视图中获取ConstraintLayout.LayoutParams,并设置您的circleRadius属性值。最后将LayoutParams应用于该视图。

示例代码:

    ConstraintLayout.LayoutParams layoutParams = (ConstraintLayout.LayoutParams) fab1.getLayoutParams();
    layoutParams.circleRadius = 300;
    fab1.setLayoutParams(layoutParams);
如果您想要对“circleRadius”进行动画处理,可以使用ValueAnimator进行动画处理。在“onAnimationUpdate”方法中,将新的“circleRadius”应用于“ConstraintLayout.LayoutParams”。

示例代码:

  private ValueAnimator getAnimator(final FloatingActionButton fab, long duration) {


    ValueAnimator anim = ValueAnimator.ofInt(150, 300);
    anim.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
        @Override
        public void onAnimationUpdate(ValueAnimator valueAnimator) {
            int val = (Integer) valueAnimator.getAnimatedValue();
            ConstraintLayout.LayoutParams layoutParams = (ConstraintLayout.LayoutParams) fab.getLayoutParams();
            layoutParams.circleRadius = val;
            fab.setLayoutParams(layoutParams);
        }
    });
    anim.setDuration(duration);
    anim.setInterpolator(new LinearInterpolator());
    anim.setRepeatMode(ValueAnimator.REVERSE);
    anim.setRepeatCount(ValueAnimator.INFINITE);

    return anim;
}



 ValueAnimator valueAnimator1 = getAnimator(fab1, 1000);
 valueAnimator1.start();

4

考虑使用以下代码来编程应用ConstraintSet

ConstraintLayout cl = (ConstraintLayout) findViewById(R.id.circle_constraint); // No need if you have already done.
ConstraintSet c = new ConstraintSet(); // Make new ConstraintSet.
c.clone(cl); // Cloning from our ConstraintLayout or else our ConstraintSet won't get affect on ConstraintLayout.
c.constrainCircle(R.id.circle_position_0, R.id.circle_center, 40, 45); // Applying our circle constraint, use anything replacing 40 for radius & 45 for any angle.
c.applyTo(cl); // Apply back our ConstraintSet on ConstraintLayout.

您需要从现有布局中克隆约束集,然后将其应用于您想要添加约束的布局,并在完成后重新应用到您的布局中。


@Lajos 请尝试这个并告诉我。 - Jeel Vankhede

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接