热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

html5canvas常用属性方法(介绍)-

本章给大家带来html5canvas常用属性方法(介绍),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
本章给大家带来html5 canvas常用属性方法(介绍),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

首先引入标签就不必说了。

其次就是得到canvas的2d环境了( var ctx = canvasDom.getContext('2d') )。

现在呢,你可能想画点什么东西。画东西之前你要确定好一些东西,比如:

 ctx.fillStyle:这是一个用来确定填充颜色的属性。(带fill都和填充有关)
ctx.strokeStyle:这是一个用来确定"笔路径"(就像是线条)的属性。(带stroke都和描线有关)
ctx.shadow++:这是有4个设置所画图形阴影的属性(shadowColor,shadowBlur,shadowOffsetX,shadowOffsetY),我不常用,略。
ctx.lineWidth:这是4个设置线条样式的属性(lineCap,lineJoin,lineWidth,miterLimit)中最常用的,设置线宽,值为带px的string。
ctx.font:这是设置文本()的字体大小和字体样式,值可以是"30px",也可以是"30px Microsoft yahei"。同时配合ctx.textAlign和ctx.baseline设置对齐位置和基线位置。然后通过ctx.filltext()或者ctx.strokeText()绘制文字,还有ctx.measureText()返回一个对象,里面包含文本的信息,比如width,height。

了解了上面这些基础属性后,你就可以画点什么了:

想要显示点什么东西,流程大概是先弄路径(路径是看不见的),然后再通过ctx.fill()或ctx.stroke来对路径进行填充或描线。

你可以用ctx.rect(x,y,width,height)或ctx.arc(x,y,radius,startAngle,endAngle,anticolorwise)先弄一个路径,然后在fill或者stroke。

当然矩形有ctx.fillRect()和ctx.strokeRect()直接弄一个可见的方形。(圆没有这两个方法)

最后再介绍一个黑板擦--ctx.clearRect(x,y,weight,height),用来清除该方框内的所有像素。

还有一个为了防止之前的路径干扰,可以在每次画之前都ctx.beginPath()来清掉之前的路径。

以上就是基本的canvas的使用,下面就来聊点高(yong)级(bu)点(shang)的。

矩形样式的渐变填充:

var grd = ctx.createLinearGradient(x0,y0,x1,y1);
grd.addColorStop(0,"black");
grd.addColorStop(1,"white");
ctx.fillstyle = grd;
ctx.fillRect(x,y,w,h);

这一趟下来相当于是先预定义了一个渐变样式(可填充或者描线),将样式设置好后进行填充或者描线。

还有createRadialGradient()配合addColorStop设置放射状的样式。

媒体(图片、视频、其他canvas)的填充:  

var img = imgDom;
var pat = ctx.createPattern(img,"repeat");

然后这个pat就可以给ctx.++Style,从而进行填充或者描线等。

其中pattern有四种:repeat(默认),repeat-x,repeat-y,no-repeat。

自定义路径:

利用ctx.moveTo(x,y);把路径起点移动到(x,y) ,然后配合lineTo(x,y),就可以得到路径,就可以描线显示出来。

当然如果你想填充,但是可能路径没有闭合,可以利用ctx.closePath()闭合路径,然后进行填充。

画布切割:

使用ctx.clip()可以根据当前已闭合的路径来剪切画布,被剪切的画布部分就不能被操作了。

可以通过ctx.save()对当前区域先进行保存,然后通过ctx.restore()进行恢复。

画圆弧:

画圆弧通过ctx.arcTo(x0,y0,x1,y1,radius);通过两点和半径确定弧线,来得到路径,然后根据需要填充或者描线。

判断点是否在路径内:

ctx.isPointInPath();返回布尔值,没啥好说的。

有一种曲线叫 贝塞尔:

  先用ctx.moveTo()移至起始点。

  ctx.quadraticCurveTo(c1x,c1y,edx,edy);利用起点和一个控制点加终点的贝塞尔曲线;

  ctx.beizierCurveTo(c1x,c1y,c2x,c2y,edx,edy);利用两个控制点绘制的贝塞尔曲线。

图形转换:

    ctx.scale(w,h);放大w>1就是宽度上放大,h就是高度上。

    ctx.rotate(r);r为弧度单位,如20度:20*Math.PI/180。顺时针。

    ctx.translate(x,y)设置画布上(0,0)的位置,(x,y)就是当前(0,0)的位置。

    ctx.transform(a,b,c,d,e,f);分别是水平缩放、水平倾斜、垂直倾斜、垂直缩放、水平位移、垂直位移。该属性会叠加,对下一个图形有效。

    ctx.setTransform(a,b,c,d,e,f);同上,该属性会重新定义一个transform,对下一个图形有效。

