如果我限制的视图的可见性消失,则使用marginTop
下方的xml将被忽略。
目前最新的布局lib版本com.android.support.constraint:constraint-layout:1.0.0-beta4
示例:
tvMessage
和ivCommentImage
为visible
- llLeftActions
上的16dp上边距和llRightActions
工作正常。如果ivCommentImage
为gone
,则忽略边距。
<android.support.v7.widget.CardView
android:layout_width="match_parent"
android:layout_height="wrap_content">
<android.support.constraint.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="16dp">
<!-- some more views here -->
<TextView
android:id="@+id/tvMessage"
style="@style/SocialFeed.Description"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginEnd="16dp"
android:layout_marginLeft="16dp"
android:layout_marginRight="16dp"
android:layout_marginStart="16dp"
android:layout_marginTop="16dp"
app:layout_constraintHorizontal_bias="0.0"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toBottomOf="@+id/ivProfile"
app:layout_goneMarginTop="0dp"
tools:text="@string/lorem_ipsum_140chars"/>
<android.support.v7.widget.AppCompatImageView
android:id="@+id/ivCommentImage"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginTop="16dp"
android:adjustViewBounds="true"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toBottomOf="@+id/tvMessage"
app:layout_goneMarginTop="0dp"
/>
<android.support.constraint.Guideline
android:id="@+id/gCenter"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical"
app:layout_constraintGuide_percent="0.5"/>
<LinearLayout
android:id="@+id/llLeftActions"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginTop="16dp"
android:gravity="center_vertical|left"
android:orientation="horizontal"
app:layout_constraintLeft_toLeftOf="@+id/tvMessage"
app:layout_constraintRight_toLeftOf="@+id/gCenter"
app:layout_constraintTop_toBottomOf="@+id/ivCommentImage"
app:layout_goneMarginTop="0dp"
/>
<LinearLayout
android:id="@+id/llRightActions"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginTop="16dp"
android:gravity="center_vertical|right"
android:orientation="horizontal"
app:layout_constraintLeft_toLeftOf="@+id/gCenter"
app:layout_constraintRight_toRightOf="@+id/tvMessage"
app:layout_constraintTop_toBottomOf="@+id/ivCommentImage"
app:layout_goneMarginTop="0dp"/>
</android.support.constraint.ConstraintLayout>
</android.support.v7.widget.CardView>
答案 0 :(得分:7)
它完全符合预期 - 请注意您在layout_goneMarginTop="0dp"
和@id/llLeftActions
上添加了@id/llRightActions
...
这意味着当他们指向的小部件(@id/ivCommentImage
)被标记为已消失时,将用于顶部连接的边距将为... 0dp,而不是16dp的边距。这就是这些属性的用途! :)
答案 1 :(得分:1)
platform :<ios, macos, tvos etc.>, '<version of the OS>'
请注意最后一行,在边缘周围添加约束使约束有效。
您还可以在Studio中使用设计视图,并在对象之间拖放约束。