IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> canvas五角星和矩形会碰撞出什么样的火花 -> 正文阅读

[JavaScript知识库]canvas五角星和矩形会碰撞出什么样的火花

话不多说,直接上代码

index.html

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>DrawCanvas</title>
        <script src="./DrawCanvas.js"></script>
    </head>
    <body>
        <div>
            <canvas id="myCanvas" width="800px" height="600px" style="border: 1px solid #d3d3d3;">
                您的浏览器不支持 HTML5 canvas 标签。
            </canvas>
        </div>
    </body>
    <script>
        var width = 1620;
        var height = 1080;
        var step = width / 30;
        var drawCanvas = DrawCanvas.createNew();
        drawCanvas.canvas = document.getElementById("myCanvas");
        if (drawCanvas.canvas) {
            drawCanvas.canvas.setAttribute("width", width);
            drawCanvas.canvas.setAttribute("height", height);
            drawCanvas.canvas.style.zIndex = 1;
            drawCanvas.canvas.style.position = "absolute";
            drawCanvas.canvas.style.top = 0;
            drawCanvas.canvas.style.left = 0;
            drawCanvas.initCanvasContext();
        }
        if (drawCanvas.canvas) {
            drawCanvas.setFillColor("#F40002");
            drawCanvas.drawRectangle(
                {
                    x: 0,
                    y: 0
                }, width, height, 1, 1);
            
            drawCanvas.setFillColor("#FAF408");
            drawCanvas.drawPentangle(
                {
                    x: 5 * step,
                    y: 5 * step
                }, 3 * step, 1, 1);
            drawCanvas.drawPentangle(
                {
                    x: 10 * step,
                    y: 2 * step
                }, 1 * step, 1, 1);
            drawCanvas.drawPentangle(
                {
                    x: 12 * step,
                    y: 4 * step
                }, 1 * step, 1, 1);
            drawCanvas.drawPentangle(
                {
                    x: 12 * step,
                    y: 7 * step
                }, 1 * step, 1, 1);
            drawCanvas.drawPentangle(
                {
                    x: 10 * step,
                    y: 9 * step
                }, 1 * step, 1, 1);
        }
    </script>
</html>

DrawCanvas.js

function drawRectangle(context, point, width, height, lineType, fillType) {
    if (!context) return;

    if(lineType === 0) {
        context.setLineDash([3, 3]);
    } else if(lineType === 1) {
        context.setLineDash([]);
    }

    if (fillType === 0)
        context.strokeRect(point.x, point.y, width, height);
    else if(fillType === 1)
        context.fillRect(point.x, point.y, width, height);
    else {
        context.strokeRect(point.x, point.y, width, height);
        context.fillRect(point.x, point.y, width, height);
    }
}

function calculatePentanglePoints(center, r) {
    var points = new Array();
    var point = new Object();
    var radian = 72 * Math.PI / 180;

    point.x = center.x;
    point.y = center.y - r;
    points.push(point);

    point = new Object();
    point.x = center.x + r * Math.sin(radian);
    point.y = center.y - r * Math.cos(radian);
    points.push(point);

    point = new Object();
    radian = 36 * Math.PI / 180;
    point.x = center.x + r * Math.sin(radian);
    point.y = center.y + r * Math.cos(radian);
    points.push(point);

    point = new Object();
    point.x = center.x - r * Math.sin(radian);
    point.y = center.y + r * Math.cos(radian);
    points.push(point);

    point = new Object();
    radian = 72 * Math.PI / 180;
    point.x = center.x - r * Math.sin(radian);
    point.y = center.y - r * Math.cos(radian);
    points.push(point);

    return points;
}

function drawPentangle(context, center, r, lineType, fillType) {
    if (!context) return;

    if(lineType === 0) {
        context.setLineDash([3, 3]);
    } else if(lineType === 1) {
        context.setLineDash([]);
    }

    const pentanglePoints = calculatePentanglePoints(center, r);
    for (let i = 0; i < 5; i++) {
        console.log("[" + pentanglePoints[i].x + ", " + pentanglePoints[i].y + "]");
    }
    context.beginPath();
    context.moveTo(pentanglePoints[0].x, pentanglePoints[0].y);
    context.lineTo(pentanglePoints[3].x, pentanglePoints[3].y);
    context.lineTo(pentanglePoints[1].x, pentanglePoints[1].y);
    context.lineTo(pentanglePoints[4].x, pentanglePoints[4].y);
    context.lineTo(pentanglePoints[2].x, pentanglePoints[2].y);
    context.closePath();

    if (fillType === 0)
        context.stroke();
    else if(fillType === 1)
        context.fill();
    else {
        context.fill();
        context.stroke();
    }
}

var DrawCanvas = {
    createNew: function() {
        var drawCanvasObj = {};
        drawCanvasObj.canvas = undefined;
        drawCanvasObj.context = undefined;
        drawCanvasObj.initCanvasContext = function() {
            drawCanvasObj.context = drawCanvasObj.canvas.getContext("2d");
            drawCanvasObj.context.strokeStyle = "black";
            drawCanvasObj.context.fillStyle = "red";
            drawCanvasObj.context.lineWidth = 1;
        };
        drawCanvasObj.setStrokeColor = function(color) {
            drawCanvasObj.context.strokeStyle = color;
        };
        drawCanvasObj.setFillColor = function(color) {
            drawCanvasObj.context.fillStyle = color;
        };
        drawCanvasObj.drawRectangle = function(leftTop, width, height, lineType, fillType) {
            if (!drawCanvasObj.context) return;
            drawRectangle(drawCanvasObj.context, leftTop, width, height, lineType, fillType);
        };
        drawCanvasObj.drawPentangle = function(center, r, lineType, fillType) {
            if (!drawCanvasObj.context) return;
            drawPentangle(drawCanvasObj.context, center, r, lineType, fillType);
        };
        return drawCanvasObj;
    }
};
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-02-28 15:20:07  更:2022-02-28 15:21:56 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 10:31:57-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码