详解如何用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实战第一波 让我们尽情的圆角吧
Aug 27 HTML / CSS
CSS3 制作旋转的大风车(充满童年回忆)
Jan 30 HTML / CSS
详解CSS3阴影 box-shadow的使用和技巧总结
Dec 03 HTML / CSS
利用CSS3伪元素实现逐渐发光的方格边框
May 07 HTML / CSS
利用 CSS3 实现的无缝轮播功能代码
Sep 25 HTML / CSS
使用CSS变量实现炫酷惊人的悬浮效果
Apr 26 HTML / CSS
网页中的电话号码如何实现一键直呼效果_附示例
Mar 15 HTML / CSS
canvas使用注意点总结
Jul 19 HTML / CSS
使用html5 canvas 画时钟代码实例分享
Nov 11 HTML / CSS
浅析HTML5的WebSocket与服务器推送事件
Feb 19 HTML / CSS
localStorage、sessionStorage使用总结
Nov 17 HTML / CSS
教你使用Canvas处理图片的方法
Nov 28 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模块memcache和memcached区别分析
2011/06/14 PHP
浅析Dos下运行php.exe,出现没有找到php_mbstring.dll 错误的解决方法
2013/06/29 PHP
php接口与接口引用的深入解析
2013/08/09 PHP
phpcms配置列表页以及获得文章发布时间
2017/07/04 PHP
Ajax+Json 级联菜单实现代码
2009/10/27 Javascript
javascript 动态修改样式和层叠样式表代码
2010/04/27 Javascript
js冒泡、捕获事件及阻止冒泡方法详细总结
2014/05/08 Javascript
Jquery实现$.fn.extend和$.extend函数
2016/04/14 Javascript
jQuery实现点击行选中或取消CheckBox的方法
2016/08/01 Javascript
Bootstrap select下拉联动(jQuery cxselect)
2017/01/04 Javascript
Vue+axios实现统一接口管理的方法
2018/07/23 Javascript
javascript实现摄像头拍照预览
2019/09/30 Javascript
稍微学一下Vue的数据响应式(Vue2及Vue3区别)
2019/11/21 Javascript
python实现的文件夹清理程序分享
2014/11/22 Python
Python中使用tarfile压缩、解压tar归档文件示例
2015/04/05 Python
Python中datetime常用时间处理方法
2015/06/15 Python
Python 序列的方法总结
2016/10/18 Python
Python 输入一个数字判断成绩分数等级的方法
2018/11/15 Python
python pandas写入excel文件的方法示例
2019/06/25 Python
centos+nginx+uwsgi+Django实现IP+port访问服务器
2019/11/15 Python
Tensorflow 实现释放内存
2020/02/03 Python
pyinstaller将含有多个py文件的python程序做成exe
2020/04/29 Python
Python3之乱码\xe6\x97\xa0\xe6\xb3\x95处理方式
2020/05/11 Python
Pycharm操作Git及GitHub的步骤详解
2020/10/27 Python
纯CSS3实现3D旋转书本效果
2016/03/21 HTML / CSS
CSS3 新增选择器的实例
2019/11/13 HTML / CSS
新加坡航空官方网站:Singapore Airlines
2016/10/13 全球购物
英国最大的体育&时尚零售公司:JD Sports
2017/12/13 全球购物
第二层交换机和路由器的区别?第三层交换机和路由器的区别?
2013/05/23 面试题
建筑结构施工专业推荐信
2014/02/21 职场文书
2014年个人技术工作总结
2014/12/08 职场文书
武当山导游词
2015/02/03 职场文书
爱牙日宣传活动总结
2015/02/05 职场文书
4S店销售内勤岗位职责
2015/04/13 职场文书
导游词之西安骊山
2019/12/20 职场文书
为了顺利买到演唱会的票用Python制作了自动抢票的脚本
2021/10/16 Python