ConstraintLayout 的蓝图与最终设计不符

ConstraintLayout's blueprint does not match the final design

因为我已经更新到 Android Studio 2.2,所以我尝试使用新的 ConstraintLayout 来创建一个简单的 Activity。令人惊讶的是,alpha 8(目前是最新的)确实有问题,导致蓝图阶段多次重置。

主要问题是我通过蓝图添加的所有项目都没有限制在“设计”选项卡中:

Design and Blueprint

依赖项:

dependencies {
    compile fileTree(include: ['*.jar'], dir: 'libs')
    //testCompile 'junit:junit:4.12'
    compile 'com.android.support:appcompat-v7:24.2.1'
    compile 'com.android.support:design:24.2.1'
    compile 'com.google.android.gms:play-services-appindexing:9.4.0'
    compile 'org.apache.openejb:openejb-telnet:3.1.4'
    compile 'com.android.support.constraint:constraint-layout:1.0.0-alpha8'
}

我确实记得在创建新的 Empty Activity 时取消选中或选中某些复选标记。跟那个有关系吗?

Activity class 扩展 Activity.

请帮我解决新布局构造函数的错误。

XML:

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:id="@+id/activity_telnet"
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="xx.xxx.xxxx.TelnetActivity">

    <TextView
        android:text="IP:"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/tv_IP"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintLeft_toLeftOf="parent"/>
    <EditText
        android:layout_width="180dp"
        android:layout_height="16dp"
        android:inputType="text|textPersonName"
        android:ems="10"
        android:id="@+id/et_IP"
        android:layout_marginStart="80dp"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintLeft_toRightOf="@+id/tv_IP" android:layout_marginLeft="80dp"
    />
    <TextView
        android:text="Port:"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/tv_port"
        app:layout_constraintLeft_toLeftOf="@+id/tv_IP"
        android:layout_marginTop="16dp" app:layout_constraintTop_toBottomOf="@+id/tv_IP"/>
    <EditText
        android:layout_width="180dp"
        android:layout_height="16dp"
        android:inputType="number"
        android:ems="10"
        android:id="@+id/et_port"
        app:layout_constraintBottom_toBottomOf="@+id/tv_port"
        app:layout_constraintLeft_toLeftOf="@+id/et_IP"
    />
    <Button
        android:text="Connect"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/btn_connect"
        app:layout_constraintRight_toRightOf="parent"
        android:layout_marginTop="16dp" app:layout_constraintTop_toBottomOf="@+id/et_port"
        app:layout_constraintLeft_toLeftOf="parent"
        tools:layout_constraintRight_creator="1" tools:layout_constraintLeft_creator="1"
        android:onClick="connect (TelnetActivity)"/>
    <TextView
        android:text="Status:"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/textView3"
        android:layout_marginTop="16dp" app:layout_constraintTop_toBottomOf="@+id/btn_connect"
        app:layout_constraintLeft_toLeftOf="parent"/>
    <TextView
        android:text="Disconnected"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/tv_status"
        app:layout_constraintTop_toTopOf="@+id/textView3"
        app:layout_constraintLeft_toLeftOf="@+id/et_port"/>
    <TextView
        android:text="Send msg:"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/textView4"
        android:layout_marginTop="16dp" app:layout_constraintTop_toBottomOf="@+id/textView3"
        app:layout_constraintLeft_toLeftOf="@+id/textView3"/>
    <EditText
        android:layout_height="16dp"
        android:ems="10"
        android:id="@+id/et_sendMsg"
        android:layout_width="180dp" android:inputType="text"
        app:layout_constraintBottom_toBottomOf="@+id/textView4"
        app:layout_constraintRight_toRightOf="@+id/et_port"/>
    <TextView
        android:text="Response:"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/textView5"
        android:layout_marginTop="16dp" app:layout_constraintTop_toBottomOf="@+id/textView4"
        app:layout_constraintLeft_toLeftOf="parent"/>
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/tv_response"
        app:layout_constraintBottom_toBottomOf="@+id/textView5"
        app:layout_constraintLeft_toLeftOf="@+id/tv_status"
        app:layout_constraintTop_toTopOf="@+id/textView5"/>
    <Button
        android:text="OK"
        android:layout_width="88dp"
        android:layout_height="48dp"
        android:id="@+id/btn_sendMsg"
        app:layout_constraintBottom_toBottomOf="@+id/et_sendMsg"
        app:layout_constraintTop_toTopOf="@+id/et_sendMsg"
        android:layout_marginBottom="16dp"
        android:layout_marginStart="24dp"
        app:layout_constraintLeft_toRightOf="@+id/et_port" android:layout_marginLeft="24dp"
        app:layout_constraintVertical_bias="0.44" android:onClick="sendMsg (TelnetActivity)"/>
</android.support.constraint.ConstraintLayout>

PS:重新启动 Android Studio 有助于将所有元素放在正确的位置,直到我移动了其中任何一个。在那之后——一切再次崩溃。

如果您从 alpha7 更新到 alpha8(如果您下载 Android Studio 2.2 可能就是这种情况),您可能需要重建项目 and/or 在 Studio 中执行文件-> 使缓存无效-- 尽管重新启动 Studio 应该就足够了。告诉我这是否适合你。

还有;您 运行 处于哪种环境? (Windows、Mac、Linux,哪个 JVM...)