实例介绍
【实例简介】这实现了一个折线统计图 的简单统计数据
【实例截图】
【实例截图】
【核心代码】
package com.example.draw; import android.content.Context; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import android.graphics.Paint.Align; import android.graphics.Paint.Cap; import android.graphics.PointF; import android.graphics.Typeface; import android.util.AttributeSet; import android.view.View; public class DrawImg extends View { public DrawImg(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); } public DrawImg(Context context, AttributeSet attrs) { super(context, attrs); } public DrawImg(Context context) { super(context); } // 绘制文本 private void drawTxtView(Canvas canvas,String drawTxt) { Paint txtPaint = new Paint(); txtPaint.setColor(Color.BLUE); // 设置文本位置 txtPaint.setTextAlign(Align.LEFT); // 设置文本大小 txtPaint.setTextSize(38); // 设置画笔的锯齿效果 true表示无锯齿 false 反之 txtPaint.setAntiAlias(true); txtPaint.setTypeface(Typeface.MONOSPACE); // 当然也可以设置为"实心"(Paint.Style.FILL), "空心"(Paint.Style.STROKE) // txtPaint.setStyle(Paint.Style.STROKE); // 设置“空心”的外框的宽度 // txtPaint.setStrokeWidth(5); // x默认是drawTxt这个字符的左边在屏幕的位置,如果设置了setTextAlign(Paint.Align.CENTER);那就是字符的中心,y是指定这个字符baseline在屏幕上的位置。 canvas.drawText(drawTxt, 16, 80, txtPaint); } private void drawCircleView(Canvas canvas,float cx,float xy,boolean isSx,int color) { Paint circlePaint = new Paint(); circlePaint.setColor(color); if (isSx) { circlePaint.setStyle(Paint.Style.FILL); }else { circlePaint.setStyle(Paint.Style.STROKE); } // circlePaint.setStrokeCap(Cap.ROUND); /** * 画点 : 参数介绍 * 1.起始端点的X坐标。 * 2.起始端点的Y坐标。 * 3.点直径。 * 5.绘制直线所使用的画笔。 */ canvas.drawCircle(cx, xy, 10, circlePaint); } // 绘制线段 private void drawSlash(Canvas canvas,float startX,float startY,float stopX,float stopY) { Paint paint = new Paint(); paint.setColor(Color.GRAY); // 设置线宽 paint.setStrokeWidth(5f); /** * 画线 : 参数介绍 * 1.起始端点的X坐标。 * 2.起始端点的Y坐标。 * 3.终止端点的X坐标。 * 4.终止端点的Y坐标。 * 5.绘制直线所使用的画笔。 */ canvas.drawLine(startX, startY, stopX, stopY, paint); } private void drawText(Canvas canvas,String str,float x,float y) { Paint paint = new Paint(); paint.setColor(Color.DKGRAY); paint.setTextSize(28); /** * 画文本 : 参数介绍 * 1.文本X坐标假指长度 * 2.文本Y坐标假指高度 * 3.绘制直线所使用的画笔。 */ canvas.drawText(str, x, y, paint); } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); drawTxtView(canvas, "黄兴路步行街商圈"); drawCircleView(canvas,100,210, true,Color.CYAN); drawSlash(canvas,107,215,230,260); drawCircleView(canvas,230,260, true,Color.BLUE); drawSlash(canvas,238,260,420,170); drawCircleView(canvas,420,170, true,Color.GREEN); drawSlash(canvas,427,170,610,210); drawCircleView(canvas,610,210, true,Color.RED); drawSlash(canvas,50,290,680,290); drawText(canvas, "10km/h", 50, 180); drawText(canvas, "人民路", 50, 330); drawText(canvas, "5km/h", 200, 220); drawText(canvas, "蔡锷路", 180, 330); drawText(canvas, "40km/h", 370, 140); drawText(canvas, "沿江路", 370, 330); drawText(canvas, "35km/h", 570, 170); drawText(canvas, "五一路", 570, 330); } }
好例子网口号:伸出你的我的手 — 分享!
小贴士
感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。
- 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
- 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
- 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
- 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
关于好例子网
本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明
网友评论
我要评论