1.效果
2.思想
2.1.雪花生成 初始化
从y=0,生成随机r半径 r=(5到10随机) ,x轴随机 x=屏幕宽度*随机比例,y轴随机下滑距离speet=(0.1到2随机 )
2.2.雪花下滑
每次y轴+=speet滑动距离
2.3雪花复用
每次下滑的时候判断当前y轴+speet滑动距离+R直径如果大于屏幕的高度 ,那么y=0 然后重新生成速度 半径 x轴
3.代码实现
//绘制雪花效果
public class XueHua extends View {
public Paint paint;
public DisplayMetrics displayMetrics;
public XueHua(Context context) {
this(context,null);
}
public XueHua(Context context, @Nullable AttributeSet attrs) {
this(context, attrs,0);
displayMetrics = context.getResources().getDisplayMetrics();
init();
}
public XueHua(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
Timer timer;
@SuppressLint("ResourceAsColor")
public void init(){
paint = new Paint();
paint.setAntiAlias(true);
timer = new Timer();
timer.schedule(new TimerTask() {
@Override
public void run() {
postInvalidate();//在子线程中执行 postInvalidate()会使onDrow()方法得到执行
}
}, 300, 10);
for (int i = 0; i <400 ; i++) {
XueHuaPoin xueHuaPoin = new XueHuaPoin();
//点的位置
xueHuaPoin.setX(random.nextFloat()*displayMetrics.widthPixels);
xueHuaPoin.setY(random.nextFloat()*displayMetrics.heightPixels);
xueHuaPoin.setSpeet(random.nextFloat());
//圆的半径
xueHuaPoin.setRadius(random.nextInt(5)+5);
list.add(xueHuaPoin);
}
}
@SuppressLint("NewApi")
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
aaa();
list.forEach((element)->{
canvas.drawCircle(element.getX(),element.getY(),element.getRadius(),paint);
});
}
List<XueHuaPoin> list =new ArrayList<>();
Random random = new Random();
public void aaa(){
for (int i = 0; i <list.size() ; i++) {
//判断是否超出屏幕高度
if(list.get(i).getY()+10<displayMetrics.heightPixels){
list.get(i).setY(list.get(i).getY()+(2*list.get(i).getSpeet()));
}else list.get(i).setY(0);//超出高度 我这没有写重新计算半径和y轴
}
}
public void dis(){
timer.cancel();
}
}