【问题标题】:Android Button border shadowAndroid Button 边框阴影
【发布时间】:2012-04-10 07:09:31
【问题描述】:

Button 视图中的Shadow 属性为文本提供阴影。如何给 Button 的右下边框加上阴影?如下图所示:

【问题讨论】:

标签: android button shadow


【解决方案1】:

你可以试试。我在我的项目中使用它。我给按钮的右侧和底部边框提供阴影。

按钮 xml

<Button
      android:id="@+id/buttonSignIn"
      android:layout_width="fill_parent"
      android:layout_height="50dp"
      android:background="@drawable/button_dropshadow"
      android:textColor="000000"
      android:text="Sign In" />

在drawable文件中添加button_dropshadow.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item>
    <layer-list>
        <item android:left="5dp" android:top="5dp">
            <shape>
                <corners android:radius="3dp" />
                <solid android:color="#000000" />
            </shape>
        </item>
        <item android:bottom="2dp" android:right="2dp">
            <shape>
                <gradient android:angle="270" 
                    android:endColor="#ffffff" android:startColor="#ffffff" />
                <stroke android:width="1dp" android:color="#000000" />
                <corners android:radius="4dp" />
                <padding android:bottom="10dp" android:left="10dp" 
                    android:right="10dp" android:top="10dp" />
            </shape>
        </item>
    </layer-list>
</item>

</selector>

谢谢。

【讨论】:

    【解决方案2】:

    尝试使用选择器制作自己的按钮 9 补丁图像:

    btn_normal.9.png

    btn_pressed.9.png

    btn_focused.9.png

    btn_selector.xml

    <?xml version="1.0" encoding="utf-8"?>
    <selector xmlns:android="http://schemas.android.com/apk/res/android">
        <item android:state_selected="true" android:drawable="@drawable/btn_focused" />
        <item android:state_focused="true" android:drawable="@drawable/btn_focused" />
        <item android:state_pressed="true" android:drawable="@drawable/btn_pressed" />
        <item android:drawable="@drawable/btn_normal" />
    </selector>
    

    并在按钮的属性中添加android:background="@drawable/btn_selector"

    【讨论】:

      【解决方案3】:

      Here 是我发现并可以提供帮助的 Blob 帖子。它只能在相对布局中工作。创建一个与您的按钮大小相同的 View 组件,并将其放在下面:

      <Button
          android:id="+@id\my_button"
          android:layout_below="@id/some_layout_item"
          android:layout_width="100dp"
          android:layout_height="5dp"
          >
      </Button>
      <View
          android:layout_below="@id/my_button"
          android:layout_width="100dp"
          android:layout_height="5dp"
          android:background="@drawable/drop_shadow"
          >
      </View>
      

      将阴影创建为可绘制对象 (drop_shadow.xml):

      <?xml version="1.0" encoding="utf-8"?>
      <shape xmlns:android=”http://schemas.android.com/apk/res/android”>    
          <gradient
              android:startColor="@color/cream_dark"
              android:endColor="@color/cream"
              android:angle="270"
              >
          </gradient>
      </shape>
      

      【讨论】:

      • 这仅设置背景颜色。我不想改变背景颜色。我只想右下边框。
      • 我认为你可以通过使用第二个视图的尺寸和边距来实现你想要的。
      • 您想说,在按钮后面放置一个黑色视图?
      • 这真是一项繁琐的工作。我正在尝试使用可绘制的形状来做到这一点。
      【解决方案4】:

      我的按钮背景是这样设置的

      <?xml version="1.0" encoding="utf-8"?>
      <shape xmlns:android="http://schemas.android.com/apk/res/android" >
          <gradient
           android:startColor="@android:color/holo_green_dark"
           android:endColor="@android:color/holo_green_light"
           android:angle="90">
         </gradient>
           <stroke
           android:width="1px"
           android:color="@android:color/darker_gray" />
      </shape>
      

      可以通过在原始按钮形状下添加第二个形状来实现阴影效果,将其颜色更改为黑色或灰色的较暗颜色。但是阴影应该和按钮的形状一样。

       <?xml version="1.0" encoding="utf-8"?>
       <shape xmlns:android="http://schemas.android.com/apk/res/android" >
      
           <solid android:color="@android:color/darker_gray"/>
      
       </shape>
      

      要重叠不同的项目,我们必须使用“层列表”资源并包含以前的形状。阴影应该出现在第一个位置,然后是带有一些位移的原始按钮。在本例中,我们在按钮底部创建阴影,偏移量为 4px。

      <?xml version="1.0" encoding="utf-8"?>
      <layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
         <item android:drawable="@drawable/shadow"/>
         <item
           android:drawable="@drawable/button"
           android:bottom="4px" 
           android:right="4px"
           />  
       </layer-list>
      

      现在将按钮的背景设置为图层列表可绘制对象。这应该部分完成。

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2015-02-09
        • 1970-01-01
        • 2018-08-29
        • 1970-01-01
        • 2015-04-13
        • 1970-01-01
        相关资源
        最近更新 更多