【柿饼派GUI】Canvas画布控件使用(五)

本文介绍使用Canvas画布控件绘制:

  1. 画线
  2. 矩形
  3. 空心圆
  4. 实心圆
  5. 画图片
  6. 绘制文本

正文开始:
新建默认项目 >>新建page >>拖一个Canvas控件,设置 X = 0, Y = 0, Width = 480, Height = 272,
剩下的就交给js代码逻辑进行实现

var page = {

    /* 此方法在第一次显示窗体前发生 */
    onLoad: function (event) {
        this.drawCanvas()
    },

    drawCanvas: function () {

        var ctx = pm.createCanvasContext('Canvas1', this)
        // 画线
        drawLine(ctx)
        // 画矩形 空心和实心矩形
        drawRect(ctx)
        // 画圆 空心圆和实心圆
        drawArc(ctx)
        // 画图片
        drawImage(ctx)
        // 绘制文本
        drawText(ctx)
        // 绘制折线图
        drawLineImage(ctx)

        ctx.draw()

        function drawLine(ctx) {
            // 设置边框颜色
            ctx.setStrokeStyle('red')
            // 设置绘制线宽度
            ctx.setLineWidth(2)
            // 移动到画线起点
            ctx.moveTo(20, 20)
            // 设置绘制线的终点
            ctx.lineTo(60, 40)
            ctx.stroke()
        }

        function drawRect(ctx) {
            // 设置边框颜色
            ctx.setStrokeStyle('#ff00ff')
            // 设置矩形 坐标点 和 宽 高
            ctx.strokeRect(100, 10, 80, 50)// 矩形框
            ctx.stroke()
            //设置矩形填充颜色
            ctx.setFillStyle('#ffff00')
            ctx.fillRect(110, 20, 60, 30)// 填充矩形
        }

        function drawArc(ctx) {
            // 这里圆的绘制起始角度以水平为0度

            // 移动到圆心位子
            ctx.moveTo(60, 95)
            // 绘制空心圆 圆心x,圆心y半径,开始角度,结束角度
            ctx.arc(60, 95, 50, 0, 2 * Math.PI)
            // 设置圆心填充色
            ctx.setFillStyle('#0000ff')
            ctx.fill()

            // 绘制实心圆
            ctx.beginPath()
            // 设置圆的线宽, 由于下文设置圆的半径r为2, 这里线宽为2r
            ctx.setLineWidth(4)
            // 设置圆心填充色
            ctx.setStrokeStyle('#ff0000')
            ctx.arc(60, 95, 2, 0, 2 * Math.PI)
            ctx.stroke()
        }

        function drawImage(ctx) {
            // 默认图片路径为resource内部,支持相对路径
            // 图片路径, X坐标, Y坐标
            ctx.drawImage('image.png', 10, 150)
        }

        function drawText(ctx) {
            // 设置文本颜色
            ctx.setFillStyle('red')
            // 设置字体以及字号
            ctx.setFont('STXINWEI.TTF', 20)
            ctx.fillText('this is test string.', 200, 20)
        }

        function drawLineImage(ctx) {
            // 设置一组数据
            var datas = [120, 40, 95, 62, 136, 100]
            var sums = 0
            for (var s = 0; s < datas.length; s++) {
                sums += datas[s]
            }
            ctx.beginPath()

            ctx.setStrokeStyle('white')
            ctx.setLineWidth(2)
            // 其实实现上不难,主要是计算各种坐标比较麻烦
            ctx.moveTo(140, 80)
            // 绘制纵轴坐标箭头
            ctx.lineTo(145, 85)
            ctx.moveTo(140, 80)
            ctx.lineTo(135, 85)
            ctx.moveTo(140, 80)
            // 原点
            ctx.lineTo(140, 250)
            // 绘制横轴线和箭头
            ctx.lineTo(470, 250)
            ctx.lineTo(465, 245)
            ctx.moveTo(470, 250)
            ctx.lineTo(465, 255)

            // 设置绘制文本字号和颜色
            ctx.setFillStyle('white')
            ctx.setFontSize(15)

            // 循环绘制纵轴刻度 和 刻度值
            for (var v = 1; v < datas.length; v++) {
                ctx.moveTo(140, 250 - 30 * v)
                ctx.lineTo(135, 250 - 30 * v)
                ctx.fillText((30 * (datas.length - v)) + '', 110, 66 + 30 * v)
            }

            // 循环绘制横轴刻度 和 刻度值
            for (var i = 0; i <= datas.length; i++) {
                ctx.moveTo(140 + 50 * i, 245)
                ctx.lineTo(140 + 50 * i, 250)
                ctx.fillText(i + '', 140 + 50 * i, 256)
            }
            ctx.stroke()

            console.log('sums >>' + sums)
            ctx.fillText('Sums: ' + sums, 250, 90)

            // 遍历数据进行画线 画点
            for (var d = 0; d < datas.length; d++) {
                console.log('x >>' + (140 + 50 * d) + '  y >>' + (250 - datas[d]))

                if (d == 0)
                    ctx.moveTo(140 + 50 * (d + 1), 250 - datas[d])
                else
                    ctx.lineTo(140 + 50 * (d + 1), 250 - datas[d])
                // 画点
                ctx.setLineWidth(2)
                ctx.arc(140 + 50 * (d + 1) + 2, 250 - datas[d], 2, 0, 2 * Math.PI)
                // 绘制当前数据
                ctx.fillText(datas[d] + '', 140 + 50 * (d + 1) - 5, 250 - datas[d] - 15)
            }

            ctx.stroke()
        }
    }

};

