Android-给图片添加阴影

本文介绍两种在安卓应用中实现图片阴影效果的方法。一种是通过自定义drawable使用layer-list定义两个图片,另一种是自定义view使用setShadowLayer绘制阴影,后者能提供更真实的虚化效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

给图片添加阴影效果,这是很常见的需求。第一种方法是自定义drawable,使用layer-list定义两个图片,代码如下:

show_view.xml:

<?xml version="1.0" encoding="utf-8"?> 
<layer-list xmlns:android="http://schemas.android.com/apk/res/android"> 
<!-- 阴影图片,android:left表示阴影图片左边到背景图片左边的距离
    android:top表示阴影图片上边到背景图片上边的距离-->
     <item   android:left="5dp"
        android:top="5dp">
         <shape> 
	          <corners android:radius="25dp"/>
	          <solid android:color="#60000000"/> 
          </shape> </item>
 <!-- 背景图片,android:right表示阴影图片右边到背景图片右边的距离
    android:bottom表示阴影图片下边到背景图片下边的距离-->
     <item   android:bottom="5dp"
        android:right="5dp"> 
        <shape> 
	         <corners android:radius="25dp"/>
	         <solid android:color="#000000"/>
          </shape> 
          </item>
           </layer-list>

在main.xml中定义一个textview作为待显示控件,将show_view.xml设为这个testview的背景,main.xml的代码如下:

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.example.liusiyutaloner.frescotest.MainActivity"> 
    <TextView
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:background="@drawable/shadow_view"/> 
</RelativeLayout>

运行程序显示效果如下:

看着还可以,但是这里面有一个缺陷,大家细看就会发现这个阴影是实边的,没有虚化的效果,这样就不够真实,影响用户体验。下面我们来看第二种方法。

第二种方式就是自定义view,代码里通过setShadowLayer绘制图片阴影,代码如下:

CustomShadowView类:

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color; 
import android.graphics.Paint; 
import android.graphics.RectF;
import android.util.AttributeSet;
import android.view.View; 
public class CustomShadowView extends View { 
private Paint mPaint;
 public CustomShadowView(Context context, AttributeSet attrs) { 
 			super(context, attrs); 
 			mPaint = new Paint(); mPaint.setColor(Color.BLACK); 			
 		   this.setLayerType(View.LAYER_TYPE_SOFTWARE, null); 
 			} 
 			@Override
 protected void onDraw(Canvas canvas) {
 			  super.onDraw(canvas); 
 			  //绘制阴影,param1:模糊半径;param2:x轴大小:param3:y轴大小;param4:阴影颜色 			mPaint.setShadowLayer(10F, 15F, 15F, Color.GRAY);
 			   RectF rect = new RectF(0 , 0, 200, 200);
 			    canvas.drawRoundRect(rect, (float)75, (float)75, mPaint); } }

再将CustomShadowView类加到main.xml中,代码如下:

<?xml version="1.0" encoding="utf-8"?>
 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="150dp"
    android:layout_height="150dp"
    tools:context="com.example.liusiyutaloner.frescotest.MainActivity"> 
 <com.example.liusiyutaloner.frescotest.CustomShadowView
        android:layout_gravity="center"
        android:layout_width="125dp"
        android:layout_height="125dp"
        android:layout_centerHorizontal="true" />
</RelativeLayout>

运行即可看到以下效果:
在这里插入图片描述
可以看到这种方法绘制出的阴影有虚化效果,多了立体感和层次感,所以更推荐使用。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值