简易的html5 Canvas绘图示例(斗图终结者第一版源码)

mengkun 10.1K 7

我从2015年的9月份开始接触网页制作这一块,期间断断续续做了很多小作品,斗图终结者无疑是其中最成功的的一个,有图为证:

简易的html5 Canvas绘图示例(斗图终结者第一版源码)

在我的所有网站中,斗图终结者的访问量是最多的

(不要问访问量为什么都这么少,我的网站从来都只是自娱自乐,没有打过任何广告……全靠“自来水”)

斗图终结者网站也是我的第一个练手作品,我第一次学写js时做的就是一个单页的表情图生成器;第一次学写php时就把单页的表情图生成器变成了多页面的(已在php编写的简单多页面网页Demo这篇博文中进行了分享),方便插入更多图像。

今天,我要分享的正是斗图终结者第一版的Demo源代码:

  1. <!--  
  2. * 斗图终结者(http://zb.mkblog.cn) 第一版源代码  
  3. * 孟坤博客 编写  
  4. * 文章地址:https://mkblog.cn/519/  
  5. * 编写日期:2016-3-25  
  6. * 更新日期:2016-12-25  
  7. -->  
  8. <!DOCTYPE html>     
  9. <html>     
  10. <head>     
  11. <meta charset="UTF-8">    
  12. <meta name="viewport" content="width=device-width">  
  13. <title>表情包制作</title>   
  14. <style>  
  15. *{  
  16.     padding:0;  
  17.     margin:0;  
  18.     font-family:"微软雅黑";  
  19.     font-size: 14px;  
  20. }  
  21. #text{  
  22.     width:391px;  
  23.     height:50px;  
  24.     text-align:center;  
  25.     font-size: 18px;  
  26.     -moz-border-radius: 5px;  
  27.     -webkit-border-radius: 5px;  
  28.     border-radius: 5px;  
  29.     border:1px solid #666;  
  30. }  
  31. #mainCenter{  
  32.     max-width:500px;  
  33.     margin:0 auto;  
  34.     text-align:center;  
  35. }  
  36. #myCanvas{  
  37.     margin:30px 0 0 0;  
  38. }  
  39. .shadow{  
  40.     -moz-border-radius: 5px;  
  41.     -webkit-border-radius: 5px;  
  42.     border-radius: 5px;  
  43.     /*IE 7 AND 8 DO NOT SUPPORT BORDER RADIUS*/  
  44.     -moz-box-shadow: 0px 0px 10px #000000;  
  45.     -webkit-box-shadow: 0px 0px 10px #000000;  
  46.     box-shadow: 0px 0px 10px #000000;  
  47.     /*IE 7 AND 8 DO NOT SUPPORT BLUR PROPERTY OF SHADOWS*/  
  48. }  
  49. </style>    
  50. </head>     
  51. <body>     
  52. <div id="mainCenter">  
  53.     <canvas id="myCanvas" class="shadow" width="391px" height="368px" style="none;">您的浏览器不支持canvas标签。</canvas>   
  54.     <br /><br />  
  55.     <p>在下方输入文字。在图片上使用鼠标右键或长按保存</p>  
  56.     <input name="text" id="text" onchange ="draw();" onpropertychange ="draw();" oninput  ="draw();" value="听说你很跳" />  
  57. </div>  
  58. <script type="text/javascript">  
  59. function draw(){  
  60.     var canvas = document.getElementById("myCanvas");       //获取Canvas对象(画布)   
  61.     var write = document.getElementById("text").value;        //获取文本的值  
  62.     if(canvas.getContext){     //简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误   
  63.         var ctx = canvas.getContext("2d");       //获取对应的CanvasRenderingContext2D对象(画笔)     
  64.         var img = new Image();                    //创建新的图片对象     
  65.         img.src = "https://mkblog.cn/blog/demo/doutu/1.png";    //指定原始图片的URL     
  66.         img.onload = function(){   //浏览器加载图片完毕后再绘制图片     
  67.             ctx.drawImage(img, 0, 0, 391, 368);  //以Canvas画布上的坐标(0,0)为起始点,绘制高度、宽度分别为391和368的图像  
  68.             ctx.font = "35px 微软雅黑";      //设置字体样式   
  69.             ctx.fillStyle = "black";           //设置字体填充颜色   
  70.             ctx.textAlign = 'center'; //设置文本的水平对对齐方式  
  71.             ctx.fillText(write, canvas.width/2, 350);       //从画布高度为350px的地方居中绘制文本  
  72.         };        
  73.     }    
  74. }  
  75. draw();  
  76. </script>     
  77. </body>  
  78. </html>  

斗图终结者上线有八个月了,功能也越做越多,但它的表情制作功能仍然是基于上述原理……之所以不用业内普遍的在后台用php生成图片,完全是因为懒得改了~

发表评论 取消回复
表情 图片 链接 代码

  1. 阿伟
    阿伟 Lv 1

    斗图终结者有没有源码呀

  2. putown.org
    putown.org Lv 1

    很喜欢,斗图终结者和MK音乐。音乐是因为接口的原因么,经常性更新导致无法播放。

  3. 懿古今
    懿古今 Lv 3

    刚才看了,挺多表情的,非常不错 [强]

    • mengkun
      mengkun 站长

      @懿古今那些表情图都是收集了大半年的成果~

    • mengkun
      mengkun 站长

      @懿古今博主你好,我来请教一个问题 [呲牙] :主题中有大量类似的代码:

      	<?php if (get_option('ygj_adh') == '关闭') { ?>
      	<?php { echo ''; } ?>
      	<?php } else { include(TEMPLATEPATH . '/inc/ad/ad_h.php'); } ?>
      

      这里为什么不直接这样写呢:

      	<?php if (get_option('ygj_adh') != '关闭') {include(TEMPLATEPATH . '/inc/ad/ad_h.php'); } ?>
      

      (PS:主要是搞不懂那里为什么要 echo一个空内容……)

      • 懿古今
        懿古今 Lv 3

        @mengkun[呲牙] 我是业余玩博客的,这个主题也是学习知更鸟Ality主题后折腾出来的,这个其实就是跟平时的语法习惯。如果什么什么否则什么什么,改成你这个更简洁。这个不用纠结的。 [偷笑]

      • mengkun
        mengkun 站长

        @懿古今我还以为是因为一些特殊原因那里必须要有内容输出呢 [偷笑]

分享