欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

Android UI效果之绘图篇(四)

程序员文章站 2024-02-22 14:33:46
上一篇博文说到了shader的五个子类 - bitmapshader - lineargradient - radialgradient - sweepgr...

上一篇博文说到了shader的五个子类
- bitmapshader
- lineargradient
- radialgradient
- sweepgradient
- composeshader
其中bitmapshader和lineargradient已经做了说明,今天就把剩余的三个shader补充一下
3. radialgradient
先看下构造方法

 /**
   @param centerx   中心x坐标
   @param centery   中心y坐标
   @param radius   半径
   @param centercolor 开始颜色
   @param edgecolor  结束颜色
   @param tilemode  the shader tiling mode
   */
  public radialgradient(float centerx, float centery, float radius,int centercolor, int edgecolor, @nonnull tilemode tilemode)


 public radialgradient(float centerx, float centery, float radius,@nonnull int colors[], @nullable float stops[], @nonnull tilemode tilemode)

第一个构造方法已经进行了文档说明,比较简单,而第二个构造方法和lineargradient同理,就不再赘述,使用方法也基本类似,这里直接看下效果即可

radialgradient rg = new radialgradient(canvas.getwidth()/2, canvas.getheight()/2, 200, 0xffff0000, 0xff0000ff, shader.tilemode.[clamp|repeat |mirror]);
    paint.setshader(rg);
    canvas.drawrect(0, 0, canvas.getwidth(), canvas.getheight(), paint);

① clamp

Android UI效果之绘图篇(四)

② repeat

Android UI效果之绘图篇(四)

③ mirror

Android UI效果之绘图篇(四)

1、sweepgradient

/**
  *
  * @param cx  中心x坐标
  * @param cy  中心y坐标
  * @param color0 开始颜色
  * @param color1 结束颜色
  */
 public sweepgradient(float cx, float cy, int color0, int color1)

Android UI效果之绘图篇(四)

第一个构造方法比较简单,没什么好说的,效果的话类似于做煎饼皮,展开选择360度。主要看第二个构造方法

 public sweepgradient(float cx, float cy,int colors[], float positions[])

cx、cy没什么好说的,中心点坐标,colors颜色数组,主要是positions,positions中每个item的取值范围在0f-1f之间,对于colors中相应颜色在图形中的位置

int[] colors = {0xffff0000, 0xff00ff00, 0xffffff00, 0xffffffff,0xff000000};
float[] positions = {0f,0.25f, 0.5f, 0.75f, 1f};
sweepgradient rg = new sweepgradient(canvas.getwidth() / 2, canvas.getheight() / 2, colors, positions);
paint.setshader(rg);
canvas.drawrect(0, 0, canvas.getwidth(), canvas.getheight(), paint);

Android UI效果之绘图篇(四)

composeshader

composeshader(shader shadera, shader shaderb, xfermode mode)
composeshader(shader shadera, shader shaderb, porterduff.mode mode)

composeshader,混合shader,看到构造方法,大家应该就已经会用composeshader,其实就是对两个shader进行取并集交集操作,遗忘了的同学可以翻看下上一篇文章,这里就不再演示了。