【Canvas与徽章】盾形银底红带Best Quality Premium徽章

news2024/11/23 1:46:16

【成图】

【代码】

<!DOCTYPE html>
<html lang="utf-8">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<head>
     <title>BestQulity金属牌Draft3</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=198;// 基准尺寸

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

        // 2圈
        ctx.save();
        var r=R*0.99;
        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();
        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();
        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.99;        
        var width=r/4*3.4;
        var gnt1=ctx.createLinearGradient(-width,0,width,0);
        gnt1.addColorStop(0,"rgb(111,1,2)");
        gnt1.addColorStop(0.1,"rgb(162,3,7)");
        gnt1.addColorStop(0.25,"rgb(182,2,4)");
        gnt1.addColorStop(0.5,"rgb(208,2,4)");
        gnt1.addColorStop(0.75,"rgb(182,2,4)");
        gnt1.addColorStop(0.9,"rgb(162,3,7)");
        gnt1.addColorStop(1,"rgb(111,1,2)");
        ctx.fillStyle=gnt1;
        drawRect(ctx,0,r/3,2*width,r/2);
        ctx.fill();
        ctx.restore();

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

        // 绘制五星
        ctx.save();
        var r=R*0.99;        
        var width=r/4*3.4;
        var margin=width/4;
        var n=5;
        var w=(2*width-2*margin)/(n-1);

        // 中间三星
        for(var i=-1;i<=1;i++){            
            var radius=r*0.15-Math.abs(i)*r/30;
            var a=createPt(i*w,r*0.77+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();
        }

        // 边上两星
        w*=0.9;
        for(var i=-2;i<=2;i+=4){            
            var radius=r*0.15-Math.abs(i)*r/30;
            var a=createPt(i*w,r*0.77+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:五角星中心纵坐标
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:盾牌中心纵坐标
radius:半径,即盾牌高度的一半
----------------------------------------------------------*/
function drawShield(ctx,x,y,radius){
    const R=radius;// 接参数
    const H=R;// 一半高度
    const H1=H/5;// 隆起高度
    const W=H/4*3.4;// 一半宽度
    const R1=R/20;// 小圆半径
    const R2=2.5*R1;// 大圆半径
    const ALPHA=Math.atan(H1/W);//隆起角度

    var a=createPt(x-W,y-H);
    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,y+H);
    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+H1);
    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,y+H);
    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,y-H);
    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:圆半径
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/2194198.html

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

相关文章

怎么成为年薪53万的AI产品经理?我分析了200份大厂的招聘要求

我在 BOSS 直聘搜索AI产品经理&#xff0c;筛选了公司规模在10000人以上的公司&#xff0c;清洗整理后得到 229 个岗位信息&#xff0c;分析得到如下信息&#xff1a; 按最低薪资算&#xff0c;平均年薪 40.2 万&#xff1b;取薪资范围均值&#xff0c;平均年薪 52.9 万;只有 …

判断两棵树是否相等

判断两棵树是否相等 两棵树是否相等的判断条件&#xff1a; 1. 树的结构一样 2. 对应节点存放的值相等 思路1&#xff1a; 首先对树的结果判断&#xff0c;若结构一样&#xff0c;则进行下一步节点中值的判断&#xff0c;若结构不一样&#xff0c;直接返回false 1.定义一个f…

C++ | Leetcode C++题解之第458题可怜的小猪

题目&#xff1a; 题解&#xff1a; class Solution { public:int poorPigs(int buckets, int minutesToDie, int minutesToTest) {if (buckets 1) {return 0;}vector<vector<int>> combinations(buckets 1,vector<int>(buckets 1));combinations[0][0] …

万字长文带你从底层到实战了解Python中的time模块,从基础到进阶让你轻松掌握时间管理

博客主页&#xff1a;长风清留扬-CSDN博客系列专栏&#xff1a;Python基础专栏每天更新大数据相关方面的技术&#xff0c;分享自己的实战工作经验和学习总结&#xff0c;尽量帮助大家解决更多问题和学习更多新知识&#xff0c;欢迎评论区分享自己的看法感谢大家点赞&#x1f44…

图解Linux文件属性与目录配置

Linux的文件属性十分重要&#xff0c;与windows的文件属性有很大不同&#xff0c;Linux的文件增加了许多属性&#xff0c;如读写、连接数、文件拥有者及所属群组。如果一个文件属于一个群组&#xff0c;那么这个群组的成员就可以访问&#xff0c;其他的群组就不能访问&#xff…

Qt中的网络客户端

目录 HttpClient http报文相关 HttpClient发送报文格式 x-www-form-urlencoded: multipart/form-data raw binary QUrl QNetworkAccessManager Http-Get Http-Post http-post:form-data ftp-up ftp-down QDesktopServices HttpClient http报文相关 URL是为了 统…

人机协作:科技与人类智慧的融合

随着科技的飞速发展&#xff0c;越来越多的领域开始借助人工智能&#xff08;AI&#xff09;和自动化技术来提升工作效率。人机协作&#xff08;Human-Machine Collaboration&#xff09;这一概念逐渐成为现代技术进步的核心。它不仅改变了我们的工作方式&#xff0c;也在重新定…

