【Canvas与诗词】要做一棵树,站成永恒

【成图】

【代码】

<!DOCTYPE html>
<html lang="utf-8">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<head><title>要做一棵树站成永恒</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;// 基准尺寸// 金外圈ctx.save();    var r=R*1.00;ctx.shadowOffsetX=r/30;ctx.shadowOffsetY=r/30;ctx.shadowColor="grey";ctx.shadowBlur=6;        var gdntGeneral=ctx.createLinearGradient(-r,-r,r,r);// 整体渐变色gdntGeneral.addColorStop(0,"rgb(234,221,153)");gdntGeneral.addColorStop(1,"rgb(86,67,16)");ctx.fillStyle=gdntGeneral;drawRoundSixPolygon(ctx,0,0,r,R/20);ctx.fill();ctx.restore();// 内凹圈ctx.save();    var r=R*0.96;var gnt2=ctx.createLinearGradient(-r,-r,r,r);gnt2.addColorStop(0,"rgb(86,67,16)");gnt2.addColorStop(1,"rgb(234,221,153)");ctx.fillStyle=gnt2;drawRoundSixPolygon(ctx,0,0,r,R/20);ctx.fill();ctx.restore();// 奶白底ctx.save();    var r=R*0.94;var gnt1=ctx.createLinearGradient(-r,-r,r,r);gnt1.addColorStop(0,"rgb(255,252,236)");gnt1.addColorStop(1,"rgb(177,161,140)");ctx.fillStyle=gnt1;drawRoundSixPolygon(ctx,0,0,r,R/20);ctx.fill();ctx.restore();    // 诗词ctx.save();    var r=R*0.94;var color="black";// 诗歌正文var start=createPt(0,-r/1.5);var gap=r/4.5;var sz=R/7.6;writeText(ctx,start.x,start.y,"要做一棵树",sz+"px 方正宋刻本秀楷简体",color);writeText(ctx,start.x,start.y+gap,"站成永恒",sz+"px 方正宋刻本秀楷简体",color);writeText(ctx,start.x,start.y+2*gap,"没有悲欢的姿势",sz+"px 方正宋刻本秀楷简体",color);writeText(ctx,start.x,start.y+3*gap, "一半在尘土里安详",sz+"px 方正宋刻本秀楷简体",color);writeText(ctx,start.x,start.y+4*gap,"一半在风里飞扬",sz+"px 方正宋刻本秀楷简体",color);writeText(ctx,start.x,start.y+5*gap,"一半洒落荫凉",sz+"px 方正宋刻本秀楷简体",color);writeText(ctx,start.x,start.y+6*gap,"一半沐浴阳光",sz+"px 方正宋刻本秀楷简体",color);ctx.restore();// 中间色带ctx.save();    var r=R*0.92;drawRoundSixPolygon(ctx,0,0,r,R/20);ctx.clip();ctx.rotate(Math.PI/3);const W=r/9;// 被剪切的图形const G=W;var colors=["rgba(229,56,48,0.3)","rgba(244,155,48,0.3)","rgba(255,231,35,0.3)",        "rgba(90,143,60,0.3)","rgba(39,140,192,0.3)","rgba(62,58,122,0.3)","rgba(120,75,116,0.3)","rgba(0,0,255,0.3)",];for(var i=0;i<4;i++){var idx=+i;var x=G/2+W/2+i*(G+W);var y=0;var w=W;var h=5.5*r;ctx.fillStyle=colors[4-i-1];drawRect(ctx,x,y,w,h);ctx.fill();var idx=-i;var x=-G/2-W/2-i*(G+W);var y=0;var w=W;var h=5.5*r;ctx.fillStyle=colors[4+i+1];drawRect(ctx,x,y,w,h);ctx.fill();}ctx.restore();writeText(ctx,WIDTH/2-30,HEIGHT/2-5,"逆火制图","8px consolas","lightgrey");// 版权}
}/*----------------------------------------------------------
函数:用于绘制矩形
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();
}/*----------------------------------------------------------
函数:绘制正多边形
n:正多边形的边数
x:正多边形中心的横坐标
y:正多边形中心的纵坐标
r:正多边形中心到顶点的距离
----------------------------------------------------------*/
function drawPolygon(ctx,n,x,y,r){var polyArr=[];for(var i=0;i<n;i++){var theta=Math.PI*2/n*i+Math.PI/6;var pt={};pt.x=r*Math.cos(theta)+x;pt.y=r*Math.sin(theta)+y;polyArr.push(pt);}ctx.beginPath();for(let i=0;i<polyArr.length;i++){ctx.lineTo(polyArr[i].x,polyArr[i].y);}ctx.closePath();
}/*----------------------------------------------------------
函数:用于绘制圆角六边形
ctx:绘图上下文
x:六边形中心横坐标
y:六边形中心纵坐标
R:六边形半径
r:圆角半径
----------------------------------------------------------*/
function drawRoundSixPolygon(ctx,x,y,R,r){// 取点const N=6;// 六边形边数const ROUND=r;// 圆角半径var arr=[];// 放顶点三点的数组for(var i=0;i<N;i++){var theta=Math.PI*2/N*i-Math.PI/6;var r=R;var a=createPt(x+r*Math.cos(theta),y+r*Math.sin(theta));r=ROUND/Math.sqrt(3);var angle=theta+Math.PI/3*2;var c=createPt(a.x+r*Math.cos(angle),a.y+r*Math.sin(angle));r=ROUND/Math.sqrt(3);angle=theta-Math.PI/3*2;var b=createPt(a.x+r*Math.cos(angle),a.y+r*Math.sin(angle));var arrInner=[b,a,c];arr.push(arrInner);}// 绘图ctx.save();ctx.beginPath();for(var i=0;i<arr.length;i++){var b=arr[i][0];var a=arr[i][1];var c=arr[i][2];ctx.lineTo(b.x,b.y);ctx.quadraticCurveTo(a.x,a.y,c.x,c.y);ctx.lineTo(c.x,c.y);}ctx.closePath();ctx.restore();
}/*----------------------------------------------------------
函数:用于绘制实心圆,用途是标记点以辅助作图
ctx:绘图上下文
x:矩形中心横坐标
y:矩形中心纵坐标
r:圆半径
color:填充圆的颜色
----------------------------------------------------------*/
function drawSolidCircle(ctx,x,y,r,color){ctx.fillStyle=color;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="middle";ctx.textAlign="center";ctx.font = font;ctx.fillStyle=color;ctx.fillText(text,x,y);ctx.restore();
}/*-------------------------------------------------------------
以下转载自https://www.thepaper.cn/newsDetail_forward_25790971
如果有来生文/三毛如果有来生,要做一棵树,站成永恒。没有悲欢的姿势,一半在尘土里安详,一半在风里飞扬;一半洒落荫凉,一半沐浴阳光。非常沉默、非常骄傲。从不依靠、从不寻找。如果有来生,要化成一阵风,一瞬间也能成为永恒。没有善感的情怀,没有多情的眼睛。一半在雨里洒脱,一半在春光里旅行;寂寞了,孤自去远行,把淡淡的思念统统带走,从不思念、从不爱恋;如果有来生,要做一只鸟,飞越永恒,没有迷途的苦恼。东方有火红的希望,南方有温暖的巢床,向西逐退残阳,向北唤醒芬芳。如果有来生,希望每次相遇,都能化为永恒。
--------------------------------------------------------------*/
//-->
</script>

