Подтвердить что ты не робот

Добавить эффекты тени в поле EditText

Я пытаюсь создать поле EditText, имеющее Shadows (нижнюю и правую стороны), подобные этому

enter image description here

попробовал googling и охотился на многие обсуждения SO, но все они предназначены для TextView not EditText.

Это мой код, добавляющий тень к входному тексту, но не к TextField

<EditText android:id="@+id/txtpin" 
        android:maxLength="4" 
        android:layout_marginLeft="10dp" 
        android:layout_height="37dp" 
        android:gravity="center_horizontal" 
        android:inputType="textPassword" 
        android:longClickable="false" 
        android:layout_width="160dp" 

        android:shadowColor="@color/Black"
        android:shadowDx="1.2"
        android:shadowDy="1.2"
        android:shadowRadius="1.5" 

        android:background="@color/White">
            <requestFocus></requestFocus>
        </EditText>

Я предполагаю, что он нуждается в некотором пользовательском представлении xml в drawable, но не в получении точной идеи. Какова будет логика для достижения этого.

Любая помощь будет оценена.

4b9b3361

Ответ 1

Ну.. ответ @Shalini помог мне таким образом, но все же у меня есть другой способ добиться двумерной тени с помощью поля EditText, и я собираюсь поделиться с вами.

Нам нужно создать пользовательский вид XML с тремя слоями для EditText, нижняя тень и правая сторона тени

Ниже мой код.

Рез/рисуем/edittext_shadow.xml

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">

<!-- most important is order of layers -->

    <!-- Bottom right side 2dp Shadow -->
    <item >
        <shape android:shape="rectangle">
            <solid android:color="#000000" />           
        </shape>
    </item>

    <!-- Bottom 2dp Shadow -->
    <item>
        <shape android:shape="rectangle">
            <solid android:color="#000000" />   
        </shape>
    </item>

    <!-- White Top color -->
    <item android:bottom="3px" android:right="3px">
        <shape android:shape="rectangle">
            <solid android:color="#FFFFFF" />           
        </shape>
    </item> 
</layer-list>

Теперь мы можем установить это теневое представление на наш TextField, используя свойство "Background"

как это

Рез/макет/main.xml

<EditText android:layout_width="wrap_content" 
            android:id="@+id/txtpin"  
            android:maxLength="4" 
            android:layout_height="37dp" 
            android:gravity="center_horizontal" 
            android:longClickable="false" 
            android:padding="2dp"

            android:inputType="textPassword|number" 
            android:password="true" 
            android:background="@drawable/edittext_shadow" 
            android:layout_weight="0.98" 
            android:layout_marginLeft="15dp">
                <requestFocus></requestFocus>
   </EditText>

и экран результатов похож на сообщение выше.

Благодаря SO, обмен знаниями.

Ответ 2

Это работает для меня..

   <EditText 
       android:layout_width="fill_parent" 
       android:shadowRadius="2"  
       android:shadowColor="#0000ff"
       android:shadowDx="2"
       android:shadowDy="4" 
       android:id="@+id/EditText01" 
       android:layout_height="wrap_content" />

Надеюсь, это поможет:)

Ответ 3

Из Эффект тени для текста в Android?, возможно, вы подумали бы об использовании

android:shadowColor, 
android:shadowDx,
android:shadowDy,
android:shadowRadius;

В качестве альтернативы:

setShadowLayer()