利用 html5 canvas 简单绘制折线图

<!DOCTYPE html>

<html>
	<head>
		<meta charset='utf-8'>
		<title>画图</title>
		<style>
			#divContainer{
				margin-top: 20px;
				text-align: center;
			}
			#cv{
				width: 300px;
				height: 200px;
				border-bottom: 2px solid #000;
				border-left: 2px solid #000;
			}
		</style>
	</head>
	<body>
		<div id="divContainer">
			铝锭价走势图<br/>
			<canvas id="cv">你的设备不支持图表数据显示</canvas>
		</div>

		<script>
			(function(){
				window.onload = function(){

					//数据源
					var dict = [
						{x: "2015-04-24", y: 13400},
						{x: "2015-04-25", y: 13380},
						{x: "2015-04-26", y: 13370},
						{x: "2015-04-27", y: 13370},
						{x: "2015-04-28", y: 13380}
					]

					//数据源提取
					var len = dict.length;
					var xArr = [], yArr = [], tmp_yArr = [];
					for(var i=0; i<len; i++){
						xArr.push(i * 60);
						tmp_yArr.push(dict[i].y);
					}
					var tmp_minY = Math.min.apply(Math, tmp_yArr);//最小值
					var tmp_maxY = Math.max.apply(Math, tmp_yArr);//最大值
					if(tmp_maxY - tmp_minY <= 100){
						for(var i=0; i<len; i++){
							yArr.push(tmp_yArr[i] - tmp_minY + 50);//与最小的做比较
						}
					}
					else{//如果相差太大会导致图表不美观
						for(var i=0; i<len; i++){
							yArr.push(tmp_yArr[i] / 500);
						}
					}
					var minY = Math.min.apply(Math, yArr);
					var maxY = Math.max.apply(Math, yArr);

					//canvas 准备
					var canvas = document.getElementById("cv");//获取canvas画布
					var ctx  = canvas.getContext("2d");

					//画折线
					for(var i=0 ;i<len; i++){
						var x = xArr[i];
						var y = maxY - yArr[i] + minY;
						if(i === 0){
							ctx .moveTo(x, y);
						}
						else{
							ctx .lineTo(x, y);
						}
					}
					ctx .stroke();

					//画点
					for(var i=0; i<len; i++){
						var x = xArr[i];
						var y = maxY - yArr[i] + minY;
						var xMemo = dict[i].x;
						var yMemo = "¥" + dict[i].y;
						ctx.beginPath();
						ctx.fillStyle = "#000";
						ctx.arc(x, y, 2, 0, 2*Math.PI);//画点
						ctx.fill();
					 	ctx.fillText(yMemo, x + 3, y - 10);
					 	ctx.fillText(xMemo, x + 3, canvas.height - 10, 40);//画文字
					}

				}
			})();
		</script>
	</body>
</html>

  • 8
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要在 Android 上绘制折线图,可以使用 Canvas 和 Paint 类来实现。 首先,你需要创建一个自定义 View 组件,并在其 onDraw() 方法中实现绘图逻辑。在绘制折线图时,你需要先计算出每个数据点的坐标,然后使用 Path 类绘制连接这些点的线条。 下面是一个简单的示例代码,实现了一个基本的折线图绘制: ```java public class LineChartView extends View { private List<Float> mData = new ArrayList<>(); public LineChartView(Context context) { super(context); } public LineChartView(Context context, AttributeSet attrs) { super(context, attrs); } public LineChartView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); } public void setData(List<Float> data) { mData = data; invalidate(); // 通知 View 进行重新绘制 } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); // 设置笔颜色和样式 Paint paint = new Paint(); paint.setColor(Color.BLUE); paint.setStyle(Paint.Style.STROKE); paint.setStrokeWidth(5); // 计算每个数据点的坐标 int width = getWidth(); int height = getHeight(); float xInterval = width / (mData.size() - 1); float yInterval = height / Collections.max(mData); Path path = new Path(); for (int i = 0; i < mData.size(); i++) { float x = i * xInterval; float y = height - mData.get(i) * yInterval; if (i == 0) { path.moveTo(x, y); } else { path.lineTo(x, y); } } // 绘制折线图 canvas.drawPath(path, paint); } } ``` 在 Activity 中,你可以通过调用 setData() 方法来设置折线图的数据,并将自定义 View 组件添加到布局中: ```java List<Float> data = new ArrayList<>(); data.add(10f); data.add(20f); data.add(50f); data.add(30f); data.add(40f); LineChartView lineChartView = new LineChartView(this); lineChartView.setData(data); LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams( LinearLayout.LayoutParams.MATCH_PARENT, LinearLayout.LayoutParams.MATCH_PARENT); linearLayout.addView(lineChartView, layoutParams); ``` 上述代码会在 LinearLayout 中添加一个折线图,其中数据为 [10, 20, 50, 30, 40]。你可以根据自己的需求来修改上述代码,实现更加复杂的折线图绘制

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值