使用canvas来绘制折线图

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>坐标点进行连线</title>
    <style>
        canvas{
            border: 1px solid red;
        }
    </style>
</head>
<body>
    <!-- 将今天绘制的坐标点进行连线 -->
    <canvas width="600" height="400" id="canvas"></canvas>
</body>
<script>
    var canvas = document.getElementById('canvas');
    var ctx = canvas.getContext('2d');
    var padding = 30;
    var arrowHeight = 20,
        arrowWidth = 10;
    var x0 = padding,
        y0 = canvas.height - padding;
    var maxX = canvas.width - padding*2 -arrowHeight,
        maxY = canvas.height - padding*2 - arrowHeight;
    //绘制坐标轴
    //X轴
    ctx.moveTo(x0,y0);
    ctx.lineTo(x0,y0 - maxY-arrowHeight);
    //Y轴
    ctx.moveTo(x0,y0);
    ctx.lineTo(x0 + maxX +arrowHeight,y0);
    ctx.stroke();
    //绘制箭头
    //X轴
    ctx.beginPath();
    ctx.moveTo(x0+maxX+arrowHeight,y0);
    ctx.lineTo(x0+maxX,y0-arrowWidth*0.5);
    ctx.lineTo(x0+maxX+arrowHeight*0.5,y0);
    ctx.lineTo(x0+maxX,y0+arrowWidth*0.5);
    //Y轴
    ctx.moveTo(x0,y0-maxY-arrowHeight);
    ctx.lineTo(x0-arrowWidth*0.5,y0-maxY);
    ctx.lineTo(x0,y0-maxY-arrowHeight*0.5);
    ctx.lineTo(x0+arrowWidth*0.5,y0-maxY);
    ctx.fill();
    //绘制点
    ctx.beginPath();
    var data = [ [ 10, 20 ], [ 15, 13 ], [ 17, 30 ], [ 30, 10 ], [ 20, 15 ] ];
    //取点的数据
    /*将其中X与Y的最大值找出来,因为要做一个比例的转化:
                            点坐标/max点坐标 = 页面上点坐标/canvas的轴的最大值*/
    var pointX = Math.max.apply(null,data.map(function(v){return v[0];}));
    var pointY = Math.max.apply(null,data.map(function(v){return v[1];}));
    //法一:使用冒泡排序
    for(var i =0;i<data.length-1;i++){
        for(var j =0;j<data.length-1-i;j++){
            if(data[j][0]>data[j+1][0]){
                var temp = data[j +1];
                data[j+1] = data[j];
                data[j] = temp;
            }
        }
    }
    //声明一个新数组用于存储数据
    var arr = [];
    for(var i = 0 ; i < data.length ; i++){
        var tempX = data[i][0]/pointX*maxX,
            tempY = data[i][1]/pointY*maxY;
        //一定要记得坐标的最后一步转换
        var X = x0 + tempX,
            Y = y0 - tempY;
        arr.push([X,Y]);
        ctx.moveTo(X-4,Y-4);
        ctx.lineTo(X-4,Y+4);
        ctx.lineTo(X+4,Y+4);
        ctx.lineTo(X+4,Y-4);
    }
    console.log(arr);
    ctx.fill();
    //画线
    ctx.beginPath();
    //比较值,优化直线
    arr.forEach(function(v,i){
        ctx[['moveTo','lineTo'][i>0?1:0]](v[0],v[1]);
    })
    /*for(var i = 0 ; i < data.length-1 ; i++){
        var tempX = data[i][0]/pointX*maxX,
            tempY = data[i][1]/pointY*maxY;
        var tempX1 = data[i+1][0]/pointX*maxX,
            tempY1 = data[i+1][1]/pointY*maxY;
        //一定要记得坐标的最后一步转换
        var X = x0 + tempX,
            Y = y0 - tempY,
            X1 = x0 + tempX1,
            Y1 = y0 - tempY1;
        ctx.moveTo(X,Y);
        ctx.lineTo(X1,Y1);
    }*/
    ctx.stroke();
</script>
</html>

转载于:https://www.cnblogs.com/199316xu/p/6425136.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 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]。你可以根据自己的需求来修改上述代码,实现更加复杂的折线图绘制

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值