【Canvas与标牌】盾形银底红带Best Quality Premium标牌

news2024/10/8 13:36:28

【成图】

【代码】

<!DOCTYPE html>
<html lang="utf-8">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<head>
     <title>BestQulityPremium金属牌重制版Draft2</title>
     <style type="text/css">
     .centerlize{
        margin:0 auto;
        width:1200px;
     }
     </style>
     </head>

     <body οnlοad="init();">
        <div class="centerlize">
            <canvas id="myCanvas" width="12px" height="12px" style="border:1px dotted black;">
                如果看到这段文字说您的浏览器尚不支持HTML5 Canvas,请更换浏览器再试.
            </canvas>
        </div>
     </body>
</html>
<script type="text/javascript">
<!--
/*****************************************************************
* 将全体代码(从<!DOCTYPE到script>)拷贝下来,粘贴到文本编辑器中,
* 另存为.html文件,再用chrome浏览器打开,就能看到实现效果。
******************************************************************/

// canvas的绘图环境
var ctx;

// 高宽
const WIDTH=512;
const HEIGHT=512;

// 舞台对象
var stage;

//-------------------------------
// 初始化
//-------------------------------
function init(){
    // 获得canvas对象
    var canvas=document.getElementById('myCanvas');  
    canvas.width=WIDTH;
    canvas.height=HEIGHT;

    // 初始化canvas的绘图环境
    ctx=canvas.getContext('2d');  
    ctx.translate(WIDTH/2,HEIGHT/2);// 原点平移

    // 准备
    stage=new Stage();    
    stage.init();

    // 开幕
    animate();
}

// 播放动画
function animate(){    
    stage.update();    
    stage.paintBg(ctx);
    stage.paintFg(ctx);     

    // 循环
    if(true){
        //sleep(100);
        window.requestAnimationFrame(animate);   
    }
}