END

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

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

相关文章

tauri开发Mac电脑Safari浏览器一个很奇怪的问题:在 input 输入框输入的是全小写英文字母,会自动将首字母转换为大写解决办法

问题原因 在 Mac 系统中默认使用 Safari 的内核 WKWebView 作为渲染引擎&#xff0c;而 Safari 浏览器的一些 “人性化” 机制&#xff1a;如果输入框中输入的是全小写英文&#xff0c;会自动将首字母转换为大写。 解决办法 我只需要禁止这个默认的行为&#xff0c;即可解决这…

STM32(十八):实时时钟

时间戳 Unix 时间戳&#xff08;Unix Timestamp&#xff09;定义为从UTC/GMT的1970年1月1日0时0分0秒开始所经过的秒数&#xff0c;不考虑闰秒。 时间戳存储在一个秒计数器中&#xff0c;秒计数器为32位/64位的整型变量。 世界上所有时区的秒计数器相同&#xff0c;不同时…

项目_C_Ncurses_Flappy bird小游戏

Ncurses库 概述 什么是Ncurses库&#xff1a; Ncurses是一个管理应用程序在字符终端显示的函数库&#xff0c;库中提供了创建窗口界面、移动光标、产生颜色、处理键盘按键等功能。 安装Ncurses库&#xff1a; sudo apt-get install libncurses5-dev 头文件与编译&#xf…

