Android实现图片添加阴影效果的2种方法

作者:至浊至愚 时间:2022-10-31 06:46:55 

给图片添加阴影效果,这是很常见的需求。第一种方法是自定义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>

运行程序显示效果如下:

Android实现图片添加阴影效果的2种方法

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

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

CustomShadowView类:


package com.example.liusiyutaloner.frescotest;

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>

运行即可看到以下效果:

Android实现图片添加阴影效果的2种方法

可以看到这种方法绘制出的阴影有虚化效果,多了立体感和层次感,所以更推荐使用。

来源:http://blog.csdn.net/u011421608/article/details/51923812

标签:Android,图片,阴影
0
投稿

猜你喜欢

  • Java从服务端下载Excel模板文件的两种方法

    2021-08-29 05:44:40
  • Android下拉刷新上拉加载控件(适用于所有View)

    2022-09-20 21:40:20
  • C#中XML基础用法

    2023-08-05 17:12:34
  • Android编程实现3D立体旋转效果的实例代码

    2023-04-01 13:40:50
  • c# wpf如何使用Blend工具绘制Control样式

    2022-10-26 09:35:25
  • Java中反射动态 代理接口的详解及实例

    2023-11-28 05:29:36
  • Java内存溢出和内存泄露

    2023-01-21 17:48:48
  • Android PopUpWindow使用详解

    2023-06-30 06:33:11
  • Java内存模型与JVM运行时数据区的区别详解

    2023-11-24 13:29:08
  • 分享一个C#编写简单的聊天程序(详细介绍)

    2023-06-19 03:21:59
  • JSON中optString和getString方法的区别

    2021-09-06 03:46:14
  • Idea自动生成Entity实现过程详解

    2022-06-03 12:18:24
  • C++二分查找算法实例

    2021-09-07 20:40:05
  • android手机获取gps和基站的经纬度地址实现代码

    2022-04-05 03:03:00
  • C#画笔Pen绘制光滑模式曲线的方法

    2021-11-26 05:13:33
  • Spring security登录过程逻辑详解

    2022-09-04 19:58:20
  • java实现拼图游戏

    2022-09-21 11:14:19
  • Android实现蒙版弹出框效果

    2023-06-14 17:13:43
  • SpringAOP如何获取方法参数上的注解

    2021-09-19 23:22:18
  • servlet上传文件实现代码详解(四)

    2021-09-04 21:17:23
  • asp之家 软件编程 m.aspxhome.com