canvas绘制一个常用的emoji表情

发布时间 - 2026-01-11 00:26:56    点击率:

效果图:

代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta http-equiv="X-UA-Compatible" content="IE=edge">
 <title>表情</title>
 <meta name="viewport" content="initial-scale=1, maximum-scale=1">
 <meta name="apple-mobile-web-app-capable" content="yes">
 <meta name="apple-mobile-web-app-status-bar-style" content="black">
</head>
<style type="text/css">
 *{
 margin: 0;
 padding: 0;
 }
 body{
  overflow:hidden;
 }
 canvas{
 /*background: #000;*/
 /*opacity: 0.5;*/
 }
</style>
<body>
 <canvas id="canvas"></canvas>
</body>
<script type="text/javascript">
(function(win,el){
 var canvas = document.querySelector(el),
 ctx = canvas.getContext('2d');
 canvas.width = win.innerWidth;
 canvas.height = win.innerHeight;

 ctx.translate(canvas.width/2,canvas.height/2);//将画布移到屏幕中心

 // 绘制圆形头部
 ctx.beginPath();
 var grd=ctx.createLinearGradient(0,-100,0,100);
 grd.addColorStop(0,'#FDF390');
 grd.addColorStop(1,'#B97814');

 ctx.fillStyle = grd;
 ctx.strokeStyle = '#A86B14';
 ctx.lineWidth = 5;
 ctx.arc(0,0,100,0,2*Math.PI);
 ctx.fill();
 ctx.stroke();

 //嘴巴
 ctx.beginPath();
 ctx.lineCap = 'round';
 ctx.lineJoin = 'round';
 ctx.fillStyle = '#754800';
 ctx.strokeStyle = '#935B06';
 ctx.moveTo(-63,-2);
 ctx.quadraticCurveTo(-37,90,49,46);
 ctx.lineTo(-63,-2);
 ctx.fill();
 ctx.stroke();

 // 牙齿
 ctx.beginPath();
 ctx.lineWidth = 8;
 ctx.strokeStyle = '#FFF';
 ctx.moveTo(-58,6);
 ctx.lineTo(38,47);
 ctx.stroke();

 // 眼泪左
 ctx.beginPath();
 var yanlei = ctx.createLinearGradient(-48,-48,-97,30);
 yanlei.addColorStop(0,'#90C1C8');
 yanlei.addColorStop(1,'#5394C8');

 var yanleib = ctx.createLinearGradient(-48,-48,-97,30);
 yanleib.addColorStop(0,'#7CAEA7');
 yanleib.addColorStop(1,'#245F6A');

 ctx.strokeStyle = yanleib;
 ctx.fillStyle = yanlei;
 ctx.moveTo(-56,-37);
 ctx.lineTo(-96,25);
 ctx.quadraticCurveTo(-90,50,-82,56);
 ctx.lineTo(-29,-27);
 ctx.stroke();
 ctx.fill();

 // 眼泪右
 ctx.beginPath();
 var yanlei = ctx.createLinearGradient(-48,-48,-97,30);
 yanlei.addColorStop(0,'#90C1C8');
 yanlei.addColorStop(1,'#5394C8');
 ctx.strokeStyle = yanleib;
 ctx.fillStyle = yanlei;
 ctx.moveTo(33,35);
 ctx.lineTo(34,91);
 ctx.quadraticCurveTo(55,88,55,78);
 ctx.lineTo(53,44);
 ctx.stroke();
 ctx.fill();

 // 眼睛
 ctx.beginPath();
 ctx.lineJoin = 'round';
 ctx.lineCap = 'round';
 ctx.lineWidth = 5;
 ctx.fillStyle = '#714801';
 ctx.strokeStyle = '#714801'
 ctx.moveTo(-58,-39);
 ctx.quadraticCurveTo(-32,-41,-25,-27);
 ctx.quadraticCurveTo(-42,-36,-58,-39);
 ctx.fill();
 ctx.stroke();

 // 麒麟臂
 ctx.beginPath();
 var qlgrd=ctx.createRadialGradient(30,-19,5,30,-19,60);
 qlgrd.addColorStop(0,'#F7D25F');
 qlgrd.addColorStop(1,'#EEB63B');

 ctx.lineWidth = 5;
 ctx.strokeStyle = '#CE7F12';
 ctx.fillStyle = qlgrd;
 ctx.moveTo(78,87);
 ctx.quadraticCurveTo(100,74,81,-19);
 ctx.quadraticCurveTo(68,-45,49,-39);
 ctx.quadraticCurveTo(59,-35,59,-26);
 ctx.quadraticCurveTo(36,-62,-10,-59);
 ctx.quadraticCurveTo(-14,-55,-9,-50);
 ctx.quadraticCurveTo(18,-48,33,-26);
 ctx.quadraticCurveTo(0,-54,-28,-48);
 ctx.quadraticCurveTo(-37,-42,-28,-33);
 ctx.quadraticCurveTo(-1,-37,19,-15);
 ctx.quadraticCurveTo(-5,-37,-34,-28);
 ctx.quadraticCurveTo(-36,-21,-27,-18);
 ctx.quadraticCurveTo(-13,-17,11,2);
 ctx.quadraticCurveTo(-10,-15,-27,-11);
 ctx.quadraticCurveTo(-30,-6,-24,1);

 ctx.lineTo(1,12);
 ctx.quadraticCurveTo(7,29,41,42);
 ctx.quadraticCurveTo(43,63,52,81);
 ctx.quadraticCurveTo(64,92,78,87);
 ctx.stroke();
 ctx.fill();

})(window,'#canvas')
</script>
</html>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!