Page(page);

page = 0;


绘制折线图其实并不难, 都是一些坐标的计算, 绘制的时候, 最好要在脑海里或者画出一个这样的图:

写完收工, 模拟运行查看效果:
从上到下,从左到右依次是: 画线 >> 画矩形 空心和实心矩形 >> 绘制文本 >> 画圆 空心圆和实心圆 >> 绘制折线图 >> 画图片

原文地址:https://www.cnblogs.com/Katakana/p/11594262.html

时间: 2024-08-29 20:34:01

【柿饼派GUI】Canvas画布控件使用(五)的相关文章

10分钟,利用canvas画一个小的loading界面(顺便讨论下绘制效率问题)

首先利用定义下canvas得样式 <canvas width="1024" height="720" id="canvas" style="border: 1px solid #808080;display: block;margin: 100px auto;>你的游览器不支持canvas</canvas> 这里主要要说的就是宽高,不要在style里面定义,不然会被拉伸.(对于这点,建议大家看下W3c文档,不是很

10分钟,利用canvas画一个小的loading界面

首先利用定义下canvas得样式 <canvas width="1024" height="720" id="canvas" style="border: 1px solid #808080;display: block;margin: 100px auto;>你的游览器不支持canvas</canvas> 这里主要要说的就是宽高,不要在style里面定义,不然会被拉伸.(对于这点,建议大家看下W3c文档,不是很

html5学习(一)--canvas画时钟

利用空余时间学习一下html5. 1 <!doctype html> 2 <html> 3 <head></head> 4 <body> 5 <canvas id="clock" width="500" height="500"></canvas> 6 <script> 7 var clock=document.getElementById('cloc

html5中用canvas画八大行星围绕太阳转

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8&

Android利用canvas画各种图形

canvas通俗的说就是一张画布,我们可以使用画笔paint,在其上面画任意的图形. 原理: 可以把canvas视为Surface的替身或者接口,图形便是绘制在Surface上的.Canvas封装了所有的绘制调用.通过Canvas, 绘制到Surface上的内容首先存储到一个内存区域(也就是对应的Bitmapz中),该Bitmap最终会呈现到窗口上. 使用: 1.Canvas可以直接new Canvas(): 2.在View中重写OnDraw()方法,里面有一个Canvas,今天讨论的内容. 方

HTML5之Canvas画正方形

1.设计源码 <!DOCTYPE html> <head> <meta charset="utf-8" /> <title>HTML5之Canvas画正方形</title> <script type="text/javascript"> function drawFour(id) { //获取canvas元素 var canvas = document.getElementById("

HTML5之Canvas画圆形

1.设计源码 <!DOCTYPE html> <head> <meta charset="utf-8" /> <title>HTML5之Canvas画圆形</title> </head> <body onLoad="drawFour('canvas')"> <canvas id="canvas" width="1200" height=&

樱花的季节,教大家用canvas画出飞舞的樱花树

又到了樱花的季节,教大家使用canvas画出飞舞的樱花树效果. 废话少说,先看效果. 演示效果地址:http://suohb.com/work/tree4.htm 查看演示效果 第一步,我们先画出一棵树的主体. 我画树的使用的原理是,定义一个起始点,从这个点开始,向一个角度移动一段距离.得到另一个点. 画出一条线连接两个点. 以新得到的点,依旧向这个角度,移动一段距离.得到第三个点,连写第二第三个点. 以此类推.一定步长之后,就得到一条射线. 我们根据自然界中的真实树的情况,这条线越来越细,直到

canvas画的北斗七星和大熊座

用canvas画的北斗七星和大熊座,主要用到的知识点是:canvas.定时器. html代码: 1 <body> 2 <canvas id="canvas" width="1250px" height="670px"> 3 4 </canvas> 5 6 </body> css代码: 1 body{ 2 background-color:#0B0B0D; 3 } 4 5 #canvas{ 6 pos