详解如何用canvas画一个微笑的表情


Posted in HTML / CSS onMarch 14, 2019

实习期间让我用canvas画一个表情,比较简单,话不多说直接上代码:

<body>

<div id="canvas-warp">
    <canvas id="canvas" style="display: block; margin: 200px auto;">
        你的浏览器居然不支持Canvas!
    </canvas>
</div>
<script>
    window.onload = function () {
        var canvas = document.getElementById("canvas");
        canvas.width = 400;
        canvas.height = 400;
        //获取上下文
        var context = canvas.getContext("2d");
        //用于画有填充色圆的函数  参数分别为圆心坐标 ,半径,起始与终止位置,线颜色,填充颜色
        function drawCircle(x2, y2, r2, a2, b2, lineColor, FillColor) {
            context.beginPath();
            context.arc(x2, y2, r2, a2, b2 * Math.PI);
            context.strokeStyle = lineColor;
            context.fillStyle = FillColor;
            context.fill(); //确认填充
            context.stroke();
        };
        //用于画圆弧函数 默认线条为黑色 无填充 参数分别为:圆心x坐标,圆心y坐标,半径,开始位置,终止位置
        function drawsArc(x, y, r, l1, l2) {
            context.beginPath();
            context.arc(x, y, r, l1 * Math.PI, l2 * Math.PI);
            context.strokeStyle = "black";
            context.stroke();
        };
        //用于画眼睛的函数
        function darwEyes(x1, y1, a1, b1) { //参数分别为椭圆圆心位置 长轴  短轴
            context.strokeStyle = "#754924"
            ParamEllipse(context, x1, y1, a1, b1); //椭圆
            function ParamEllipse(context, x, y, a, b) {
                //使每次循环所绘制的路径(弧线)接近1像素
                var step = (a > b) ? 1 / a : 1 / b;
                context.beginPath();
                context.moveTo(x + a, y); //从椭圆的左端点开始绘制
                for (var i = 0; i < 2 * Math.PI; i += step) {
                    //参数为i,表示度数(弧度)
                    context.lineTo(x + a * Math.cos(i), y + b * Math.sin(i));
                }
                context.closePath();
                context.fillStyle = "#754924";
                context.fill(); 
                context.stroke();
            };
        };
        //脸
        drawCircle(200, 200, 200, 0, 2, "#EEE685", "#FCF200");
        //左眼
        context.strokeStyle = "#754924"
        darwEyes(116, 130, 18, 25);
        drawCircle(110, 127, 12, 0, 2, "#754924", "#F5F5F5");
        //右眼
        darwEyes(296, 130, 18, 25);
        drawCircle(290, 127, 12, 0, 2, "#754924", "#F5F5F5");
        //左眉毛
        drawsArc(100, 100, 50, 1.3, 1.7);
        //右眉毛
        drawsArc(300, 100, 50, 1.3, 1.7);
        //嘴巴
        drawsArc(200, 120, 180, 0.3, 0.7);
    }
</script>
</body>

效果图

详解如何用canvas画一个微笑的表情

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
CSS3中的元素过渡属性transition示例详解
Nov 30 HTML / CSS
利用CSS3 动画 绘画 圆形动态时钟
Mar 20 HTML / CSS
CSS3实现线性渐变用法示例代码详解
Aug 07 HTML / CSS
详解Html5中video标签那些属性和方法
Jul 01 HTML / CSS
html5 Canvas绘制线条 closePath()实例代码
May 10 HTML / CSS
突袭HTML5之Javascript API扩展3—本地存储全新体验
Jan 31 HTML / CSS
Html5新特性用canvas标签画多条直线附效果截图
Jun 30 HTML / CSS
详解HTML5之pushstate、popstate操作history,无刷新改变当前url
Mar 15 HTML / CSS
HTML5页面中尝试调起APP功能
Sep 12 HTML / CSS
HTML5添加禁止缩放功能
Nov 03 HTML / CSS
Canvas多边形绘制的实现方法
Aug 05 HTML / CSS
HTML5超炫酷粒子效果的进度条的实现示例
Aug 23 HTML / CSS
使用html2canvas将页面转成图并使用用canvas2image下载
Apr 04 #HTML / CSS
5分钟弄清楚html5的drag and drop(小结)
Apr 10 #HTML / CSS
canvas画布实现手写签名效果的示例代码
Apr 23 #HTML / CSS
HTML5网页录音和上传到服务器支持PC、Android,支持IOS微信功能
Apr 26 #HTML / CSS
html5中监听canvas内部元素点击事件的三种方法
Apr 28 #HTML / CSS
Html5实现单张、多张图片上传功能
Apr 28 #HTML / CSS
鲜为人知的HTML5语音合成功能
May 17 #HTML / CSS
You might like
PHP中预定义的6种接口介绍
2015/05/12 PHP
PHP7.0版本备注
2015/07/23 PHP
最准确的php截取字符串长度函数
2015/10/29 PHP
PHP数据库操作四:mongodb用法分析
2017/08/16 PHP
PHP实现浏览器中直接输出图片的方法示例
2018/03/14 PHP
php swoft框架实例用法
2020/12/22 PHP
HTML TO JavaScript 转换
2006/06/26 Javascript
解析js原生方法创建表格效率测试
2013/07/08 Javascript
理解javascript函数式编程中的闭包(closure)
2016/03/08 Javascript
sencha ext js 6 快速入门(必看)
2016/06/01 Javascript
JavaScript中捕获与冒泡详解及实例
2017/02/03 Javascript
linux 后台运行node服务指令方法
2018/05/23 Javascript
javascript 对象 与 prototype 原型用法实例分析
2019/11/11 Javascript
Vue组件通信$attrs、$listeners实现原理解析
2020/09/03 Javascript
Python中的匿名函数使用简介
2015/04/27 Python
Python中的类与类型示例详解
2019/07/10 Python
详解Python Qt的窗体开发的基本操作
2019/07/14 Python
Pytorch evaluation每次运行结果不同的解决
2020/01/02 Python
python图形开发GUI库pyqt5的基本使用方法详解
2020/02/14 Python
解决windows下python3使用multiprocessing.Pool出现的问题
2020/04/08 Python
Python 保存加载mat格式文件的示例代码
2020/08/04 Python
python爬取代理ip的示例
2020/12/18 Python
美赞臣营养马来西亚旗舰店:Enfagrow马来西亚
2019/07/26 全球购物
以下为Windows NT 下的32 位C++程序,请计算sizeof 的值
2016/12/07 面试题
行政助理的职责
2013/11/14 职场文书
作弊检讨书1000字
2014/02/01 职场文书
历史学专业求职信
2014/06/19 职场文书
工作求职信
2014/07/04 职场文书
土建施工员岗位职责
2014/07/16 职场文书
高中生学习计划书
2014/09/15 职场文书
房屋过户委托书范本
2014/10/07 职场文书
派出所副所长四风问题个人整改措施思想汇报
2014/10/13 职场文书
员工工作心得体会
2019/05/07 职场文书
navicat 连接Ubuntu虚拟机的mysql的操作方法
2022/04/02 MySQL
讲解Python实例练习逆序输出字符串
2022/05/06 Python
Redis批量生成数据的实现
2022/06/05 Redis