7-5 ConstraintLayout

StrayCat·2022년 10월 5일
0

ConstraintLayout

  • 안드로이드 플랫폼이 아니라 androidx에서 제공하는 라이브러리이다.

  • ConstraintLayout은 상대위치로 배치하는 RelativeLayout과 비슷하지만 더 많은 속성값을 지원한다.

  • 안드로이드 스튜디오에서 XML 작성 뿐 아니라 화면을 마우스로 편집할 수 있도록 레이아웃 편집기를 제공한다.

  • 필요한 뷰를 드래그앤 드롭하여 화면에 넣은 후, 속성값을 입력하고 뷰의 상대위치를 지정해준다.

(드래그 앤 드롭으로 만든 화면)

(자동으로 생성되는 XML 레이아웃 파일)

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.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_height="match_parent"
    android:layout_width="match_parent">


    <ImageView
        android:id="@+id/imageView3"
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:layout_marginStart="30dp"
        android:layout_marginTop="30dp"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:srcCompat="@drawable/ic_launcher_foreground" />

    <TextView
        android:id="@+id/titleView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="20dp"
        android:text="카카오톡"
        android:textSize="20dp"
        app:layout_constraintStart_toEndOf="@+id/imageView3"
        app:layout_constraintTop_toTopOf="@+id/imageView3" />

    <TextView
        android:id="@+id/messageView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="20dp"
        android:text="기기 로그인 알림"
        android:textSize="20dp"
        app:layout_constraintBottom_toBottomOf="@+id/imageView3"
        app:layout_constraintStart_toEndOf="@+id/imageView3" />

    <TextView
        android:id="@+id/dateView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="30dp"
        android:layout_marginEnd="30dp"
        android:text="2022.10.06"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>

0개의 댓글