// 舞台类
function Stage(){
    // 初始化
    this.init=function(){
        
    }

    // 更新
    this.update=function(){    
        
    }

    // 画背景
    this.paintBg=function(ctx){
        ctx.clearRect(-WIDTH/2,-HEIGHT/2,WIDTH,HEIGHT);// 清屏    
    }

    // 画前景
    this.paintFg=function(ctx){
        // 底色
        ctx.save();
        ctx.fillStyle = "white";
        ctx.fillRect(-WIDTH/2,-HEIGHT/2,WIDTH,HEIGHT);
        ctx.restore();

        const R=210;// 基准尺寸

        // #1圈
        ctx.save();
        var r=R*1.00;
        ctx.shadowOffsetY=8; // 设置阴影
        ctx.shadowColor="lightgrey";
        ctx.shadowBlur=6;
        ctx.fillStyle="lightgrey";
        drawShield(ctx,0,0,r);
        ctx.fill();
        ctx.restore();

        // #2圈
        ctx.save();
        var r=R*0.98;
        var gnt1=ctx.createLinearGradient(0,-r,0,r);
        gnt1.addColorStop(0,"rgb(243,243,243)");
        gnt1.addColorStop(0.3,"rgb(171,171,171)");
        gnt1.addColorStop(0.6,"rgb(101,101,101)");
        gnt1.addColorStop(0.7,"rgb(114,114,114)");
        gnt1.addColorStop(0.8,"rgb(97,97,97)");
        gnt1.addColorStop(0.9,"rgb(87,87,87)");
        gnt1.addColorStop(1,"rgb(156,156,156)");
        ctx.fillStyle=gnt1;
        drawShield(ctx,0,0,r);
        ctx.fill();
        ctx.restore();

        // #3圈
        ctx.save();
        var r=R*0.94;
        ctx.fillStyle="black";
        drawShield(ctx,0,0,r);
        ctx.fill();
        ctx.restore();

        // #4圈
        ctx.save();
        var r=R*0.93;
        var gnt1=ctx.createLinearGradient(-r,-r,r,r);
        gnt1.addColorStop(0,"rgb(208,208,208)");
        gnt1.addColorStop(0.33,"rgb(244,244,244)");
        gnt1.addColorStop(0.5,"rgb(203,203,203)");
        gnt1.addColorStop(0.67,"rgb(246,246,246)");
        gnt1.addColorStop(1,"rgb(187,187,187)");
        ctx.fillStyle=gnt1;
        drawShield(ctx,0,0,r);
        ctx.fill();
        ctx.restore();

        // BEST文字
        ctx.save();
        var r=R*0.93;
        ctx.textBaseline="middle";
        ctx.textAlign="center";
        ctx.font = r*0.50+"px Bahnschrift SemiBold SemiConden";
        ctx.fillStyle="black";
        ctx.fillText("BEST",0,-r*0.56);
        ctx.restore();

        // QUALITY文字
        ctx.save();
        var r=R*0.93;
        ctx.textBaseline="middle";
        ctx.textAlign="center";
        ctx.font = r*0.33+"px Bahnschrift SemiBold SemiConden";
        ctx.fillStyle="black";
        ctx.fillText("QUALITY",0,-r*0.13);
        ctx.restore();

        // 红带
        ctx.save();
        var r=R*0.98;        
        var width=r*63/85;
        var gnt1=ctx.createLinearGradient(-width,0,width,0);
        gnt1.addColorStop(0,"rgba(111,1,2,0.9)");
        gnt1.addColorStop(0.1,"rgba(162,3,7,0.9)");
        gnt1.addColorStop(0.25,"rgba(182,2,4,0.9)");
        gnt1.addColorStop(0.5,"rgba(208,2,4,0.9)");
        gnt1.addColorStop(0.75,"rgba(182,2,4,0.9)");
        gnt1.addColorStop(0.9,"rgba(162,3,7,0.9)");
        gnt1.addColorStop(1,"rgba(111,1,2,0.9)");
        ctx.fillStyle=gnt1;
        drawRect(ctx,0,r/3.5,2*width,r/2.5);
        ctx.fill();
        ctx.restore();

        // PRESMIUM文字
        ctx.save();
        var r=R*0.98;        
        ctx.textBaseline="middle";
        ctx.textAlign="center";
        ctx.font = r*0.25+"px Bahnschrift SemiBold SemiConden";
        ctx.fillStyle="white";
        ctx.fillText("PRESMIUM",0,r*0.32);
        ctx.restore();

        // 红带
        ctx.save();
        var r=R*0.98;        
        var width=r*63/85;
        var offset=r/3.5;
        
        for(var i=-1;i<=1;i++){
            var sz=Math.abs(i);//size
            var radius=r*0.14-sz*r/30;
            var a=createPt(i*offset,r*0.64+radius*Math.tan(Math.PI/10));
            
            ctx.save();
            ctx.translate(a.x,a.y);
            var gnt=ctx.createRadialGradient(0,0,0,0,0,radius);
            gnt.addColorStop(0,"red");
            gnt.addColorStop(1,"rgb(117,0,0)");
            ctx.fillStyle=gnt;
            draw5Star(ctx,0,0,radius);
            ctx.fill();
            ctx.restore();
        }

        offset*=0.9;
        for(var i=-2;i<=2;i+=4){
            var sz=Math.abs(i);//size
            var radius=r*0.14-sz*r/30;
            var a=createPt(i*offset,r*0.64+radius*Math.tan(Math.PI/10));
            
            ctx.save();
            ctx.translate(a.x,a.y);
            var gnt=ctx.createRadialGradient(0,0,0,0,0,radius);
            gnt.addColorStop(0,"red");
            gnt.addColorStop(1,"rgb(117,0,0)");
            ctx.fillStyle=gnt;
            draw5Star(ctx,0,0,radius);
            ctx.fill();
            ctx.restore();
        }


        ctx.restore();

                
        writeText(ctx,WIDTH/2-30,HEIGHT/2-5,"逆火制图","8px consolas","lightgrey");// 版权
    }
}

