• 在庆祝海南建省办经济特区30周年大会上的讲话 2019-10-07
  • 俄罗斯世界杯F组:球迷风采 2019-09-24
  • 彭于晏廖凡曝姜文“精神洁癖” 2019-09-24
  • 苏州大学研究生支教团网上众筹资助留守儿童 2019-09-23
  • 湖北政务微信排行榜第187期出炉 交警类公号表现亮眼 2019-09-19
  • 【奋斗吧2018】风电检修工——荒原上的“听风者” 2019-08-31
  • 母亲节又送康乃馨?送这样的健康佳品才走心 2019-08-30
  • [酷]此文已经把马克思理论、边际理论、人类需求层次理论、生物学理论、心理学理论、社会管理学理论等理论在哲学层面完美融合了! 2019-08-26
  • 兰芝雪纱修颜气垫隔离霜 2019-07-27
  • “鹊桥”中继星顺利进入使命轨道运行 2019-07-27
  • 超越舆情管理的360度信息决策 2019-07-22
  • 视频陶然居变形记:从路边小饭馆到全国餐饮十强 2019-07-21
  • 防震减灾事业发展的重要理论成果 2019-07-20
  • 珠宝配美人!李冰冰大片衣着性感秀身段 2019-07-20
  • 机器人也能拥有“情商”?这个可以有 2019-07-19
  • 香港赛马会六肖中:详解如何用canvas画一个微笑的表情

      发布时间:2019-03-14 15:11:37   作者:Youki   我要评论

    这篇文章主要介绍了详解如何用canvas画一个微笑的表情的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

    实习期间让我用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绘制表情包的示例代码

      这篇文章主要介绍了canvas绘制表情包的示例代码的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
      2018-07-09

    最新评论

  • 在庆祝海南建省办经济特区30周年大会上的讲话 2019-10-07
  • 俄罗斯世界杯F组:球迷风采 2019-09-24
  • 彭于晏廖凡曝姜文“精神洁癖” 2019-09-24
  • 苏州大学研究生支教团网上众筹资助留守儿童 2019-09-23
  • 湖北政务微信排行榜第187期出炉 交警类公号表现亮眼 2019-09-19
  • 【奋斗吧2018】风电检修工——荒原上的“听风者” 2019-08-31
  • 母亲节又送康乃馨?送这样的健康佳品才走心 2019-08-30
  • [酷]此文已经把马克思理论、边际理论、人类需求层次理论、生物学理论、心理学理论、社会管理学理论等理论在哲学层面完美融合了! 2019-08-26
  • 兰芝雪纱修颜气垫隔离霜 2019-07-27
  • “鹊桥”中继星顺利进入使命轨道运行 2019-07-27
  • 超越舆情管理的360度信息决策 2019-07-22
  • 视频陶然居变形记:从路边小饭馆到全国餐饮十强 2019-07-21
  • 防震减灾事业发展的重要理论成果 2019-07-20
  • 珠宝配美人!李冰冰大片衣着性感秀身段 2019-07-20
  • 机器人也能拥有“情商”?这个可以有 2019-07-19
  • 神圣计划官网怎么付费 助赢软件ios 大发快三怎么玩稳赚 重庆欢乐生肖开奖结果 天镜棋牌 非凡聚合计划软件手机版 大赢家体育比分 北京快三开奖结果查 稳赚六肖三中一 幸运飞艇挂机软件免费版