分组
Android里的ConstraintLayout是个非常强大的工具,欧博它有效的解决了Android里Layout的层级嵌套的问题。使用一个ConstraintLayout可以实现之前多个Layout才能实现的效果。
本篇文章就介绍下ConstraintLayout里比较进阶用法之一:Group。
在我们的日常开发中,经常遇到这种场景:几个控件需要同时消失或者出现。在没有ConstraintLayout的时代,这个操作很容易:因为这些控件一般都在一个父ViewGroup里,欧博娱乐所以只要把这个ViewGroup设置消失或出现即可。
但是,当我们引入了ConstraintLayout之后,因为消除了层级嵌套,欧博allbet所有的控件都“平摊”在作为root的ConstraintLayout下面了。在这种情况下,要方便的同时操作几个控件,似乎比以前麻烦了。
Group就是为了解决这个问题而诞生的。
Group示例首先,欧博百家乐我们定义2个控件:
<Button android:id="@+id/btn_a" android:layout_width="wrap_content" android:layout_height="wrap_content" app:layout_constraintTop_toTopOf="parent" app:layout_constraintLeft_toLeftOf="parent" android:layout_marginTop="200dp" android:layout_marginLeft="30dp" android:text="这是控件A"/> <Button android:id="@+id/btn_b" android:layout_width="wrap_content" android:layout_height="wrap_content" app:layout_constraintLeft_toLeftOf="@id/btn_a" app:layout_constraintTop_toBottomOf="@id/btn_a" android:layout_marginTop="30dp" android:text="这是控件B"/>然后,我们定义一个Group:
<android.support.constraint.Group android:id="@+id/group" android:layout_width="wrap_content" android:layout_height="wrap_content" android:visibility="visible" app:constraint_referenced_ids="btn_a,btn_b"/>通过app:constraint_referenced_ids="btn_a,btn_b"这句,让group把btn_a和btn_b两个控件包含进来。注意,虽然Group也是一个控件,但是在UI上是看不见的。
接下来,我们可以通过操作这个Group来同时操作btn_a和btn_b两个控件:
findViewById(R.id.group).setVisibility(View.GONE);上面这行代码可以把btn_a和btn_b同时设置为View.Gone。
注意:一个控件可以属于多个Group,这是允许的。此时,这个控件的属性由xml里最后一个包含它的Group决定。
以上就是对ConstraintLayout里Group的介绍,希望可以帮到你。