# canvas emoji  # canvas 绘制图片  # 移到  # win  # el  # javascript  # function  # getContext  # querySelector  # ctx  # var  # document  # script  # hidden  # canvas  # overflow  # padding  # body  # id  # opacity  # background  # strokeStyle 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251811 】 【 AI营销90571


相关推荐: 百度浏览器网页无法复制文字怎么办 百度浏览器复制修复  Laravel Eloquent访问器与修改器是什么_Laravel Accessors & Mutators数据处理技巧  Laravel 419 page expired怎么解决_Laravel CSRF令牌过期处理  Java遍历集合的三种方式  使用PHP下载CSS文件中的所有图片【几行代码即可实现】  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  Laravel如何使用Telescope进行调试?(安装和使用教程)  Laravel怎么实现前端Toast弹窗提示_Laravel Session闪存数据Flash传递给前端【方法】  Laravel中的withCount方法怎么高效统计关联模型数量  Laravel如何配置和使用缓存?(Redis代码示例)  Win11怎么更改系统语言为中文_Windows11安装语言包并设为显示语言  javascript中的数组方法有哪些_如何利用数组方法简化数据处理  如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?  Laravel Seeder怎么填充数据_Laravel数据库填充器的使用方法与技巧  html文件怎么打开证书错误_https协议的html打开提示不安全【指南】  百度输入法全感官ai怎么关 百度输入法全感官皮肤关闭  HTML5空格在Angular项目里怎么处理_Angular中空格的渲染问题【详解】  潮流网站制作头像软件下载,适合母子的网名有哪些?  如何为不同团队 ID 动态生成多个非值班状态按钮  实例解析Array和String方法  公司网站制作需要多少钱,找人做公司网站需要多少钱?  Laravel怎么使用artisan命令缓存配置和视图  LinuxCD持续部署教程_自动发布与回滚机制  Laravel怎么在Blade中安全地输出原始HTML内容  Bootstrap整体框架之JavaScript插件架构  如何在万网主机上快速搭建网站?  VIVO手机上del键无效OnKeyListener不响应的原因及解决方法  晋江文学城电脑版官网 晋江文学城网页版直接进入  网页制作模板网站推荐,网页设计海报之类的素材哪里好?  Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲  微博html5版本怎么弄发语音微博_语音录制入口及时长限制操作【教程】  今日头条AI怎样推荐抢票工具_今日头条AI抢票工具推荐算法与筛选【技巧】  js实现点击每个li节点,都弹出其文本值及修改  Laravel Fortify是什么,和Jetstream有什么关系  Claude怎样写结构化提示词_Claude结构化提示词写法【教程】  Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】  Laravel如何配置任务调度?(Cron Job示例)  原生JS实现图片轮播切换效果  phpredis提高消息队列的实时性方法(推荐)  如何在VPS电脑上快速搭建网站?  rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted  如何为不同团队 ID 动态生成多个“认领值班”按钮  Laravel如何实现一对一模型关联?(Eloquent示例)  Laravel Blade模板引擎语法_Laravel Blade布局继承用法  如何挑选优质建站一级代理提升网站排名?  Laravel怎么做缓存_Laravel Cache系统提升应用速度的策略与技巧  什么是JavaScript解构赋值_解构赋值有哪些实用技巧  ,在苏州找工作,上哪个网站比较好?  如何在IIS7上新建站点并设置安全权限?  Python自动化办公教程_ExcelWordPDF批量处理案例