Съезжают элементы на разных устройствах

Решил сделать первое объемное приложение, по коду всё отлично, всё работает, а вот по макету Activity у меня возникают большие вопросы на которые я не могу найти ответы в интернете, поэтому и спрашиваю у вас.

Основная проблема в том, что элементы при запуске на разных мобильных устройств стоят неправильно как планировалось иногда вообще выходит всё из экрана (устройства на которых тестировал: Honor 7a pro (абсолютно все элементы расширяются до невероятных размеров и выходят за экран), huawei p smart 2019 (элементы стоят неправильно). Эмулятор на котором работаю - Pixel API 28, там всё хорошо. Многие элементы создавались в Figma и были перемещены в проект в виде вектора. Я понимаю то что, проблема в dp и пикселях устройств, но как другие разработчики делают все без ошибок и их приложения поддерживают большинство устройств. Подскажите пожалуйста, буду очень благодарен. Код activity_main.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_width="match_parent"
    android:layout_height="match_parent"
    android:background="@color/fon"
    tools:context=".MainActivity">

    <TextView
        android:id="@+id/text1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="23dp"
        android:layout_marginTop="64dp"
        android:fontFamily="@font/montserrat_regular"
        android:text="@string/priv"
        android:textColor="@color/text_color"
        android:textSize="27sp"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <TextView
        android:id="@+id/text2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="23dp"
        android:layout_marginTop="120dp"
        android:fontFamily="@font/montserrat_light"
        android:text="@string/fdsf"
        android:textColor="@color/text_color2"
        android:textSize="15sp"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <ImageView
        android:id="@+id/imageView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="64dp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.0"
        app:layout_constraintStart_toEndOf="@+id/text2"
        app:layout_constraintTop_toTopOf="parent"
        app:srcCompat="@drawable/ic_robot_svgrepo_com" />


    <TextView
        android:id="@+id/text3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="23dp"
        android:layout_marginTop="40dp"
        android:fontFamily="@font/montserrat_regular"
        android:text="@string/azac2"
        android:textColor="@color/text_color"
        android:textSize="23sp"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/imageView" />

    <ImageView
        android:id="@+id/btn_rashod"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="23dp"
        android:layout_marginTop="20dp"
        app:layout_constraintEnd_toStartOf="@+id/btn_values"
        app:layout_constraintHorizontal_bias="0.0"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/text3"
        app:srcCompat="@drawable/ic_rashod" />

    <ImageView
        android:id="@+id/btn_values"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="20dp"
        android:layout_marginEnd="23dp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/text3"
        app:srcCompat="@drawable/ic_group_2btn_values" />

    <ImageView
        android:id="@+id/btn_currence"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="23dp"
        android:layout_marginTop="36dp"
        app:layout_constraintEnd_toStartOf="@+id/imageView6"
        app:layout_constraintHorizontal_bias="0.0"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/btn_rashod"
        app:srcCompat="@drawable/ic_group_3btn_money" />

    <ImageView
        android:id="@+id/imageView6"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="36dp"
        android:layout_marginEnd="23dp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/btn_values"
        app:srcCompat="@drawable/ic_group_4btn_aboutapp" />


</androidx.constraintlayout.widget.ConstraintLayout>

Приложение запущено на Huawei P Smart 2019

Эмулятор Pixel в Android Studio


Ответы (0 шт):