H5+javascript 动态绘制五角星

news/2024/7/19 14:47:25 标签: canvas, html5, js

原理

手动画五角星感觉谁都会。
在这里插入图片描述
这不是有手就行,简简单单。可是用代码画图应该怎样做呢?
其实也很简单在H5画布上无非就是找点,然后按一定的顺序连接这些点。那么问题来了点怎么找啊?
给你整副图,一看就明白了。
在这里插入图片描述
懂了吧,这不就是圆上的五个点么,找出来不就行了。圆的方程高中生都张口就来(x-a)²+(y-b)²=r²。不过这好像没啥用因为我们想要坐标点。在稍微那么仔细一看,这不是将整个圆平分了5份吗。每个1/5弧对应的圆心角,这不是2π/5么。有了圆心角用极坐标求位置那不很nice。圆的极坐标公式:ρ²=x²+y²,x=ρcosθ,y=ρsinθ,tanθ=y/x,(x不为0)。自己设定一个半径 r(这也就决定了五角星的大小),这五个坐标就为(rcos(2π/5),rsin(2π/5))、(rcos(4π/5),rsin(4π/5))、(rcos(6π/5),rsin(6π/5))、(rcos(8π/5),rsin(8π/5))、(rcos(10π/5),rsin(10π/5))。(具体怎样看坐标系是怎样建立的,这些点的角度可以同时偏移相同的角度)
五个点有了然后确定连接顺序就行了。
在这里插入图片描述
顺序为1、3、5、2、4、1。用这用代码体现出来就行了。
(原理是上面说的那样但是由于起始绘制点和H5坐标系与数学上的坐标系有些差别的缘故,可能需要一些调整。比如:要画出上图那样的一个角指向正上方的五角星就需要对角度进行一些调整,所有的点的圆心角要减去90度。)

代码

画一个上图那样的五角星。

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>五角星</title>
</head>
<body>
    <canvas id="mycanvas" width="300" height="200" style="border: 1px solid;">
        您的浏览器不支持H5画布!
    </canvas>
    <script>
        var mycanvas = document.getElementById("mycanvas");
        var ctx = mycanvas.getContext("2d");
        var pas = Math.PI*2/5;
        var i=0;
        ctx.beginPath();
        ctx.moveTo(150, 10);//绘制的起点
        
        var id = setInterval(function(){//圆心位置(150,110)
            i += 2;
            if(i > 10){
                clearInterval(id);
            }
            ctx.lineTo(150 + 100 * Math.cos(i*pas-Math.PI/2), 110 + 100 * Math.sin(i*pas-Math.PI/2));
            ctx.strokeStyle = "red";
            ctx.stroke();
        },200)
    </script>
</body>
</html>

效果

在这里插入图片描述


http://www.niftyadmin.cn/n/489842.html

相关文章

html中script的位置导致的js不能正常执行问题

前言 今天写网页&#xff0c;犯了一个刚学h5时容易犯的低级错误&#xff0c;记录一下。 情景 问题代码&#xff1a; 不用看代码的内容&#xff0c;看js的引入位置即可。这两个文件在同一目录下js文件名为1.js。 html代码&#xff1a; <!DOCTYPE html> <html lang&…

微信小程序怎样用setData修改字典和在数组中添加

setData函数在小程序中具有同时修改前端和后端的功能&#xff0c;应该是进行数据修改中最常用的一个功能了。 修改data中的变量 wxml <view>{{information}} </view> <view><button type"primary" bindtap"click">修改信息<…

win10系统安装face_recognition

介绍 face_recognition是一个人脸识别库&#xff0c;号称识别准确率可达 99.38%。 因为写毕业设计要用到这个库&#xff0c;开始在Ubuntu上使用这个库&#xff0c;安装没有出现任何问题。今天在win10系统上想要安装这个库时却出现了问题&#xff0c;记录一下。 问题 face_re…

wxpython制作桌面悬浮球

介绍 使用wxpython制作一个类似于电脑管家一样的悬浮球。 功能 圆形窗口自动鼠标离开悬浮球自动贴边鼠标在悬浮球上自动弹出整个悬浮球 效果 代码 import wxclass myframe(wx.Frame):def __init__(self):super().__init__(parentNone,poswx.DefaultPosition,stylewx.FRAME…

OpenCV-python的imshow方法无法弹出窗口问题

问题 今天使用OpenCV的imshow方法预览摄像头捕捉的图像时&#xff0c;出现了显示窗口不弹出的问题&#xff0c;最后通过安装matplotlib库解决的。 使用的代码 import cv2 import os # 调用笔记本内置摄像头&#xff0c;所以参数为0&#xff0c;如果有其他的摄像头可以调整参…

PyAutoGUI使用

PyAutoGUI使用 ### 鼠标事件 获取屏幕大小&#xff0c;返回的为元组&#xff1a;width, height pyautogui.size() 检查坐标是否在屏幕内&#xff0c;返回bool值&#xff1a;pyautogui.onScreen(x, y) 获取鼠标位置&#xff0c;返回的为元组&#xff1a;currentMouseX, cur…

wxFormBuilder使用介绍

wxFormBuilder介绍 wxFormBuilder是一个开源&#xff0c;跨平台的所见即所得的图形用户界面生成器&#xff0c;可以翻译wxWidget GUI设计成C&#xff0c;Python&#xff0c;PHP&#xff0c;XRC格式。github项目地址 这个工具将wxPython设计用户图形界面的过程可视化。通过简单…

BFC(Block Formatting Context) 块级格式化上下文

BFC(Block Formatting Context) 块级格式化上下文 BFC就好像标签的一个属性&#xff0c;可以使一个区域具有独立渲染不影响其他区域的特性。 BFC常用的几个方式 float属性不为noneoverflow属性不为visibleposition属性为absolute或fixeddisplay属性为inline-blockcontain值为…