ConstraintLayout 编辑器偏向

ConstraintLayout Editor Biased

我一直在尝试为我的应用程序制作一个 GUI(使用 ConstraintLayout),其中我的图像就像对齐的按钮一样,但是,这些按钮(或实际上的任何东西)有这个奇怪的问题,即使我移动(并保存)约束位置,它只是回到某个数字(在本例中为 16)。

我在这里做错了什么?是什么原因this/Why是编辑重置了位置吗?

http://i.imgur.com/OFndFb7.gifv (GIF - 40s)

版本:

XML 布局:

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:layout_editor_absoluteY="25dp"
    tools:layout_editor_absoluteX="0dp">

    <Button
        android:id="@+id/Button_Color_Red"
        android:layout_width="40dp"
        android:layout_height="40dp"
        android:layout_marginTop="80dp"
        android:layout_marginStart="16dp"
        android:background="@drawable/btn_red_color_menu"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintLeft_toLeftOf="parent" />

    <Button
        android:id="@+id/Button_Color_Indigo"
        android:layout_width="40dp"
        android:layout_height="40dp"
        android:layout_marginTop="80dp"
        android:layout_marginStart="8dp"
        android:background="@drawable/btn_indigo_color_menu"
        app:layout_constraintLeft_toRightOf="@+id/Button_Color_Yellow"
        app:layout_constraintTop_toTopOf="parent" />

    <Button
        android:id="@+id/Button_Color_Green"
        android:layout_width="40dp"
        android:layout_height="40dp"
        android:layout_marginTop="80dp"
        android:layout_marginStart="8dp"
        android:background="@drawable/btn_green_color_menu"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintLeft_toRightOf="@+id/Button_Color_Indigo"/>

    <Button
        android:id="@+id/Button_Color_Yellow"
        android:layout_width="40dp"
        android:layout_height="40dp"
        android:layout_marginTop="80dp"
        android:layout_marginStart="8dp"
        android:background="@drawable/btn_yellow_color_menu"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintLeft_toRightOf="@+id/Button_Color_Red" />

</android.support.constraint.ConstraintLayout>

XML 对于 btn_x_color_menu:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item>
        <shape android:shape="rectangle">
            <solid android:color="@color/Red_Primary"/>
        </shape>
    </item>
</selector>

按钮 Button_Color_Green 上有两个属性发生冲突。

    android:layout_marginLeft="16dp"
    android:layout_marginStart="8dp"

当你移动按钮时,设计者创建了android:layout_marginLeft,但是android:layout_marginStart保持不变并且有冲突。这就是移动小部件后边距恢复的原因。

这两个属性对于从左到右的布局应该是相同的,但设计者似乎想要更改 android:layout_marginLeft 但如果它存在,则尊重 android:layout_marginStart

这可能是 ConstraintLayout 1.0.2 中的错误。在找到修复或更好的解决方案之前,您可以手动将这些属性更改为相同,或者只使用 android:layout_marginLeft 并稍后手动添加 android:layout_marginStart 。 (Lint 应该会提醒您这样做。)

既然您知道了这个问题,您也许可以找到更好的解决方案。

希望对您有所帮助。