首页前端开发HTML字中字效果的实现【html5实例】

字中字效果的实现【html5实例】

时间2024-01-24 18:18:26发布访客分类HTML浏览320
导读:收集整理的这篇文章主要介绍了字中字效果的实现【html5实例】,觉得挺不错的,现在分享给大家,也给大家做个参考。 用htML5实现如图字中有字效果实现思路:用canvas输出文字,然后分析像素点,根据像素点输出文字。核心代码:Ja...
收集整理的这篇文章主要介绍了字中字效果的实现【html5实例】,觉得挺不错的,现在分享给大家,也给大家做个参考。

用htML5实现如图字中有字效果

实现思路:用canvas输出文字,然后分析像素点,根据像素点输出文字。

核心代码:

JavaScript Code复制内容到剪贴板
  1. VAR canvas;   
  2. var ctx;   
  3. var tex;   
  4. var blankStr = "  "; //输出空白   
  5.     
  6. $(function () {   
  7.     
  8.     $("button#BT").click(function () { //绑定按钮单击事件   
  9.     
  10.         if ($("canvas#myCanvas").length >  0) {   
  11.             canvas = $("canvas#myCanvas")[0];   
  12.             ctx = canvas.getContext("2d");   
  13.         }   
  14.     
  15.         var tex = $("input#inpt").val(); //获取输入框文字   
  16.         if (!tex) tex = "顶"; //默认文字为"顶"   
  17.         if (tex.length >  1) {  //只支持一个汉字   
  18.             alert("亲,少输入点字好吧,我吃不消呢~");   
  19.             return;   
  20.         }   
  21.     
  22.         var reg = /[\u4E00-\u9FA5]/g; //用正则表达式判断是否为汉字   
  23.         if (!reg.test(tex)) {   
  24.             alert("亲,输入一个汉字好吧,其他的我不认识呢~");   
  25.             return;   
  26.         }   
  27.     
  28.         ctx.fillStyle = "rgba(0,0,0,1)"; //绘制底色   
  29.         ctx.fillRect(20, 20, 40, 40);     
  30. ?   
  31.         ctx.fillStyle = "rgba(255,255,255,1)"//绘制文字   
  32.         ctx.font = "bolder 40px 宋体";   
  33.         ctx.textBaseline = 'top';   
  34.         ctx.fillText(tex, 20, 20);   
  35.     
  36.         var panel = $("#panel"); //汉字输出区域   
  37.         panel.html(""); //清空历史汉字   
  38.     
  39.         for (y = 1;  y  40;  y++) {   
  40.             for (x = 1;  x  40;  x++) {   
  41.                 imageData = ctx.getImageData(20 + x, 20 + y, 1, 1); //获取灰度像素值   
  42.                 if (imageData.data[0] > 180 ) {     //0为黑,255为白,取180是为了调控精度,确保不同浏览器都能有良好效果   
  43.                     panel.html(panel.html() + blankStr);   
  44.                 }  else {   
  45.                     panel.html(panel.html() + tex);   
  46.                 }   
  47.             }   
  48.             panel.html(panel.html() + "br> ");   
  49.         }   
  50.     } );   
  51.     
  52.     $("button#bt").click(); //第一次加载是输出"顶"   
  53. } );     

以上这篇字中字效果的实现【html5实例】就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

原文地址:http://www.cnblogs.com/shouce/archive/2016/05/03/5453737.html

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

上一篇: HTML5 Canvas绘制五星红旗下一篇:html5需遵循的6个设计原则猜你在找的html5相关文章 关于移动端h5开发相关内容总结2022-05-17html5教程-学表单的第二天2018-12-10html5教程-HTML5浏览器支持2018-12-10html5教程-HTML5智能表单2018-12-10html5教程-微信H5使用resLoader实现加载页效果2018-12-10html5教程-day01-初级-JS0-热身运动JS入门教程2018-12-10html5教程-html5shiv.js和respond.min.js2018-12-10html5教程-不同浏览器对于html5 audio标签和音频格式的兼容性2018-12-10html5教程-使用Html5实现手风琴案例2018-12-10html5教程-html5笔记2018-12-10 其他相关热搜词更多phpjavapython程序员load

若转载请注明出处: 字中字效果的实现【html5实例】
本文地址: https://pptw.com/jishu/585587.html
html5需遵循的6个设计原则 HTML5+Canvas+CSS3实现齐天大圣孙悟空腾云驾雾效果

游客 回复需填写必要信息