HTML5 Canvas绘制文本及图片的基础教程

2019-01-28 22:08:48王冬梅

以canvas上指定的坐标点开始,以指定的大小(width和height)绘制整个图像,图像将根据指定的尺寸自动进行相应的缩放。
drawImage(mixed image, int imageX, int imageY, int imageWidth, int imageHeight, int canvasX, int canvasY, int canvasWidth, int canvasHeight)
将指定图像的局部图像(以(imageX, imageY)为左上角、宽度为imageWidth、高度为imageHeight的矩形部分)绘制到canvas中以(canvasX,canvasY)为左上角坐标、宽度为canvasWidth、高度为canvasHeight的矩形区域中
是的,你没有看错。要在canvas中绘制图像,我们可以使用一个名为drawImage()的方法,不过该方法具有三种不同的变体,每个方法变体允许接收的参数不仅数量不同,连参数的含义也不尽相同。

在这里,我们对上述三个变体分别举例说明。

首先,我们使用drawImage()的第一个变体在canvas上绘制Google的logo图片(原始尺寸为550 x 190)。

JavaScript Code复制内容到剪贴板
  1. <!DOCTYPE html>    <html>   
  2. <head>    <meta charset="UTF-8">   
  3. <title>HTML5 Canvas绘制图像入门示例</title>    </head>   
  4. <body>      
  5. <!-- 添加canvas标签,并加上红色边框以便于在页面上查看 -->    <canvas id="myCanvas" width="400px" height="300px" style="border: 1px solid red;">   
  6. 您的浏览器不支持canvas标签。    </canvas>   
  7.    <script type="text/javascript">   
  8. //获取Canvas对象(画布)    var canvas = document.getElementById("myCanvas");   
  9. //简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误    if(canvas.getContext){     
  10.     //获取对应的CanvasRenderingContext2D对象(画笔)        var ctx = canvas.getContext("2d");   
  11.             //创建新的图片对象   
  12.     var img = new Image();        //指定图片的URL   
  13.     img.src = "http://www.365mini.com/image/google_logo.png";        //浏览器加载图片完毕后再绘制图片