android layout - studio - Esta vista no está restringida verticalmente. En tiempo de ejecución saltará a la izquierda a menos que agregue una restricción vertical
restricciones constraint layout (10)
Desde Android Studio v3 y superior, Infer Constraint se eliminó del menú desplegable.
Use el icono de la varita mágica en el menú de la barra de herramientas sobre la vista previa del diseño; existe el botón " Inferir restricciones ". Haga clic en este botón, esto agregará automáticamente algunas líneas en el campo de texto y se eliminará la línea roja.
El nuevo editor de diseño en Android Studio 2.2 sigue mostrando este error en vistas como EditText y Buttons. amablemente ayuda. También, cualquier enlace que ayude en la incorporación con el nuevo diseño de restricción sería apreciado.
código:
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
android:id="@+id/activity_main"
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:context="com.set.email.MainActivity"
tools:layout_editor_absoluteX="0dp"
tools:layout_editor_absoluteY="81dp">
<TextView
android:text="To:"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
tools:layout_editor_absoluteX="7dp"
tools:layout_editor_absoluteY="4dp"
android:id="@+id/textTo"/>
<EditText
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:inputType="textEmailAddress"
android:ems="10"
tools:layout_editor_absoluteX="0dp"
tools:layout_editor_absoluteY="24dp"
android:id="@+id/editTo"
android:textAppearance="@android:style/TextAppearance.DeviceDefault.Medium"/>
<EditText
android:layout_width="384dp"
android:layout_height="42dp"
android:inputType="textPersonName"
android:ems="10"
tools:layout_editor_absoluteX="0dp"
tools:layout_editor_absoluteY="94dp"
android:id="@+id/editSubject"
android:textAppearance="@android:style/TextAppearance.DeviceDefault.Medium"/>
<EditText
android:layout_width="384dp"
android:layout_height="273dp"
android:inputType="textPersonName"
android:ems="10"
tools:layout_editor_absoluteX="0dp"
tools:layout_editor_absoluteY="179dp"
android:id="@+id/editMessage"
app:layout_constraintLeft_toLeftOf="@+id/activity_main"
tools:layout_constraintLeft_creator="50"
android:textAppearance="@android:style/TextAppearance.DeviceDefault.Medium"/>
<Button
android:text="Send"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
tools:layout_editor_absoluteX="140dp"
tools:layout_editor_absoluteY="454dp"
android:id="@+id/btnSend"
app:layout_constraintLeft_toLeftOf="@+id/editMessage"
tools:layout_constraintLeft_creator="0"
app:layout_constraintRight_toRightOf="@+id/activity_main"
android:layout_marginEnd="16dp"
tools:layout_constraintRight_creator="0"
android:textAppearance="@android:style/TextAppearance.DeviceDefault.Medium"/>
</android.support.constraint.ConstraintLayout>
El diseño de restricción tiene como objetivo reducir las jerarquías de diseño y mejorar el rendimiento de los diseños (técnicamente, no tiene que hacer cambios para diferentes tamaños de pantalla, sin superposición, funciona como un encanto en un móvil, así como una pestaña con las mismas restricciones). se deshace del error anterior cuando está utilizando el nuevo editor de diseño.
Haga clic en el círculo pequeño y arrástrelo hacia la izquierda hasta que el círculo se vuelva verde, para agregar una restricción izquierda (dé un número, digamos x dp. Repítalo con los otros lados y deje la restricción inferior en blanco si tiene otra vista debajo de ella) .
Editar: según el sitio de desarrolladores, en lugar de agregar restricciones a cada vista a medida que las coloca en el diseño, puede mover cada vista a las posiciones que desee y luego hacer clic en Inferir restricciones para crear restricciones automáticamente. mas here
Si Inferir las
Constraints
todavía te da el error, solo usa este código:
app:layout_constraintBottom_toBottomOf="parent"
Simplemente cambie a la Vista de diseño y localice el widget en cuestión. Tome uno de los puntos en el límite del widget y únalo a un borde apropiado de la pantalla (o a un punto en algún otro widget).
Por ejemplo, si el widget es una barra de herramientas, simplemente tome el punto superior y únalo al borde superior de la pantalla del teléfono como se muestra en la imagen.
Simplemente copie este código a todos los componentes que arrastrará.
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
ejemplo:
<TextView
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
android:text="To:"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
tools:layout_editor_absoluteX="7dp"
tools:layout_editor_absoluteY="4dp"
android:id="@+id/textTo"/>
Vaya al Diseño, haga clic con el botón derecho en su Widget, Diseño de restricción >> Inferir restricciones. Puede observar que algún código se ha agregado automáticamente a su texto.
Vaya al Texto de diseño XML donde el widget (botón u otra Vista) indica error, enfoque el cursor allí y presione alt + enter y seleccione los atributos de restricciones faltantes.
por ejemplo tengo esto
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
use un diseño RelativeLayout como este
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
EditText
arrastrar
EditText
desde el borde del diseño y no solo el otro widget.
También puede agregar restricciones simplemente arrastrando el punto de restricción que rodea el widget al borde de la pantalla para agregar restricciones como se especifica.
El código modificado se verá similar a esto:
app:layout_constraintLeft_toLeftOf="@+id/router_text"
app:layout_constraintTop_toTopOf="@+id/activity_main"
android:layout_marginTop="320dp"
app:layout_constraintBottom_toBottomOf="@+id/activity_main"
android:layout_marginBottom="16dp"
app:layout_constraintVertical_bias="0.29"
Follow these steps:
Right click on designing part > Constraint Layout > Infer Constraints