Android AllView使用效果

package com.android.xiong.gridlayoutTest.customeview;


import com.android.xiong.gridlayoutTest.R;


import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.LinearGradient;
import android.graphics.Paint;
import android.graphics.Path;
import android.graphics.RectF;
import android.graphics.Shader;
import android.util.AttributeSet;
import android.view.View;


public class AllView extends View {


public AllView(Context context) {
super(context);
// TODO Auto-generated constructor stub
}
@Override
//重写该方法进行绘图
protected void onDraw(Canvas canvas) {
// TODO Auto-generated method stub
super.onDraw(canvas);
//将整张画布绘制成白色
canvas.drawColor(Color.WHITE);
Paint paint=new Paint();
//去锯齿
paint.setAntiAlias(true);
paint.setColor(Color.BLUE);
paint.setStyle(Paint.Style.STROKE);
paint.setStrokeWidth(4);
int viewWidth=this.getWidth();
//绘制圆形
canvas.drawCircle(viewWidth/10+10,viewWidth/10+10 , viewWidth/10, paint);
//绘制正方形
canvas.drawRect(10, viewWidth/5+20, viewWidth/5+20, viewWidth*2/5+20, paint);
//绘制矩形s
canvas.drawRect(10, viewWidth*2/5+30, viewWidth/5+10, viewWidth/2+30, paint);
RectF rect=new RectF(10, viewWidth/2+40, 10+viewWidth/5, viewWidth*3/5+40);
//绘制圆角矩形
canvas.drawRoundRect(rect, 15, 15, paint);
RectF rect1=new RectF(10, viewWidth*3/5+50,10+viewWidth/5, viewWidth*7/10+50);
//绘制椭圆
canvas.drawOval(rect1, paint);
//定一个path对象,封闭成一个三角形
Path p=new Path();
p.moveTo(10, viewWidth*9/10+60);
p.lineTo(viewWidth/5+10, viewWidth*9/10+60);
p.lineTo(viewWidth/10+10, viewWidth*7/10+60);
p.close();
//根据path进行绘制三角形s
canvas.drawPath(p, paint);
//定义一个path对象,封闭成一个五角形
Path p2=new Path();
p2.moveTo(10+viewWidth/15, viewWidth*9/10+70);
p2.lineTo(10+viewWidth*2/15, viewWidth*9/10+70);
p2.lineTo(10+viewWidth/5, viewWidth+70);
p2.lineTo(10+viewWidth/10, viewWidth*11/10+70);
p2.lineTo(10+viewWidth/10, viewWidth+70);
p2.close();
//根据path进行绘制五角形
canvas.drawPath(p2, paint);
paint.setStyle(Paint.Style.FILL);
paint.setColor(Color.RED);
//绘制圆形
canvas.drawCircle(viewWidth*3/10+20, viewWidth/10+10, viewWidth/10, paint);
//绘制正方形
canvas.drawRect(viewWidth/5+20, viewWidth/5+20, viewWidth*2/5+20, viewWidth/2+30, paint);
//绘制矩形
canvas.drawRect(viewWidth/5+20, viewWidth*2/5+30, viewWidth*2/5+20, viewWidth/2+30, paint);
RectF re2=new RectF(viewWidth/5+20, viewWidth/2+40, 20+viewWidth*2/5, viewWidth*3/5+40);
//绘制圆角矩形
canvas.drawRoundRect(rect1, 15, 15, paint);
RectF re21=new RectF(20+viewWidth/5, viewWidth*3/5+50, 20+viewWidth*2/5, viewWidth*7/10+50);
canvas.drawOval(re21, paint);
//定义以后各path封闭成三角形

Path p3=new Path();
p3.moveTo(20+viewWidth/5, viewWidth*9/10+60);
p3.lineTo(20+viewWidth*2/5+20, viewWidth*9/10+60);
p3.lineTo(20+viewWidth*3/10+20, viewWidth*7/10+60);
p3.close();

Path p4=new Path();
p4.moveTo(20+viewWidth*4/15, viewWidth*9/10+70);
p4.lineTo(20+viewWidth/3, viewWidth*9/10+70);
p4.lineTo(20+viewWidth*2/5, viewWidth+70);
p4.lineTo(20+viewWidth*3/10, viewWidth*11/10+70);
p4.lineTo(20+viewWidth/5, viewWidth+70);
p4.close();
canvas.drawPath(p4, paint);
//设置Paint渐变器
Shader shader=new LinearGradient(0, 0, 40, 60, new int[] {Color.RED,Color.GREEN,Color.BLUE,Color.YELLOW}, null, Shader.TileMode.REPEAT);
//设置阴影
paint.setShader(shader);
paint.setShadowLayer(25, 20,20, Color.GRAY);
canvas.drawCircle(viewWidth/2+30, viewWidth/10+10, viewWidth/10, paint);
//绘制正方形
canvas.drawRect(viewWidth*2/5+30, viewWidth/5+20, viewWidth*3/5+20, viewWidth*2/5+20, paint);
//绘制矩形
canvas.drawRect(viewWidth*2/5+30, viewWidth*2/5+30, viewWidth*3/5+30, viewWidth/2+30, paint);
//绘制圆角矩形
RectF rel3=new RectF(viewWidth*2/5+30, viewWidth/2+40, 30+viewWidth*3/5, viewWidth*3/5+40);
canvas.drawRoundRect(rect1, 15, 15, paint);
RectF rel32=new RectF(30+viewWidth*2/5, viewWidth*3/5+50, viewWidth*3/5+30, viewWidth*7/10+50);
//绘制椭圆
canvas.drawOval(rel32, paint);
//定一个对象封闭成三角形
Path p5=new Path();
p5.moveTo(20+viewWidth*4/15, viewWidth*9/10+70);
p5.lineTo(20+viewWidth/3, viewWidth*9/10+70);
p5.lineTo(20+viewWidth*2/5, viewWidth+70);
p5.lineTo(20+viewWidth*3/10, viewWidth*11/10+70);
p5.lineTo(20+viewWidth/5, viewWidth+70);
p5.close();
canvas.drawPath(p5, paint);

Path p6=new Path();
p6.moveTo(20+viewWidth*4/15, viewWidth*9/10+70);
p6.lineTo(20+viewWidth/3, viewWidth*9/10+70);
p6.lineTo(20+viewWidth*2/5, viewWidth+70);
p6.lineTo(20+viewWidth*3/10, viewWidth*11/10+70);
p6.lineTo(20+viewWidth/5, viewWidth+70);
p6.close();
canvas.drawPath(p6, paint);
paint.setTextSize(48);
paint.setShader(null);
//绘制七个字符串
canvas.drawText(getResources().getString(R.string.circel), 60+viewWidth*3/5, viewWidth/10+10, paint);
canvas.drawText(getResources().getString(R.string.square), 60+viewWidth*3/5, viewWidth*3/10+20, paint);
canvas.drawText(getResources().getString(R.string.rect), 60+viewWidth*3/5, viewWidth*1/2+20, paint);
canvas.drawText(getResources().getString(R.string.round_rect), 60+viewWidth*3/5, viewWidth*3/5+20, paint);
canvas.drawText(getResources().getString(R.string.oval), 60+viewWidth*3/5, viewWidth*7/10+30, paint);
canvas.drawText(getResources().getString(R.string.triangle), 60+viewWidth*3/5, viewWidth*9/10+30, paint);
canvas.drawText(getResources().getString(R.string.pentagon), 60+viewWidth*3/5, viewWidth*11/10+30, paint);


}

Activity中

@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(new AllView(this));

                //加载view


}

}

运行效果如下图所示


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值