/*----------------------------------------------------------
函数:用于绘制五边形圆角盾牌轮廓,圆角是用贝塞尔二次曲线拟合
ctx:绘图上下文
x:盾牌中心横坐标
y:盾牌中心纵坐标
radius:半径,即盾牌高度的一半
----------------------------------------------------------*/
function drawShield(ctx,x,y,radius){
    const R=radius;// 接参数
    const H=2*R;// 高度
    const W=63/85*H;// 宽度
    const ALPHA=Math.PI/12;// 下斜边与水平线的夹角
    const H1=W/2*Math.tan(ALPHA);// 左下右下两角与水平线的距离
    const R1=R/20;// 小圆角半径,用于底角外的四个角
    const R2=2.5*R1;// 大圆角半径,只用于底角
    
    // 经典的极坐标范式
    var a=createPt(x-W/2,y-H/2);
    var r=R1;
    var angle=0;
    var a1=createPt(a.x+r*Math.cos(angle),a.y+r*Math.sin(angle));
    r=R1;
    angle=Math.PI/2;
    var a2=createPt(a.x+r*Math.cos(angle),a.y+r*Math.sin(angle));

    var b=createPt(x-W/2,y+H/2-H1);
    r=R1;
    angle=-Math.PI/2;
    var b1=createPt(b.x+r*Math.cos(angle),b.y+r*Math.sin(angle));
    r=R1;
    angle=ALPHA;
    var b2=createPt(b.x+r*Math.cos(angle),b.y+r*Math.sin(angle));

    var c=createPt(x,y+H/2);
    r=R2;
    angle=Math.PI+ALPHA;
    var c1=createPt(c.x+r*Math.cos(angle),c.y+r*Math.sin(angle));
    r=R2;
    angle=-ALPHA;
    var c2=createPt(c.x+r*Math.cos(angle),c.y+r*Math.sin(angle));

    var d=createPt(x+W/2,y+H/2-H1);
    r=R1;
    angle=Math.PI-ALPHA;
    var d1=createPt(d.x+r*Math.cos(angle),d.y+r*Math.sin(angle));
    r=R1;
    angle=-Math.PI/2;
    var d2=createPt(d.x+r*Math.cos(angle),d.y+r*Math.sin(angle));

    var e=createPt(x+W/2,y-H/2);
    r=R1;
    angle=Math.PI/2;
    var e1=createPt(e.x+r*Math.cos(angle),e.y+r*Math.sin(angle));
    r=R1;
    angle=-Math.PI;
    var e2=createPt(e.x+r*Math.cos(angle),e.y+r*Math.sin(angle));

    ctx.beginPath();
    ctx.moveTo(a1.x,a1.y);
    ctx.quadraticCurveTo(a.x,a.y,a2.x,a2.y);
    ctx.lineTo(b1.x,b1.y);
    ctx.quadraticCurveTo(b.x,b.y,b2.x,b2.y);
    ctx.lineTo(c1.x,c1.y);
    ctx.quadraticCurveTo(c.x,c.y,c2.x,c2.y);
    ctx.lineTo(d1.x,d1.y);
    ctx.quadraticCurveTo(d.x,d.y,d2.x,d2.y);
    ctx.lineTo(e1.x,e1.y);
    ctx.quadraticCurveTo(e.x,e.y,e2.x,e2.y);
    ctx.closePath();
}

