Android用Canvas画一个折线图,并加以简单封装,移动终端开发课设

本文介绍如何在Android中使用Canvas绘制一个折线图,并进行简单封装。通过设置坐标轴、绘制折线和点,实现了动态数据的折线图展示。还提供了对外的数据输入方法,可以方便地根据数据更新图表。
摘要由CSDN通过智能技术生成

}

private void drawAxispoint(Canvas canvas,Paint p){

textFont=widthCriterion/5*2;

Typeface font = Typeface.create(Typeface.SANS_SERIF, Typeface.BOLD);

p.setTypeface( font );

p.setTextSize(textFont);

for (int i = 1; i <=8 ; i++) {

String text= String.valueOf(-1+i);

int stringWidth = (int) p.measureText(text); //文本长度

canvas.drawText(text, iwidthCriterion-stringWidth/2, hightCriterion9+textFont, p);// 画文本

}

for (int i = 1; i <=7 ; i++) {

String text= String.valueOf(i);

int stringWidth = (int) p.measureText(text);

//文本长度

canvas.drawText(text, widthCriterion-textFont, hightCriterion9-ihightCriterion+stringWidth/2, p);// 画文本

}

}

private void drawbrokenLine(Canvas canvas,Paint p){

canvas.drawLine(widthCriterion,hightCriterion9,widthCriterion2,hightCriterion*2,p);

canvas.drawLine(widthCriterion2,hightCriterion2,widthCriterion3,hightCriterion5,p);

canvas.drawLine(widthCriterion3,hightCriterion5,widthCriterion4,hightCriterion7,p);

canvas.drawLine(widthCriterion4,hightCriterion7,widthCriterion5,hightCriterion6,p);

canvas.drawLine(widthCriterion5,hightCriterion6,widthCriterion6,hightCriterion7,p);

canvas.drawLine(widthCriterion6,hightCriterion7,widthCriterion7,hightCriterion2,p);

canvas.drawLine(widthCriterion7,hightCriterion2,widthCriterion8,hightCriterion3,p);

//画折线上的点

canvas.drawCircle(widthCriterion, hightCriterion*9, 10, p);

canvas.drawCircle(widthCriterion2,hightCriterion2, 10, p);

canvas.drawCircle(widthCriterion3,hightCriterion5, 10, p);

canvas.drawCircle(widthCriterion4,hightCriterion7, 10, p);

canvas.drawCircle(widthCriterion5,hightCriterion6, 10, p);

canvas.drawCircle(widthCriterion6,hightCriterion7, 10, p);

canvas.drawCircle(widthCriterion7,hightCriterion2, 10, p);

canvas.drawCircle(widthCriterion8,hightCriterion3, 10, p);

}

}

下面来简单封装一下


1.首先提供给外界输入数据的方法:

public void setChartdate(String[] xdate, int[] ydate, float[] linedate) {

this.xdate = xdate; //x轴坐标

this.ydate = ydate; //y轴坐标

this.linedate = linedate; //坐标点的y轴上的位置

}

2.进行数据为空判断和越界判断

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值