【STL】stack模拟实现

stack模拟实现比较简单&#xff0c;就是直接调用deque的函数即可。 具体实现&#xff1a; #pragma once#include<deque> #include<iostream>using std::istream; using std::ostream; using std::endl; using std::cout;namespace zyy { //stack -> 后进先出t…

python log函数怎么用

log() 返回 x 的自然对数。 语法 以下是 log() 方法的语法&#xff1a; import math math.log(x[, base]) 注意&#xff1a;log()是不能直接访问的&#xff0c;需要导入 math 模块&#xff0c;通过静态对象调用该方法。 参数 x -- 数值表达式。 base -- 可选&#xff0c;底…

‌图片编辑为底片,智能工具助力,创作精彩视觉作品

在当今数字化时代&#xff0c;图像编辑已成为表达创意和美化视觉作品的重要手段。借助智能工具&#xff0c;即使是初学者也能轻松驾驭图片编辑。接下为大家展示图片编辑为底片图片的效果。 1.打开“首助编辑高手”&#xff0c;选择这里“图片批量处理”版块页面上 2.导入保存有…

C语言之三子棋游戏(附完整代码)

学了那么多关于C语言的知识&#xff0c;也该进行一下实操了。三子棋游戏应该是大家学生时代课间比较喜欢娱乐消遣的一种方式吧。那么我们今天就来说说如何实现简单版本的三子棋对战小游戏吧。 三子棋游戏介绍 三子棋游戏类似于五子棋&#xff0c;不同的是它的棋盘大小是九宫格…

LLM | Ollama 安装、运行大模型(CPU 实操版)

1. 操作步骤 1.1 安装 # 通过 homebrew 安装 brew install ollama1.2 验证&#xff08;可跳过&#xff09; # 输出命令使用提示则安装成功 ollama --help1.3 启动服务端 # 启动 ollama 服务&#xff08;默认在 11434 端口&#xff0c;模型文件在 ~/.ollama&#xff09; oll…

论文阅读笔记-Pre-trained Models for Natural Language Processing: A Survey

前言 预训练模型给下游任务带来的效果不言而喻,有了预训练模型,我们可以使用它来加速解决问题的过程。正如论文中所说的那样,预训练模型(PTMs)的出现将自然语言处理(NLP)带入了一个新时代。本篇论文基于分类从四个角度对现有PTMs进行系统分类,描述如何使PTMs的知识适应…

Spring源码学习:SpringMVC(4)DispatcherServlet请求入口分析

目录 前言HttpServlet &FrameworkServletHttpServlet #serviceFrameworkServlet#processRequest DispatcherServlet#doServicedoDispatchcheckMultipartgetHandlerAbstractHandlerMapping#getHandlerRequestMappingInfoHandlerMapping#getHandlerInternalAbstractHandlerMe…

Excel-查找和引用数据-VLOOKUP 和 HLOOKUP 函数

在 Excel 中&#xff0c;VLOOKUP 和 HLOOKUP 是用于查找和引用数据的函数。下面是它们的基本用法&#xff1a; VLOOKUP 用途&#xff1a;在表格的第一列中查找某个值&#xff0c;并返回该值所在行的指定列中的数据。 语法&#xff1a; VLOOKUP(lookup_value, table_array, …

多模态大语言模型(MLLM)-Blip2深度解读

前言 Blip2是一个多模态大语言模型&#xff0c;因其提出时间较早&#xff08;2023年&#xff09;&#xff0c;且效果较好&#xff0c;很快成为一个标杆性工作。Blip2中提出的Q-former也成为衔接多模态和文本的重要桥梁。 Blip2发表时间是2023年&#xff0c;现在引用已经3288了…

产品经理内容分享(一):AI产品经理需必备那些能力

目录 必备的AI技术知识 第一章&#xff1a;AI产品经理是否需要懂技术及其程度 第二章&#xff1a;AI产品经理必备的AI技术基础知识——基础算法与机器学习方法 第三章&#xff1a;AI产品经理必须要懂的AI技术知识——场景应用 第四章&#xff1a;AI算法与模型的关系 第五…

PhotoMaker部署文档

一、介绍 PhotoMaker&#xff1a;一种高效的、个性化的文本转图像生成方法&#xff0c;能通过堆叠 ID 嵌入自定义逼真的人类照片。相当于把一张人的照片特征提取出来&#xff0c;然后可以生成你想要的不同风格照片&#xff0c;如写真等等。 主要特点&#xff1a; 在几秒钟内…

求1000以内的完数

题目&#xff1a;一个数如果恰好等于他的因子之和&#xff08;包括1&#xff0c;但不包括这个数&#xff09;&#xff0c;这个数就是完数。编写算法找出1000之内的所有完数&#xff0c;并按下面格式输出其因子&#xff1a;28 its factors are 1,2,4,7,14 代码如下&#xff1a;…

Dell服务器电源配置

Dell服务器电源配置规则 PowerEdge 电源设置