/*--------------------------------------------------
函数:绘制正五角星
ctx:绘图上下文
x:五角星中心横坐标
y:五角星中心纵坐标
R:五角星中心到顶点的距离
---------------------------------------------------*/
function draw5Star(ctx,x,y,R){
    var r=R*Math.sin(Math.PI/10)/Math.sin(Math.PI/10*7);
    
    var arr=[0,0,0,0,0,0,0,0,0,0];

    // 顶五点
    for(var i=0;i<5;i++){
        var theta=i*Math.PI/5*2-Math.PI/10;
        var x1=R*Math.cos(theta)+x;
        var y1=R*Math.sin(theta)+y;
        arr[i*2]=createPt(x1,y1);
    }

    // 内五点
    for(var i=0;i<5;i++){
        var theta=i*Math.PI/5*2+Math.PI/10;
        var x1=r*Math.cos(theta)+x;
        var y1=r*Math.sin(theta)+y;
        arr[i*2+1]=createPt(x1,y1);
    }

    ctx.beginPath();
    for(var i=0;i<arr.length;i++){
        ctx.lineTo(arr[i].x,arr[i].y);
    }
    ctx.closePath();
}

/*----------------------------------------------------------
函数:用于绘制矩形
ctx:绘图上下文
x:矩形中心横坐标
y:矩形中心纵坐标
width:矩形宽
height:矩形高
----------------------------------------------------------*/
function drawRect(ctx,x,y,width,height){
    ctx.beginPath();
    ctx.moveTo(x-width/2,y-height/2);
    ctx.lineTo(x+width/2,y-height/2);
    ctx.lineTo(x+width/2,y+height/2);
    ctx.lineTo(x-width/2,y+height/2);
    ctx.closePath();
}

/*----------------------------------------------------------
函数:用于绘制实心圆
ctx:绘图上下文
x:矩形中心横坐标
y:矩形中心纵坐标
r:圆半径
style:填充圆的方案
----------------------------------------------------------*/
function drawSolidCircle(ctx,x,y,r,style){
    ctx.fillStyle=style;
    ctx.beginPath();
    ctx.arc(x,y,r,0,Math.PI*2,false);
    ctx.closePath();
    ctx.fill();
}

/*----------------------------------------------------------
函数:创建一个二维坐标点
x:横坐标
y:纵坐标
Pt即Point
----------------------------------------------------------*/
function createPt(x,y){
    var retval={};
    retval.x=x;
    retval.y=y;
    return retval;
}

/*----------------------------------------------------------
函数:延时若干毫秒
milliseconds:毫秒数
----------------------------------------------------------*/
function sleep(milliSeconds) {
    const date = Date.now();
    let currDate = null;
    while (currDate - date < milliSeconds) {
        currDate = Date.now();
    } 
}

/*----------------------------------------------------------
函数:书写文字
ctx:绘图上下文
x:横坐标
y:纵坐标
text:文字
font:字体
color:颜色
----------------------------------------------------------*/
function writeText(ctx,x,y,text,font,color){
    ctx.save();
    ctx.textBaseline="bottom";
    ctx.textAlign="center";
    ctx.font = font;
    ctx.fillStyle=color;
    ctx.fillText(text,x,y);
    ctx.restore();
}

/*-------------------------------------------------------------
子曰:“贤哉,回也!一箪食,一瓢饮,在陋巷,人不堪其忧,回也不改其乐。”
--------------------------------------------------------------*/
//-->
</script>

END

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2196472.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【YOLOv8实时产品缺陷检测】

YOLOv8应用于产品缺陷检测实例 项目概况项目实现YOLOv8安装及模型训练关键代码展示动态效果展示 项目概况 本项目是应用YOLOv8框架实现训练自定义模型实现单一零件的缺陷检测&#xff0c;软件界面由PyQt5实现。 功能已正式使用&#xff0c;识别效果达到预期。 项目实现 项目…

刷题 二分查找

二分查找 二分查找的本质就是 缩小有效范围 需要注意&#xff1a; int mid (left right) / 2; int mid left (right - left) / 2; 防止溢出 hot100 - 二分查找 ⭐️35. 搜索插入位置 找到第一个大于等于 target 的值 class Solution { public:// 目标: 找到第一个大于…

