前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SurfaceView实现红包雨平移动画

SurfaceView实现红包雨平移动画

作者头像
砸漏
发布2020-11-05 10:03:38
8300
发布2020-11-05 10:03:38
举报
文章被收录于专栏:恩蓝脚本恩蓝脚本

使用SurfaceView实现简单的红包雨动画,供大家参考,具体内容如下

具体代码:SurfaceViewDemo

代码语言:javascript
复制
public class TranslateSurfaceView extends SurfaceView implements DrawInterface {
private DrawHandler drawHandler;
private int width;
private int height;
private Bitmap bitmap;
private int bitmapWidth;
private int bitmapHeight;
private Toast toast;
private int count = 0;
private ArrayList<MoveModel  moveList = new ArrayList< ();
public TranslateSurfaceView(Context context) {
this(context, null);
}
public TranslateSurfaceView(Context context, AttributeSet attrs) {
this(context, attrs, -1);
}
public TranslateSurfaceView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
init();
}
private void init() {
SurfaceHolder holder = getHolder();
setZOrderOnTop(true);
holder.setFormat(PixelFormat.TRANSLUCENT);
}
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
width = getMeasuredWidth();
height = getMeasuredHeight();
}
public void prepare() {
DrawThread drawThread = new DrawThread();
drawThread.start();
drawHandler = new DrawHandler(drawThread.getLooper(), this);
bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.icon_redenvelope2);
bitmapWidth = bitmap.getWidth();
bitmapHeight = bitmap.getHeight();
}
public void addMoveModel(MoveModel moveModel) {
moveList.add(moveModel);
}
public void start() {
count = 0;
moveList.clear();
for (int i = 0; i < 10; i++) {
generateModel();
}
drawHandler.sendEmptyMessage(DrawHandler.START_DRAW_KEY);
}
public void resume() {
drawHandler.sendEmptyMessage(DrawHandler.START_DRAW_KEY);
}
public void pause() {
drawHandler.sendEmptyMessage(DrawHandler.STOP_DRAW_KEY);
}
public void quit() {
if (null != bitmap) {
bitmap.recycle();
}
if (null != drawHandler) {
drawHandler.removeCallbacksAndMessages(null);
drawHandler.getLooper().quit();
}
}
@Override
public void startDraw() {
SurfaceHolder holder = getHolder();
Canvas canvas = holder.lockCanvas();
if (null == canvas) {
return;
}
Paint paint = new Paint();
paint.setAntiAlias(true);
canvas.drawColor(Color.TRANSPARENT, PorterDuff.Mode.CLEAR);
for (MoveModel moveModel : moveList) {
canvas.drawBitmap(bitmap, moveModel.x, moveModel.y, paint);
if (moveModel.x   width || moveModel.y   height) {
resetMoveModel(moveModel);
} else {
moveModel.y += moveModel.randomY;
}
}
holder.unlockCanvasAndPost(canvas);
drawHandler.sendEmptyMessage(DrawHandler.START_DRAW_KEY);
}
@Override
public void stopDraw() {
drawHandler.removeMessages(DrawHandler.START_DRAW_KEY);
}
@Override
public boolean onTouchEvent(MotionEvent event) {
int action = event.getActionMasked();
switch (action) {
case MotionEvent.ACTION_DOWN:
checkInRect((int) event.getX(), (int) event.getY());
break;
}
return true;
}
/**
* 是否点击在红包区域
* @param x
* @param y
*/
private void checkInRect(int x, int y) {
int length = moveList.size();
for (int i = 0; i < length; i++) {
MoveModel moveModel = moveList.get(i);
Rect rect = new Rect((int) moveModel.x, (int) moveModel.y, (int) moveModel.x + bitmapWidth, (int) moveModel.y + bitmapHeight);
if (rect.contains(x, y)) {
count++;
resetMoveModel(moveModel);
if (toast == null) {
toast = Toast.makeText(getContext(), "", Toast.LENGTH_SHORT);
}
toast.setText("抢到红包" + count);
toast.show();
break;
}
}
}
private void resetMoveModel(MoveModel moveModel) {
Random random = new Random();
moveModel.x = random.nextInt(11) * (width / 10);
moveModel.y = 0;
moveModel.randomY = (random.nextInt(5) + 2) * getResources().getDisplayMetrics().density * 1.4f;
}
private void generateModel() {
Random random = new Random();
MoveModel moveModel = new MoveModel();
moveModel.moveId = moveList.size() + 1;
moveModel.x = random.nextInt(11) * (width / 10);
moveModel.y = 0;
moveModel.randomY = (random.nextInt(5) + 2) * getResources().getDisplayMetrics().density * 1.4f;
moveList.add(moveModel);
}
}

以上就是本文的全部内容,希望对大家的学习有所帮助。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档