H5引入了canvas标签,默认是一个300*150的inline-block。canvas的宽高只能用它自身的width和height属性来指定,而不能使用css样式中的width、height。

  一、获得‘画笔’对象,canvas所有的任务都需要它来执行

    var ctx=canvas.getContext('2d');

  二、一些canvas常用的属性

    fillStyle:填充样式

    strokeStyle:描边样式

    lineWidth:描边宽度

    font:绘制文本所用的字体大小和类型

    textBaseline:文本对其的基线

    shadowOffsetX、shadowOffsetY:阴影偏移量

  三、使用canvas绘制图形

    1、绘制矩形

    ctx.fillRect(x,y,w,h):填充一个矩形

    ctx.strokeRect(x,y,w,h):描边一个矩形

    ctx.clearRect(x,y,w,h):清除一个矩形范围内的内容

    2、绘制文本

    ctx.fillText(txt,x,y)填充文本

    ctx.strokeText(txt,x,y)描边文本

    ctx.measureText(txt)测量

    *要注意的是文本的定位点默认在文本基线(alphabetic)的起始点!

    3、为图形文字添加阴影

    例:ctx.shadowColor='#000';//颜色

      ctx.shadowOffsetX=8;//水平偏移量

      ctx.shadowOffsetY=8;//垂直偏移量

      ctx.shadowBlur=10;//模糊半径

    4、在绘图时使用渐变色

    ctx.createLinearGradient(x1,y1,x2,y2):创建线性渐变对象

    ctx.createRadialGradient(x1,y1,r1,x2,y2,r2):创建径向渐变对象

    ctx.addColorStop:添加颜色点

    5、绘制路径

    ctx.beginPath():开始路径

    ctx.closePath():结束路径

    ctx.moveTo(x,y):移动到指定点

    ctx.lineTo(x,y):绘制直线路径到指定点

    ctx.arc():绘制拱形路径

    ctx.ellipse():绘制椭圆路径

    ctx.bezierCurveTo():绘制贝塞尔曲线路径

    ctx.linJoin():修改折线拐点处样式

    6、绘制图像

    ctx.drawImage()

    7、对于绘制上下文状态的改变和修改

    ctx.translate(x,y):坐标轴原点移动到指定点

    ctx.rotate():旋转画笔

    ctx.scale():画笔缩放

    ctx.save():保存绘图上下文当前的变形数据

    ctx.restore():恢复最近一次的保存的变形相关的状态

 ***Canvas是个纯js实现的绘制位图的技术。

HTML5 十大新特性(四)——Canvas绘图的更多相关文章

  1. HTML5 十大新特性(五)——SVG绘图

    相对于canvas绘图,SVG是一种绘制矢量图的技术.全称叫做Scalable Vector Graphics,可缩放的矢量图,在2000年就已经存在,H5把它纳入了标准标签库,并进行了一些瘦身.需要 ...

  2. HTML5 十大新特性(二)——表单新特性

    H5的表单新特性可以分为两大类. 一.10个input的type值 1.email:邮件输入域,在表单提交时提供简单的邮箱格式验证,并弹出一个提示窗口. 2.url:地址输入域,在表单提交时提供简单的 ...

  3. HTML5 十大新特性(一)——语义标签

    说语义标签前先来理解下什么叫语义化,当下html是靠div+css来铸造页面的整体框架和结构的,通篇大量的div可读性极低,因此诞生了这些特殊的标签,简单地说就是见名知义,使页面更清晰,方便维护和开发 ...

  4. HTML5 十大新特性(十)——Web Socket

    webSocket是H5新加的一个协议,为了解决http协议的request.response一一对应和它自身的被动性,以及ajax轮询等问题.一方可以发送多条信息,连接不中断,永久连接,但也导致了服 ...

  5. HTML5 十大新特性(七)——拖放API

    拖放API是H5专门为了鼠标拖放而新提供了7个事件,可以分成三个部分来讲. 一.拖动的源对象(source)可以触发的事件 dragstart:拖动开始 drag:拖动进行中 dragend:拖动结束 ...

  6. HTML5 十大新特性(三)——视频和音频

    一.视频(video) H5新加了video标签,用来播放视频,默认为一个300*150的inline-block. 二.音频(audio) H5新加了audio标签,用来播放音频,默认为一个300* ...

  7. HTML5 十大新特性(九)——Web Storage

    H5的webStorage技术一共提供了两个对象:window.sessionStorage和window.localStorage. 一.window.sessionStorage--会话级存储 存 ...

  8. HTML5 十大新特性(八)——Web Worker

    由于js是单线程的,所以H5添加了这个叫做webWorker的概念,允许js创建多个线程,但是子线程完全受主线程控制,且不能操作DOM,从而来处理一些比较耗时的操作. 那么如何创建一个子线程呢?通过这 ...

  9. HTML5 十大新特性(六)——地理定位

    简单地用一句话概括就是,使用js获取浏览器当前所在的地理坐标,实现LBS(Location Based Service,基于定位的服务). 下面写一下它的基本调用: if(navigator.geol ...

随机推荐

  1. 算法第四版 用eclipse实现书中UnionFind例子

    一 安装环境 直接下载algs4.exe 下载完成后C:\Users\zle 下面会有algs4 文件夹 原文: Our installer downloads, installs, and conf ...

  2. uexGaodeMap插件Android接入指引

    uexGaodeMap插件Android接入指引 高德地图插件是基于高德地图API封装的AppCan平台的插件模块.开发者集成及使用此插件,需要到高德开放平台为应用申请相应的APIKey,并将APIK ...

  3. Java未被捕获的异常该怎么处理

    在你学习在程序中处理异常之前,看一看如果你不处理它们会有什么情况发生是很有好处的.下面的小程序包括一个故意导致被零除错误的表达式.class Exc0 {    public static void ...

  4. C语言函数的声明以及函数原型

    C语言代码由上到下依次执行,原则上函数定义要出现在函数调用之前,否则就会报错.但在实际开发中,经常会在函数定义之前使用它们,这个时候就需要提前声明.所谓声明(Declaration),就是告诉编译器我 ...

  5. Used Query

    ---  查询 look back 6 days logic period_key. select s.store_id, i.upc, sf.period_key from JNJ_CASINO_H ...

  6. u-boot移植 II

    下面是韦老师的uboot移植攻略: A. 开发板的相关拷贝与修改 1. 在board文件夹下面, 将原来的smdk2410复制为100ask24x0目录, 并将smdk2410.c改名为100ask2 ...

  7. wex5 实战 登陆帐号更换与用户id一致性

    一 前言 关于用户登陆,注册,页面跳转,我讲了很多,都是页面框架级别的.有人问到这个问题,索性总结一下,今天是收尾最后一篇. 以往初学时的设计是: 1 注册 2 登陆 3 进入页面. 这种很简单,没有 ...

  8. 09B-独立按键消抖实验02——小梅哥FPGA设计思想与验证方法视频教程配套文档

    芯航线--普利斯队长精心奉献   实验目的: 1.复习按键的设计 2.用模块化设计的方式实现每次按下按键0,4个LED显示状态以二进制加法格式加1,每次按下按键1,4个LED显示状态以二进制加法格式减 ...

  9. iOS开发随笔

    突然看到一个搞11年IT的前辈 他的简历给人焕然一新的感觉 IOS:深入理解object-c语言 内存管理(ARC,MRC, 写回传),GCD,RunLoop,RunTime,,Block,Deleg ...

  10. Django进阶2

    一.ORM操作进阶 ForeignKey关联 示例models from django.db import models # Create your models here. class User(m ...