向EditText字段添加阴影效果

swi*_*Boy 13 xml android effects dropshadow android-edittext

我试图像这样设计一个具有阴影(底部和右侧)的EditText字段

在此输入图像描述

尝试谷歌搜索和搜索许多SO讨论,但都是TextView而不是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>
Run Code Online (Sandbox Code Playgroud)

我想它需要一些可绘制的自定义xml视图,但没有得到确切的想法.实现这一目标的逻辑是什么.

任何帮助,将不胜感激.

swi*_*Boy 24

嗯.. @ Shalini的答案以这种方式帮助了我,但我仍然有另一种方法来使用EditText Field实现2D阴影,我将与你分享.

我们需要为EditText,底部阴影和右侧阴影创建三层自定义XML视图

以下是我的代码.

RES /抽拉/ 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>
Run Code Online (Sandbox Code Playgroud)

现在我们可以使用"Background"属性将此阴影视图设置为TextField

像这样

RES /布局/ 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>
Run Code Online (Sandbox Code Playgroud)

结果屏幕就像我上面发布的问题一样.

感谢SO,分享知识.

  • 上面的答案在功能上是正确的,但在图层列表中不需要第二项.第一项对于两个阴影都足够了. (5认同)

Sha*_*ini 9

这对我有用..

   <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" />
Run Code Online (Sandbox Code Playgroud)

希望能帮助到你:)

  • 您的解决方案对我不起作用.它将阴影添加到文本(EditText内容),而不是EditText组件的边框.我错过了什么? (16认同)