PD取电诱骗协议芯片支持PD3.1 支持大电流、大功率(28V5A 140W)快速充电。

PD取电快充协议芯片XSP16是受电端的一种PD取电快充协议芯片&#xff0c;它支持PD2.0/3.0&#xff0c;PD3.1、QC2.0/3.0、华为SCP/FCP、三星AFC等快充协议。支持UART串口发送电压/电流消息&#xff0c;供外部MCU读取&#xff0c;以便适应不同的负载。支持从充电器、车充、充电宝…

计算机基础知识:计算机中丢失 msvcr110.dll怎么修复?

1. msvcp110.dll 介绍 1.1 定义&#xff1a;Microsoft Visual C 2012的一部分 msvcp110.dll是Microsoft Visual C 2012 Redistributable Package的一部分&#xff0c;这是一个运行时库文件&#xff0c;包含了Microsoft Visual C 2012编译器所构建程序所需的函数和资源。 1.2…

使用Markdown Here插件生成邮件样式

使用Markdown Here插件生成邮件样式 通常大学生们都有给老师、助教使用邮箱发送作业的情景&#xff0c;怎样让自己发送的邮件美观呢&#xff0c;我们可以使用Markdown Here插件美化 以下为结果展示 Markdown Here 插件 官网地址 html代码 <font size"7", face…

大数据ETL数据提取转换和加载处理

什么是 ETL&#xff1f; 提取转换加载&#xff08;英语&#xff1a;Extract, transform, load&#xff0c;简称ETL&#xff09;&#xff0c;用来描述将资料从来源端经过抽取、转置、加载至目的端的过程。ETL一词较常用在数据仓库&#xff0c;但其对象并不限于数据仓库。 ETL&…

迎接国庆旅游热潮,火山引擎数据飞轮助力景区数智化升级

随着人们生活水平的提高和旅游消费观念的转变&#xff0c;国庆假期成为人们出行旅游的黄金时段。同程旅行发布的报告显示&#xff0c;北京、杭州、重庆、上海、南京、成都等城市仍是 “十一” 假期国内热门的目的地&#xff0c;而一些新兴的宝藏旅游目的地如新疆阿勒泰、云南迪…

《向量数据库指南》——Fivetran+Mlivus Cloud:打造AI搜索神器

哈哈,各位向量数据库和 AI 应用的同仁们,今天咱们来聊聊一个超级实用的话题——如何借助 Fivetran 和 Mlivus Cloud 构建 AI 驱动的搜索工具,从非结构化数据中挖掘出无尽的宝藏! 在这个信息爆炸的时代,非结构化数据已经成为了企业最重要的资产之一。它包含了大量的文本、…

进入猛增模式后,小米股价还剩下多少上涨空间?

猛兽财经核心观点&#xff1a; &#xff08;1&#xff09;小米集团的股价已经上涨到了2022年以来的最高点。 &#xff08;2&#xff09;股价从2023年的最低点上涨了185%以上。 &#xff08;3&#xff09;随着智能手机的需求反弹和电动汽车利润率的增长&#xff0c;猛兽财经认为…

YOLOv10改进策略【注意力机制篇】| NAM 即插即用模块,重新优化通道和空间注意力(含二次创新)

一、本文介绍 本文记录的是基于NAM模块的YOLOv10目标检测改进方法研究。 许多先前的研究专注于通过注意力操作捕获显著特征&#xff0c;但缺乏对权重贡献因素的考虑&#xff0c;而这些因素能够进一步抑制不重要的通道或像素。而本文利用NAM改进YOLOv10&#xff0c;通过权重的贡…

数字人直播违规被“封”,一文助你彻底解决!

随着数字人直播的日渐兴起&#xff0c;与之相关的各类消息逐渐进入到人们的视野之中&#xff0c;并开始成为众多企业、创业者以及技术爱好者所重点关注的对象。就目前的讨论情况来看&#xff0c;热度最高且讨论次数最多的便是数字人直播违规吗这一话题。 的确&#xff0c;从数字…

