博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【转】Android进阶2之 阴影制作(Shadow)
阅读量:4664 次
发布时间:2019-06-09

本文共 2087 字,大约阅读时间需要 6 分钟。

阴影制作:包括各种形状(矩形,圆形等等),以及文字等等都能设置阴影。

阴影制作是什么原理呢?

其实很简单,你需要设置阴影的东西被看作一个主层。然后在主层下面画一个阴影层。

阴影制作涉及到一个重要函数:

public   void   setShadowLayer (float radius, float dx, float dy, int color)

radius:阴影半径

dx:X轴方向的偏移量

dy:Y轴方向的偏移量

color:阴影颜色

 
注意:如果半径被设置为0,意思就是去掉阴影。
 
具体实现:
package xiaosi.textShadow;import android.app.Activity;import android.content.Context;import android.graphics.Bitmap;import android.graphics.BitmapFactory;import android.graphics.Canvas;import android.graphics.Color;import android.graphics.Paint;import android.os.Bundle;import android.view.View;public class TextShadowActivity extends Activity{    @Override    public void onCreate(Bundle savedInstanceState)    {        super.onCreate(savedInstanceState);        setContentView(new drawCanvas(this));    }    class drawCanvas extends View    {        private Bitmap  bitmap = null;        public drawCanvas(Context context)        {            super(context);            bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.i_skinprocess);        }        @Override        protected void onDraw(Canvas canvas)        {            super.onDraw(canvas);            // 建立Paint 物件            Paint paint1 = new Paint();            // 设定颜色            paint1.setColor(0xFFFFFF00);            // 设定阴影(柔边, X 轴位移, Y 轴位移, 阴影颜色)            paint1.setShadowLayer(5, 3, 3, 0xFFFF00FF);            // 实心矩形& 其阴影            canvas.drawText("我很爱你", 20,40,paint1);            Paint paint2 = new Paint();            paint2.setColor(Color.GREEN);            paint2.setShadowLayer(10, 5, 2, Color.YELLOW);            canvas.drawText("你真傻", 20,60,paint2);                        Paint paint3 = new Paint();            paint3.setColor(Color.RED);            paint3.setShadowLayer(30, 5, 2, Color.GREEN);            canvas.drawCircle(50, 130,30, paint3);                        Paint paint4 = new Paint();            paint4.setShadowLayer(5, 8, 7, Color.DKGRAY);            canvas.drawBitmap(bitmap, 50, 200, paint4);        }    }}

 

原文:http://blog.csdn.net/sjf0115/article/details/7363958

转载于:https://www.cnblogs.com/butterfly-clover/p/5480837.html

你可能感兴趣的文章
SOCKET.IO 前后端使用
查看>>
CodeForces 122G Lucky Array(一脸懵逼的树状数组)
查看>>
【开发实例】C#调用SAPI实现语音合成的两种方法
查看>>
Django实战(15):Django实现RESTful web service
查看>>
离散实验二
查看>>
使用sharepoint里Open with explorer功能
查看>>
通过模糊来弱化背景
查看>>
The Fourth Day
查看>>
NSString 比较(转)
查看>>
[hdu3631]背包或中途相遇法
查看>>
模块化开发(seajs)
查看>>
HDU1848 Fibonacci again and again 博弈 SG函数
查看>>
iOS-自建iPa应用分发平台
查看>>
12月2日站立会议
查看>>
【转载】详解 $_SERVER 函数中QUERY_STRING和REQUEST_URI区别
查看>>
DBA笔记oracle undo_retention参数可动态修改
查看>>
123我爱你
查看>>
HDU 4033 Regular Polygon(几何 + 二分)
查看>>
webgl example1
查看>>
Django基础内容整理
查看>>