网站首页  汉语字词  英语词汇  考试资料  写作素材  旧版资料

请输入您要查询的范文:

 

标题 HTML5 Canvas自定义圆角矩形与虚线示例代码
范文
    HTML5 Canvas绘制对象中提供的原生功能没有实现绘制圆角矩形与虚线的功能,通过JavaScript的Object.prototype可以实现对对象CanvasRenderingContext2D添加这两个函数功能,具体实现如下,感兴趣的朋友可以参考下
    组件fishcomponent.js的代码如下:
    代码如下:
    CanvasRenderingContext2D.prototype.roundRect =
    function(x, y, width, height, radius, fill, stroke) {
    if (typeof stroke == "undefined") {
    stroke = true;
    }
    if (typeof radius === "undefined") {
    radius = 5;
    }
    this.beginPath();
    this.moveTo(x + radius, y);
    this.lineTo(x + width - radius, y);
    this.quadraticCurveTo(x + width, y, x + width, y + radius);
    this.lineTo(x + width, y + height - radius);
    this.quadraticCurveTo(x + width, y + height, x + width - radius, y+ height);
    this.lineTo(x + radius, y + height);
    this.quadraticCurveTo(x, y + height, x, y + height - radius);
    this.lineTo(x, y + radius);
    this.quadraticCurveTo(x, y, x + radius, y);
    this.closePath();
    if (stroke) {
    this.stroke();
    }
    if (fill) {
    this.fill();
    }
    };
    CanvasRenderingContext2D.prototype.dashedLineTo = function (fromX, fromY, toX, toY, pattern) {
    // default interval distance -> 5px
    if (typeof pattern === "undefined") {
    pattern = 5;
    }
    // calculate the delta x and delta y
    var dx = (toX - fromX);
    var dy = (toY - fromY);
    var distance = Math.floor(Math.sqrt(dx*dx + dy*dy));
    var dashlineInteveral = (pattern <= 0) ? distance : (distance/pattern);
    var deltay = (dy/distance) * pattern;
    var deltax = (dx/distance) * pattern;
    // draw dash line
    this.beginPath();
    for(var dl=0; dl<dashlineInteveral; dl++) {
    if(dl%2) {
    this.lineTo(fromX + dl*deltax, fromY + dl*deltay);
    } else {
    this.moveTo(fromX + dl*deltax, fromY + dl*deltay);
    }
    }
    this.stroke();
    };
    HTML中调用演示:
    代码如下:
    <!DOCTYPE html>
    <html>
    <head>
    <meta http-equiv="X-UA-Compatible" content="chrome=IE8">
    <meta http-equiv="Content-type" content="text/html;charset=UTF-8">
    <title>Canvas Rounded Rectangle Demo</title>
    <script src="fishcomponent.js"></script>
    <link href="default.css" rel="stylesheet" />
    <script>
    var ctx = null; // global variable 2d context
    var imageTexture = null;
    window.onload = function() {
    var canvas = document.getElementById("text_canvas");
    console.log(canvas.parentNode.clientWidth);
    canvas.width = canvas.parentNode.clientWidth;
    canvas.height = canvas.parentNode.clientHeight;
    if (!canvas.getContext) {
    console.log("Canvas not supported. Please install a HTML5 compatible browser.");
    return;
    }
    var context = canvas.getContext('2d');
    context.strokeStyle="red";
    context.fillStyle="RGBA(100,255,100, 0.5)";
    context.roundRect(50, 50, 150, 150, 5, true);
    context.strokeStyle="blue";
    for(var i=0; i<10; i++) {
    var delta = i*20;
    var pattern = i*2+1;
    context.dashedLineTo(250, 50+delta, 550, 50+delta, pattern);
    }
    }
    </script>
    </head>
    <body>
    <h1>HTML5 Canvas Dash-line Demo - By Gloomy Fish</h1>
    <pre>Dash line and Rounded Rectangle</pre>
    <div id="box_plot">
    <canvas id="text_canvas"></canvas>
    </div>
    </body>
    </html>
随便看

 

在线学习网范文大全提供好词好句、学习总结、工作总结、演讲稿等写作素材及范文模板,是学习及工作的有利工具。

 

Copyright © 2002-2024 cuapp.net All Rights Reserved
更新时间:2025/5/17 9:55:25