先声明,这是我跟着网上的代码敲的,不是自己写的,这是他的博客
学习自定义view,先跟着别人的脚步,学会了自己在尝试!
1.美食卷
package com.zcf.writingboardview;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.util.AttributeSet;
import android.widget.LinearLayout;
/**
* 美食卷
* Created by zcf on 2016/5/24.
*/
public class CouponDisplayView extends LinearLayout {
private float gap = 8f;//圆间距
private int circleNum;//圆的个数
private float radius = 10f;//半径
private float remainLength;//遗留长度
private Paint mPaint;
public CouponDisplayView(Context context) {
super(context);
init();
}
public CouponDisplayView(Context context, AttributeSet attrs) {
super(context, attrs);
init();
}
public CouponDisplayView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
init();
}
private void init() {
mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
mPaint.setStyle(Paint.Style.FILL);
mPaint.setColor(Color.WHITE);
mPaint.setDither(true);
}
@Override
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
super.onSizeChanged(w, h, oldw, oldh);
remainLength = (w - gap) % (2 * radius + gap);
circleNum = (int) ((w - gap) / (2 * radius + gap));
}
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
for (int i = 0; i < circleNum; i++) {
float x = (gap + remainLength / 2 + radius + (2 * radius + gap) * i);
canvas.drawCircle(x, 0, radius, mPaint);
canvas.drawCircle(x, getHeight(), radius, mPaint);
}
}
}
2.简易滑板