ECCV`24 | 新加坡国立华为提出Vista3D: 实现快速且多视角一致的3D生成

文章链接&#xff1a;https://arxiv.org/pdf/2409.12193 gitbub链接&#xff1a;https://github.com/florinshen/Vista3D 亮点直击 提出了Vista3D&#xff0c;一个用于揭示单张图像3D darkside 的框架&#xff0c;能够高效地利用2D先验生成多样的3D物体。开发了一种从高斯投影到…

初级学习:Python实现AI并搭建

随着人工智能(AI)的迅猛发展,越来越多的人希望能够学习如何通过编程实现AI应用。Python,因为其简洁易用,被广泛认为是AI开发的理想编程语言。本文将介绍Python在AI开发中的基础应用,帮助初学者入门并构建自己的AI项目。 为什么选择Python 在了解如何用Python实现AI之前,…

十、kotlin的协程

协程 基本概念定义组成挂起和恢复结构化并发协程构建器作用域构建器挂起函数阻塞与非阻塞runBlocking全局协程像守护线程 Job的生命周期 常用函数延时和等待启动和取消启动取消 暂停 协程启动调度器启动方式启动模式线程上下文继承的定义继承的公式 协程取消与超时取消挂起点取…

HTMLCSS练习

1) 效果如下 2) 代码如下 2.1) HTML <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" conte…

Windows系统编程(三)线程并发

进程与线程 进程&#xff1a;直观的说就是任务管理器中各种正在运行的程序。对于操作系统来说&#xff0c;进程仅仅是一个数据结构&#xff0c;并不会真实的执行代码 线程&#xff1a;通常被称作但并不真的是轻量级进程或实际工作中的进程&#xff0c;它会真实的执行代码。每…

设计模式之适配器模式(Adapter)

一、适配器模式介绍 适配器模式(adapter pattern )的原始定义是&#xff1a;将类的接口转换为客户期望的另一个接口&#xff0c; 适配器可以让不兼容的两个类一起协同工作。 适配器模式是用来做适配&#xff0c;它将不兼容的接口转换为可兼容的接口&#xff0c;让原本由于接口…

2024年1月Java项目开发指南18:自定义异常输出

一般情况下&#xff0c;报错信息一大堆&#xff0c;值得注意的只有三个地方&#xff1a; 哪个文件发生了错误哪一行发生了错误错误原因是什么 只要知道这三个东西就能快速的定位到错误发生的位置并且根据提示解决。 如果你也喜欢我的这种异常输出(如文章顶部图) 那么可以参考以…

[M数学] lc3164. 优质数对的总数 II(因数分解+倍增+推公式+思维+好题)

文章目录 1. 题目来源2. 题目解析 1. 题目来源 链接&#xff1a;3164. 优质数对的总数 II 2. 题目解析 挺不错的一道 因数分解、倍增 的题目&#xff0c;需要一定的思维和推公式的能力才能解决。灵神的题解已经非常清晰易懂了&#xff0c;可以直接去看。 倍增思路&#xff…

大数据分析案例-基于逻辑回归算法构建抑郁非抑郁推文识别模型

🤵‍♂️ 个人主页:@艾派森的个人主页 ✍🏻作者简介:Python学习者 🐋 希望大家多多支持,我们一起进步!😄 如果文章对你有帮助的话, 欢迎评论 💬点赞👍🏻 收藏 📂加关注+ 喜欢大数据分析项目的小伙伴,希望可以多多支持该系列的其他文章 大数据分析案例合集

(十八)、登陆 k8s 的 kubernetes-dashboard 更多可视化工具

文章目录 1、回顾 k8s 的安装2、确认 k8s 运行状态3、通过 token 登陆3.1、使用现有的用户登陆3.2、新加用户登陆 4、k8s 可视化工具 1、回顾 k8s 的安装 Mac 安装k8s 2、确认 k8s 运行状态 kubectl proxy kubectl cluster-info kubectl get pods -n kubernetes-dashboard3、…

如何启动一个OpenSearch

创建两个集群&#xff0c;标注 不含备用节点 选择集群版本和配置集群版本 冷热存储和专用主节点这个按需开启 然后是网络&#xff0c;是否使用自定义域名&#xff0c;集群开在VPC还是公网上。 选择是否开启认证&#xff1a; 访问策略&#xff0c;其实就是资源策略 维护时段…

Oracle 数据库安装和配置详解

Oracle 数据库安装和配置详解 Oracle 数据库是一款功能强大、广泛使用的企业级关系数据库管理系统 (RDBMS)&#xff0c;适用于处理大型数据库和复杂事务。本文将介绍如何在 Linux 和 Windows 环境下安装 Oracle 数据库&#xff0c;并对其进行基本配置&#xff0c;帮助开发者快…

理解计算机系统_程序的机器级表示(特别篇):对比move和leaq看汇编语言中数据的传递,变量和指针的映射,指针的实现

前言 以<深入理解计算机系统>(以下称“本书”)内容为基础&#xff0c;对程序的整个过程进行梳理。本书内容对整个计算机系统做了系统性导引,每部分内容都是单独的一门课.学习深度根据自己需要来定 引入 汇编代码传递数据的机制令人费解.而这部分内容又是比较基础的,需要…

实例详解 | 借助 Langchain 和 Gemma 2 构建 RAG 应用

本文原作者&#xff1a;Connie Leung&#xff0c;谷歌开发者专家 (GDE)&#xff0c;原文发布于&#xff1a;DEV Community https://dev.to/railsstudent/build-a-rag-application-to-learn-angular-using-langchhtainjs-nestjs-htmx-and-gemma-2-5ggk 本文将为您介绍如何使用…

.Net基础1

.NET框架 项目结构 Connected Services是第三方服务MVC框架appsettings.json配置文件Program.cs控制台应用程序Properties里的json文件是配置启动方式 1. 基本开发 出现这个bug是因为防火墙没有把浏览器加入白名单&#xff0c;可以暂时先用http启动代替 第一步创建控制器&am…

数字化AI新赋能,智享AI直播:开启一个全新的直播时代!

数字化AI新赋能&#xff0c;智享AI直播&#xff1a;开启一个全新的直播时代! 在科技日新月异的今天&#xff0c;人工智能&#xff08;AI&#xff09;技术正以前所未有的速度改变着我们的生活和工作方式。其中&#xff0c;AI直播技术的崛起&#xff0c;无疑是数字化时代的一大亮…

深入理解 C/C++ 指针

深入理解 C 指针&#xff1a;指针、解引用与指针变量的详细解析 前言 在 C 编程语言中&#xff0c;指针 是一个非常强大且重要的概念。对于初学者来说&#xff0c;指针往往会让人感到困惑不解。本文将通过形象的比喻&#xff0c;帮助大家深入理解指针、解引用与指针变量的概念…