android 蒙层动画,2018-10-31 Android 仿泡面短视频APP动态显示蒙层效果

public class PatMirrorCoverView extends View {

Paint mPaint;

private Paint mPaintLine;

private float leftX, leftY, rightX, rightY, leftX1, leftY1, rightX1, rightY1;

Path path = new Path();

public PatMirrorCoverView(Context context) {

super(context);

init();

}

/**

* * Desc:

* *

* * Author: [lianyg]

* * Date: 2018-10-31

* *

* * @param context

* * @param attrs

*

*/

public PatMirrorCoverView(Context context, @Nullable AttributeSet attrs) {

super(context, attrs);

init();

}

/**

* * Desc:

* *

* * Author: [lianyg]

* * Date: 2018-10-31

* *

* * @param context

* * @param attrs

* * @param defStyleAttr

*

*/

public PatMirrorCoverView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {

super(context, attrs, defStyleAttr);

init();

}

/**

* * Desc:

* *

* * Author: [lianyg]

* * Date: 2018-10-31

* *

* * @param context

* * @param attrs

* * @param defStyleAttr

* * @param defStyleRes

*

*/

public PatMirrorCoverView(Context context, @Nullable AttributeSet attrs, int defStyleAttr, int defStyleRes) {

super(context, attrs, defStyleAttr, defStyleRes);

init();

}

/**

* Desc:

*

* Author: [lianyg]

* Date: 2018-10-31

*/

public void init() {

mPaintLine = new Paint();

mPaintLine.setStyle(Paint.Style.FILL);

mPaintLine.setColor(Color.RED);

mPaint = new Paint();

mPaint.setAntiAlias(true);

mPaint.setStrokeWidth(1);

mPaint.setColor(getResources().getColor(R.color.pat_color_80000000));

mPaint.setStyle(Paint.Style.FILL);

}

@Override

protected void onDraw(Canvas canvas) {

super.onDraw(canvas);

drawListRect(canvas);

}

/**

* Desc:

*

* Author: [lianyg]

* Date: 2018-10-31

*

* @param leftX

* @param leftY

* @param rightX

* @param rightY

* @param leftX1

* @param leftY1

* @param rightX1

* @param rightY1

* @param isTranslate

*/

public void setRect(float leftX, float leftY, float rightX, float rightY, float leftX1, float leftY1, float rightX1, float rightY1, boolean isTranslate) {

this.leftX = leftX;

this.leftY = leftY;

this.rightX = rightX;

this.rightY = rightY;

this.leftX1 = leftX1;

this.leftY1 = leftY1;

this.rightX1 = rightX1;

this.rightY1 = rightY1;

if (isTranslate) {

mPaint.setColor(Color.parseColor("#00000000"));

invalidate();

} else {

mPaint.setColor(Color.parseColor("#80000000"));

invalidate();

}

}

/**

*

*/

List listRect;

/**

* Desc:

*

* Author: [lianyg]

* Date: 2018-10-31

*

* @param listRect

*/

public void setRect(List listRect) {

this.listRect = listRect;

postInvalidate();

}

/**

* Desc:绘制不规则矩形

*

* Author: [lianyg]

* Date: 2018-10-31

*/

private void drawListRect(Canvas canvas) {

for (int i = 0; i < listRect.size(); i++) {

PatMirrorCoverBean patMirrorCoverBean = listRect.get(i);

if (patMirrorCoverBean.isTranslate()) {

mPaint.setColor(getResources().getColor(R.color.pat_color_effect_no));

} else {

mPaint.setColor(getResources().getColor(R.color.color_80000000));

}

float[] rect = patMirrorCoverBean.getRect();

path.reset();//这里必须要reset。否则会出现每次渲染后颜色都是第一次初始化的数据

path.moveTo(rect[0], rect[1]);

path.lineTo(rect[2], rect[3]);

path.lineTo(rect[6], rect[7]);

path.lineTo(rect[4], rect[5]);

path.close();

canvas.drawPath(path, mPaint);

}

}

}

当前绘制效果比较简单。app内部效果,是点击按钮的时候动态绘制指定坐标显示对应的区域,目前是可以显示不规则的四边形,如果需要修改其他形状,可以直接在drawListRect函数进行path.lineTo的添加等,需要记住的是path.lineTo的顺序执行。

使用方法直接,调用setRect(List);

public class PatMirrorCoverBean implements Serializable {

private float[] rect; //坐标系

public float[] getRect() {

return rect;

}

public void setRect(float[] rect) {

this.rect = rect;

}

public boolean isTranslate() {

return isTranslate;

}

public void setTranslate(boolean translate) {

isTranslate = translate;

}

private boolean isTranslate;//颜色是否透明

}

好了。有啥问题可以直接留意与我沟通

487eaed39c7b

611540954723_.pic.jpg

487eaed39c7b

621540954724_.pic.jpg

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值