canvas基本学习(圆环图,文本类,线条样式)(二)

 function draw(){
        var canvas = document.getElementById("canvas")//获取canvas对象(画布)
        var ctx = canvas.getContext("2d")//获取对应的画笔对象,获得 2d 上下文对象
        canvas.width = 800
        canvas.height = 600

        // 绘制文本
        // canvas 提供了两种方法来渲染文本:
        // fillText(text, x, y [, maxWidth])
        // 在指定的(x,y)位置填充指定的文本,绘制的最大宽度是可选的.
        // strokeText(text, x, y [, maxWidth])
        // 在指定的(x,y)位置绘制文本边框,绘制的最大宽度是可选的.
        // 一个填充文本的示例 图1
        ctx.font = "48px serif";
        ctx.fillText("心情很美丽",50,200,200)
        // 一个文本边框的示例 图2
        ctx.font = "48px serif";
        ctx.strokeStyle = "red"
        ctx.textAlign = "left" //文本对齐选项. 可选的值包括:start,end,left,right or center.默认值是 start,以xy坐标为参考点进行对齐。
        ctx.textBaseline = "hanging" //基线对齐选项. 可选的值包括:top, hanging, middle, alphabetic, ideographic, bottom。默认值是 alphabetic
        ctx.direction = "rtl" //文本方向。可能的值包括:ltr, rtl, inherit。默认值是 inherit。
        ctx.strokeText("心情很美丽",300,200,200)
        //预测量文本宽度
        var text = ctx.measureText("心情很美丽"); // TextMetrics object
        console.log(text.width) //240
        
        // 线型
        ctx.lineWidth = 15
        ctx.lineCap = "round" //lineCap值决定了线段端点显示的类型butt,round 和 square。默认是 butt。
        ctx.beginPath()
        ctx.moveTo(100,300)
        ctx.lineTo(300,300)
        ctx.strokeStyle = "green"
        ctx.stroke()
        ctx.closePath()

        // 环形,可以用于显示百分比
        ctx.lineCap = "round" //lineCap值决定了线段端点显示的类型butt,round 和 square。默认是 butt。
        //先画一个圆环
        ctx.beginPath()
        ctx.arc(400,300,40,(Math.PI/180)*360,(Math.PI/180)*0,true)
        ctx.moveTo(100,300)
        ctx.lineTo(300,300)
        ctx.strokeStyle = "#eee"
        ctx.stroke()
        //再画占比数
        ctx.beginPath()
        var percent = 0.75
        var startAngle = 360*percent //计算开始角度
        ctx.arc(400,300,40,(Math.PI/180)*startAngle,(Math.PI/180)*0,true)
        ctx.moveTo(100,300)
        ctx.lineTo(300,300)
        ctx.strokeStyle = "#FCCA42"
        ctx.stroke()
        ctx.closePath()
    }
    draw()

 打印结果:

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

suoh's Blog

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值