一个three三维 文字 粒子 着色器的作品用来感谢大家对github点星

一个three三维 文字 粒子 着色器的作品用来感谢大家对github点星 源链接&#xff1a;https://z2586300277.github.io/three-cesium-examples/#/codeMirror?navigationThreeJS&classifyshader&idtextStarShader 国内站点预览&#xff1a;http://threehub.cn github地…

CVE-2024-9014 pgAdmin4 OAuth2 client ID与secret敏感信息泄漏漏洞

文章目录 免责声明漏洞描述搜索语法漏洞复现nuclei修复建议 免责声明 本文章仅供学习与交流&#xff0c;请勿用于非法用途&#xff0c;均由使用者本人负责&#xff0c;文章作者不为此承担任何责任 漏洞描述 pgAdmin4 是开源数据库 PostgreSQL 的图形管理工具攻击者可构造恶意…

向量数据库!AI 时代的变革者还是泡沫?

向量数据库&#xff01;AI 时代的变革者还是泡沫&#xff1f; 前言一、向量数据库的基本概念和原理二、向量数据库在AI中的应用场景三、向量数据库的优势和挑战四、向量数据库的发展现状和未来趋势五、向量数据库对AI发展的影响 前言 数据是 AI 的核心&#xff0c;而向量则是数…

一个设备不知道ip地址怎么办?应对策略来袭

在数字化时代&#xff0c;设备连接网络已成常态&#xff0c;IP地址作为设备的网络身份证&#xff0c;其重要性不言而喻。然而&#xff0c;面对设备IP地址遗失的困境&#xff0c;我们往往感到束手无策。 那么&#xff0c;一个设备不知道IP地址怎么办&#xff1f;本文将为你提供一…

中国通信技术革命史

文章目录 引言I 中国通信技术革命史电报中国卫星通信的历史固定电话寻呼机(BP机)大哥大(手机)制定自己的移动通信网络技术体系5G未来科技发展的总趋势:用更少的能量,传输、处理和存储更多的信息II 知识扩展通信史(单位能量的信息传输率越来越高,网络地不断融合。)超级智能…

秒杀系统的原则和注意项

做任何技术方案都需要结合当时的业务场景、资金情况、用户体量等维度综合考虑&#xff0c;没有最好的技术方案&#xff0c;只有最合适的技术方案。 做秒杀方案亦是如此&#xff0c;秒杀活动经常会引发高并发、系统宕机和库存超卖的棘手问题&#xff0c;作为开发者&#xff0c;我…

火情监测摄像机:守护生命与财产安全的“眼睛”

随着城市化进程的加快&#xff0c;火灾隐患日益增多。为了有效预防和及时应对火灾事故&#xff0c;火情监测摄像机应运而生&#xff0c;成为现代消防安全的重要组成部分。这种高科技设备不仅能够实时监控火灾发生&#xff0c;还能为救援提供宝贵的信息支持。火情监测摄像机主要…

vulnhub-THE PLANETS-EARTH靶机

下载并导入靶机至VMWare&#xff0c;设置网络模式为NAT&#xff0c;开机 开启攻击机&#xff08;kali&#xff09;&#xff0c;也设置为Nat模式&#xff0c;与靶机处于同一网段 扫描靶机ip Nmap 192.168.114.0/24 扫描网段内活跃的主机 可以推断靶机ip为192.168.114.129 扫描…

什么是源代码加密?十种方法教你软件开发源代码加密

什么是源代码加密 源代码加密是一种安全措施&#xff0c;它通过加密技术对软件的源代码进行保护&#xff0c;以防止未授权的访问、泄露、篡改或逆向工程。源代码是软件程序的原始代码&#xff0c;通常由程序员编写&#xff0c;然后编译成可执行程序。由于源代码包含了软件的设…