水位下降

水位下降_第1张图片


< com.atsgg.customviewdemo09.WaveView
    android : layout_width = "match_parent"
    android:layout_height="match_parent"/>

public class WaveView  extends View {

    private Paint  mPaint; //  画笔对象
    private Path  mPath; //  路径对象

    private int  vWidthvHeight; //  控件宽高
    private float  ctrXctrY; //  控制点的坐标
    private float  waveY; //  整个 Wave 顶部两端点的 Y 坐标,该坐标与控制点的 Y 坐标增减幅一致 , 以及
    private float  startXendX; //  整个 Wave 的左端点 , 与右端点

    private boolean  isInc//  判断控制点是该坐移还是右移 ,true 为右移

    public WaveView(Context context) {
        this(context,  null);
    }

    public WaveView(Context context, AttributeSet attrs) {
        this(context, attrs,  0);
    }

    public WaveView(Context context, AttributeSet attrs,  int defStyleAttr) {
        super(context, attrs, defStyleAttr);

        //  实例化画笔并设置参数
        mPaint new Paint(Paint. ANTI_ALIAS_FLAG | Paint. DITHER_FLAG);
        mPaint.setColor( 0xFF00796B);

        //  实例化路径
        mPath new Path();
    }

    @Override
    protected void onSizeChanged( int w,  int h,  int oldw,  int oldh) {
        //  获取控件的宽高
        vWidth = w;
        vHeight = h;

        //  计算端点 Y 坐标
        waveY 8F vHeight;
        //  计算控制点 Y 的坐标
        ctrY = - 16F vHeight;

        startX = - 4F vWidth;
        endX 4F vWidth vWidth;
    }

    @Override
    protected void onDraw(Canvas canvas) {
        /**
         *  设置 Path 起点
          注意我将 Path 的起点设置在了控件的外部看不到的区域
          如果我们将起点设置在控件左端 x=0 的位置会使得贝塞尔曲线变得生硬
          至于为什么刚才我已经说了
          所以我们稍微让起点往 走点
          */
        mPath.moveTo( startXwaveY);

        /**
         *  以二阶曲线的方式通过控制点连接位于控件右边的终点
          终点的位置也是在控件外部
          我们只需不断让 ctrX 的大小变化即可实现 的效果
          */
        mPath.quadTo( ctrXctrYendXwaveY);
//        mPath.cubicTo(ctrX, ctrY,
//                (vWidth + 1 / 4F * vWidth) / 2, waveY - 1 / 8F * vHeight,
//                vWidth + 1 / 4F * vWidth, waveY);

        //  围绕控件闭合曲线
        mPath.lineTo( endXvHeight);
        mPath.lineTo( startXvHeight);
        mPath.close();

        canvas.drawPath( mPathmPaint);

        /**
         *  当控制点的 x 坐标大于或等于终点 x 坐标时更改标识值
          */
        if ( ctrX >=  endX) {
            isInc false;
        }
        /**
         *  当控制点的 x 坐标小于或等于起点 x 坐标时更改标识值
          */
        else if ( ctrX <=  startX) {
            isInc true;
        }
        //  根据标识值判断当前的控制点 x 坐标是该加还是减
        ctrX isInc ctrX 20 ctrX 20;

        if ( ctrY <=  vHeight) {
            ctrY +=  2;
            waveY +=  2;
        }
        mPath.reset();
        invalidate();
    }
}

你可能感兴趣的:(自定义控件,自定义View)