自定义View,绘制图文混合

package com.example.user.demopine;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Rect;
import android.graphics.RectF;
import android.support.annotation.Nullable;
import android.util.AttributeSet;

/**
 * @author ${pym}
 * @creatDate 2017/9/6 15:47
 * @description ${description}
 * @updateAuthor ${Author}
 * @updateDate$ 2017/9/6 15:47
 */

public class View extends android.view.View {
    private int w;
    private int h;

    public View(Context context) {
        super(context);
    }

    public View(Context context, @Nullable AttributeSet attrs) {
        super(context, attrs);
    }

    public View(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }

    public View(Context context, @Nullable AttributeSet attrs, int defStyleAttr, int defStyleRes) {
        super(context, attrs, defStyleAttr, defStyleRes);
    }

    public View(Context context, int w, int h) {
        super(context);
        this.w = w;
        this.h = h;
    }

    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        super.onMeasure(widthMeasureSpec, heightMeasureSpec);
    }

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        String text = "测试";
        Paint pain = new Paint();
        pain.setAntiAlias(true);
        pain.setColor(Color.RED);
        pain.setStyle(Paint.Style.STROKE);
        pain.setStrokeWidth(2);
        float radius = Math.min(w, h) / 2;
        Rect rect = new Rect(w, h, h, h);
        canvas.drawCircle(rect.centerX(), rect.centerY(), radius, pain);

        RectF rectF = new RectF(w/2, h/2, w+(w/2), h+(h/2));
        pain.setColor(Color.RED);
        pain.setStyle(Paint.Style.FILL_AND_STROKE);
        canvas.drawArc(rectF, 0, 180, false, pain);

        pain.setStyle(Paint.Style.FILL_AND_STROKE);
        pain.setTextSize(28);
        pain.setStrokeWidth(0);
        canvas.drawText(text, rect.centerX() - 20, rect.centerY() - 20, pain);
        pain.setColor(Color.WHITE);
        pain.setStrokeWidth(5);
        canvas.drawLine(rect.centerX(), rect.centerY() + 25, rect.centerX(), rect.centerX() + 75, pain);
        canvas.drawLine(rect.centerX() - 25, rect.centerX() + 50, rect.centerX() + 25, rect.centerY() + 50, pain);
    }

}


package com.example.user.demopine;

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.widget.LinearLayout;


public class MainActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        LinearLayout ll1 = (LinearLayout) findViewById(R.id.ll);
        LinearLayout ll2 = (LinearLayout) findViewById(R.id.ll2);
        View view2 = new View(this, 800, 800);
        ll2.addView(view2);

    }
}
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

GodCodeApps

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值