web-dev-qa-db-ja.com

ConstraintLayoutで立面図と影付きで表示

ConstraintLayoutを使用して、影付きのビューに標高を表示するにはどうすればよいですか?

RelativeLinearを使用すると、シャドウを使用して標高を実行してリストを実装できますが、ConstraintLayoutを使用して実行することはできません。

<?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="wrap_content"
Android:background="#fff"
Android:orientation="vertical">

<TextView
    Android:id="@+id/list_ssid"
    Android:layout_width="wrap_content"
    Android:layout_height="wrap_content"
    Android:layout_marginEnd="8dp"
    Android:layout_marginLeft="8dp"
    Android:layout_marginRight="8dp"
    Android:layout_marginStart="8dp"
    Android:layout_marginTop="8dp"
    Android:elevation="8dp"
    Android:background="#fff"
    Android:text="SSID"
    app:layout_constraintLeft_toLeftOf="parent"
    app:layout_constraintRight_toLeftOf="@+id/guideline"
    app:layout_constraintTop_toTopOf="parent" />
<TextView
    Android:id="@+id/list_ch"
    Android:layout_width="wrap_content"
    Android:layout_height="wrap_content"
    Android:layout_marginEnd="8dp"
    Android:layout_marginLeft="8dp"
    Android:elevation="8dp"
    Android:background="#fff"
    Android:layout_marginRight="8dp"
    Android:layout_marginStart="8dp"
    Android:layout_marginTop="8dp"
    Android:text="CH"
    app:layout_constraintLeft_toLeftOf="@+id/guideline"
    app:layout_constraintRight_toLeftOf="@+id/guideline2"
    app:layout_constraintTop_toTopOf="parent" />
<TextView
    Android:id="@+id/list_dB"
    Android:layout_width="wrap_content"
    Android:layout_height="wrap_content"
    Android:layout_marginEnd="8dp"
    Android:layout_marginLeft="8dp"
    Android:elevation="8dp"
    Android:background="#fff"
    Android:layout_marginRight="8dp"
    Android:layout_marginStart="8dp"
    Android:layout_marginTop="8dp"
    Android:text="dB"
    app:layout_constraintLeft_toLeftOf="@+id/guideline2"
    app:layout_constraintRight_toRightOf="parent"
    app:layout_constraintTop_toTopOf="parent" />
<Android.support.constraint.Guideline
    Android:id="@+id/guideline"
    Android:layout_width="wrap_content"
    Android:layout_height="wrap_content"
    Android:orientation="vertical"
    app:layout_constraintGuide_percent="0.65"
    tools:layout_editor_absoluteX="239dp"
    tools:layout_editor_absoluteY="0dp" />
  <Android.support.constraint.Guideline
    Android:id="@+id/guideline2"
    Android:layout_width="wrap_content"
    Android:layout_height="wrap_content"
    Android:orientation="vertical"
    app:layout_constraintGuide_percent="0.83"
    tools:layout_editor_absoluteX="306dp"
    tools:layout_editor_absoluteY="0dp" />
   </Android.support.constraint.ConstraintLayout>
8
PepitoGrillo

何らかの理由で、背景としてダミーのドローアブルを指定すると、標高はConstraintLayoutで機能します::

ドローアブルを作成します。

dumpyBg.xml

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:Android="http://schemas.Android.com/apk/res/Android">
    <item>
        <shape Android:shape="rectangle">
            <solid Android:color="@Android:color/white"/>
            <corners Android:radius="2dp" />
        </shape>
    </item>
</layer-list>

これをビューの背景として使用し、通常どおりに標高を使用します。

    Android:elevation="8dp"
    Android:background="@drawable/dummyBg"
    Android:padding="4dp"

だからあなたは得るでしょう:

<TextView
    Android:id="@+id/list_ssid"
    Android:layout_width="wrap_content"
    Android:layout_height="wrap_content"
    Android:layout_marginEnd="8dp"
    Android:layout_marginLeft="8dp"
    Android:layout_marginRight="8dp"
    Android:layout_marginStart="8dp"
    Android:layout_marginTop="6dp"
    Android:layout_marginBottom="2dp"
    Android:elevation="8dp"
    Android:background="@drawable/dummyBg"
    Android:padding="4dp"
    Android:text="SSID"
    app:layout_constraintLeft_toLeftOf="parent"
    app:layout_constraintRight_toLeftOf="@+id/guideline"
    app:layout_constraintTop_toTopOf="parent"
    app:layout_constraintBottom_toBottomOf="parent"/>
12
Nuzha

立面図を機能させるには、背景色を設定するだけビューに設定する必要があります。

<TextView
    Android:layout_width="wrap_content"
    Android:layout_height="wrap_content"
    Android:background="@color/your_color"
    Android:text="SSID"/>

それがどんな種類のビューであるかは関係ありません、
ConstraintLayoutまたはConstraintLayout自体の子

16進数の色またはcolor属性を使用することもできます。
完全に透明であってはならないことに注意してください。

1
Leo Droidcoder