drawImage():

  ctx.drawImage(dom,arg1,arg2,arg3,arg4,arg5,arg6,arg7,arg8);除了dom外最多还可以传8个参数,传2个是定位图像(原尺寸),传4个是按大小定位图像,传8个是剪切后定位图像(分别是:剪切开始x,y,剪切大小w,h,定位位置x,y,大小w,h)。

  globalAipha属性:设置全局透明度。(已经画好的不受影响)。

  globalCompositeOperation 属性 设置上一个和下一个重叠区的层叠顺序,有"source-over","destination-over",哪个over,哪个在下面。

以上就是html5 canvas常用属性方法(介绍)的详细内容,更多请关注 第一PHP社区 其它相关文章!


推荐阅读
  • 本文介绍如何在应用程序中使用文本输入框创建密码输入框,并通过设置掩码来隐藏用户输入的内容。我们将详细解释代码实现,并提供专业的补充说明。 ... [详细]
  • 本文介绍如何通过SQL查询从JDE(JD Edwards)系统中提取所有字典数据,涵盖关键表的关联和字段选择。具体包括F0004和F0005系列表的数据提取方法。 ... [详细]
  • 本文详细介绍了如何通过命令行启动MySQL服务,包括打开命令提示符窗口、进入MySQL的bin目录、输入正确的连接命令以及注意事项。文中还提供了更多相关命令的资源链接。 ... [详细]
  • 本文介绍如何使用 NSTimer 实现倒计时功能,详细讲解了初始化方法、参数配置以及具体实现步骤。通过示例代码展示如何创建和管理定时器,确保在指定时间间隔内执行特定任务。 ... [详细]
  • 本文介绍了在Windows环境下使用pydoc工具的方法,并详细解释了如何通过命令行和浏览器查看Python内置函数的文档。此外,还提供了关于raw_input和open函数的具体用法和功能说明。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • 本文探讨了在 PHP 中处理 JSON 编码时中文字符显示为 Unicode 转义序列的问题,并提供了多种有效的解决方法,包括使用正则表达式替换、URL 编码以及利用 PHP 5.4 及以上版本提供的 JSON_UNESCAPED_UNICODE 选项。 ... [详细]
  • 本文详细探讨了Netty中Future及其子类的设计与实现,包括其在并发编程中的作用和具体应用场景。我们将介绍Future的继承体系、关键方法的实现细节,并讨论如何通过监听器和回调机制来处理异步任务的结果。 ... [详细]
  • 本文详细介绍了 PHP 中的 usleep 函数,包括其定义、用法、参数说明、返回值以及相关注意事项。通过实例演示了如何使用此函数实现代码执行的微秒级延迟。 ... [详细]
  • 当地时间1月14日,德国南部巴尔德斯旺格(Balderschwang)的一家酒店遭遇了严重的雪崩袭击。大量积雪涌入建筑内部,导致建筑物受损。近期,欧洲阿尔卑斯地区多个国家因暴雪天气频繁发生雪崩,多地已发布最高级别的雪崩预警。 ... [详细]
  • 机器学习中的相似度度量与模型优化
    本文探讨了机器学习中常见的相似度度量方法,包括余弦相似度、欧氏距离和马氏距离,并详细介绍了如何通过选择合适的模型复杂度和正则化来提高模型的泛化能力。此外,文章还涵盖了模型评估的各种方法和指标,以及不同分类器的工作原理和应用场景。 ... [详细]
  • 本文介绍了如何使用PHP代码实现微信平台的媒体素材上传功能,详细解释了API接口的使用方法和注意事项,确保文件路径正确以避免常见的错误。 ... [详细]
  • 本文介绍了如何在Python中使用join()方法将列表中的元素连接成一个字符串。join()方法允许用户指定分隔符,从而灵活地生成所需格式的字符串。此外,我们还将探讨一些实际应用中的注意事项和技巧。 ... [详细]
  • 本文介绍了在 PHP 7.1 中使用 openssl_encrypt 函数替代已弃用的 mcrypt_encrypt 函数的方法,并提供了详细的代码示例和常见问题的解决方案。 ... [详细]
author-avatar
默默-晶f
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有