首页 web前端 H5教程 HTML5边玩边学(五)-图像、图案和字体

HTML5边玩边学(五)-图像、图案和字体

Mar 29, 2017 pm 03:02 PM

一、创建图像对象

在 HTML5 中,Image 对象对应着一幅图片,想要获取一个图像对象,有以下几种方法:

1) 通过 document.images 集合、document.getElementsByTagName 方法或者 document.getElementById 方法来获取网页内已经存在的图片对象;

2) 用 document.getElementsByTagName 或 document.getElementById 方法来获取另外一个 Canvas 对象,将这个 Canvas 对象作为一个图像对象;

3) 最常用的方法:创建一个新的空 Image 对象,给他一个图片的超链接,代码如下:

//创建一个空图像对象
var img = new Image();
//给图像对象一个图片超链接
img.src = 'myImage.png';
登录后复制

4) 最后一种是通过 data: url 方式嵌入图像,这种方法很奇妙,他可以用一个很长的字符串来表示一幅图像。

那么这个很长的字符串是怎么来的呢?他是把真正的图像文件(bmp jpg 等等)通过 Base64 编码而来,具体的编码程序网上能搜索到很多,我博客里就有一个 Python 版的。

用这种方式的好处就是,图片资源始终内嵌在 HTML 网页文件中,缺点是数据量太大,而且图片没办法缓存,导致网页文件打开速度变慢

下面的字符串就是一幅美女图片的 Base64 编码的一小段,让大家看看是什么样子的:

/9j/4QDfRXhpZgAASUkqAAgAAAAFABIBAwABAAAAAQAAADEBAgAVAAAASgAAADIBAgAUAAAAXw

这些乱七八糟的东西就包含了美女图片的一小部分内容了,后面我们将把它绘制到 Canvas 上

二、绘制图像对象

我们得到一个图像对象后,它只是在内存中,我们怎么才能将它绘制到画布上呢? 上下文对象有一个绘制图像对象的方法:

drawImage(image, x, y)

简单吧?image 就是你事先准备好的图像对象,x, y 就是图像左上角放置的位置 ,这个方法调用后,你的图像就会出现在 Canvas 上了

下面我们来把上面的美女图像绘制出来,代码如下:

代码



Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

--><canvas id="canvas1" width="250" height="300" style="background-color:black">

    你的浏览器不支持 &lt;canvas&gt;标签,请使用 Chrome 浏览器 或者 FireFox 浏览器

</canvas><br/>

<input type="button" value="显示美女" onclick="Show();" />

<input type="button" value="清空" onclick="Clear();" />



<script type="text/javascript">
    //美女图的 Base64 编码


    IMG_SRC=&#39;data:image/gif;base64,/9j/4QDfRXhpZgAASUkqAAgAAAA......&#39;//省略40字节

    //缩小版本的美女图

    IMG_SRC_SMALL=&#39;data:image/gif;base64,/9j/4QDfRXhpZgAASUkqAAgAAAA......&#39;//省略40字节



    function Show(){

        //获取画布对象

        ctx = document.getElementById("canvas1").getContext("2d");
        //创建图像对象

        img=new Image();

        //图像被装入后触发

        img.onload=function(){

            ctx.drawImage(img,0,0);

        }
        //指定图像源
        img.src=IMG_SRC;   
    }  


    function Clear(){

        //清除画布

        ctx = document.getElementById("canvas1").getContext("2d");

        ctx.clearRect(0,0,250,300);

    }  

</script>
登录后复制

:把绘制方法放到图像对象的 onload 事件中,是为了确保图像在完全装入后才绘制

三、缩放图像

同样的 imageDraw 方法,增加两个参数,就可以对图像实现缩放,如下:

drawImage(image, x, y, width, height)

width 代表你想将图像绘制成多宽,height 代表你想将图像绘制成多高,设定好后系统会自动按比例进行缩放。

下面的例子我们来模仿一个常见的图像软件的小功能,通过拖动滑动条对图像进行缩放,代码如下:

代码



Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

--><canvas id="canvas2" width="250" height="300" style="background-color:black">

    你的浏览器不支持 &lt;canvas&gt;标签,请使用 Chrome 浏览器 或者 FireFox 浏览器

</canvas><br/>
注意:下面的 Range 控件只能在 Google Chrome 浏览器中正确呈现

横向缩放<input type="range" min="1" max="20" onchange="Scale1(event)"/><br/>

纵向缩放<input type="range" min="1" max="20" onchange="Scale2(event)"/><br/>

按比例缩放<input type="range" min="1" max="20" onchange="Scale3(event)"/><br/>

平铺<input type="range" min="1" max="10" value="1" onchange="Scale4(event)"/><br/>



<script type="text/javascript">    

    function Scale1(){

        //计算比例

        var scale=event.target.value/10

        ///获取画布对象

        ctx = document.getElementById("canvas2").getContext("2d");

        //清空

        ctx.clearRect(0,0,250,300);

        //创建图像对象

        img=new Image();

        //图像被装入后触发

        img.onload=function(){

            //横向缩放绘制

            ctx.drawImage(img,0,0,img.width*scale,img.height);

        }

        //指定图像源

        img.src=IMG_SRC;

    } 

        

    function Scale2(){

        //计算比例

        var scale=event.target.value/10

        ///获取画布对象

        ctx = document.getElementById("canvas2").getContext("2d");

        //清空

        ctx.clearRect(0,0,250,300);

        //创建图像对象

        img=new Image();

        //图像被装入后触发

        img.onload=function(){

            //纵向缩放绘制

            ctx.drawImage(img,0,0,img.width,img.height*scale);

        }

        //指定图像源

        img.src=IMG_SRC;

    }

    

    function Scale3(){

        //计算比例

        var scale=event.target.value/10

        ///获取画布对象

        ctx = document.getElementById("canvas2").getContext("2d");

        //清空

        ctx.clearRect(0,0,250,300);

        //创建图像对象

        img=new Image();

        //图像被装入后触发

        img.onload=function(){

            //按比例缩放绘制

            ctx.drawImage(img,0,0,img.width*scale,img.height*scale);

        }

        //指定图像源

        img.src=IMG_SRC;

    }

    

    function Scale4(){

        //平铺比例

        var scale=event.target.value;

        ///获取画布对象

        ctx = document.getElementById("canvas2").getContext("2d");

        //清空

        ctx.clearRect(0,0,250,300);

        //创建图像对象

        img=new Image();

        //图像被装入后触发

        img.onload=function(){

            //平铺个数

            var n1=img.width/scale;

            var n2=img.height/scale;

            

            for(var i=0;i<n1;i++)

                for(var j=0;j<n2;j++)

                    ctx.drawImage(img,i*img.width/scale,j*img.height/scale,img.width/scale,img.height/scale);

        }

        //指定图像源

        img.src=IMG_SRC;

    }

</script>
登录后复制

横向缩放
纵向缩放
按比例缩放
平铺

提示:

只有在 Google Chrome 浏览器中,Range 控件才能呈现出滑动条的的样子并正确工作;

在其他浏览器中,您可能只能看到四个文本框,并且无法正常工作

四、裁剪图像

图像裁剪同样是使用 imageDraw 方法,原型如下:

drawImage(image, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight),其中

sx, sy 是图像上的一个坐标位置,这个坐标是裁剪的起始点

sWidth, sHeight 是裁剪的宽度和长度

有了这四个参数,我们就可以将图像上的任意区域裁剪出来了

另外

dx, dy 是画布上的一个坐标为止,裁剪出来的图像的左上角将放置在这个位置

dWidth, dHeight 是设置裁剪出来的图像绘制成多长和多宽,可以缩放

裁剪图像比较简单,就不给例子了

五、图案

在上面的图像缩放中,我们用循环的方法实现了图像的平铺,其实还有更方便的方法,就是用图案对象填充画布,图案对象用下面的方法创建:

createPattern(image,type)

其中,Type 必须是下面的字符串值之一:repeat,repeat-x,repeat-y 和 no-repeat。

得到图案对象后,可以将其设置给上下文对象的 fillStyle 属性,然后再填充画布,就可以看到重复填充的效果了。

下面的代码中,我们将把缩小版本的美女图用 repeat 模式,平铺到画布上:

图案



Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

--><canvas id="canvas3" width="250" height="300" style="background-color:black">

    你的浏览器不支持 &lt;canvas&gt;标签,请使用 Chrome 浏览器 或者 FireFox 浏览器

</canvas><br/>

<input type="button" value="贴图" onclick="Patterns();" />

<input type="button" value="清空" onclick="ClearPatterns();" />



<script type="text/javascript">

    //美女图的缩小版本

    IMG_SRC_SMALL=&#39;data:image/gif;base64,/9j/4QDfRXhpZgAASUkqAAgAAAAFABIBA......&#39;;//省略四个字节



    function Patterns(){

        ///获取画布对象

        ctx = document.getElementById("canvas3").getContext("2d");

        //创建图像对象

        img=new Image();

        //指定图像源

        img.src=IMG_SRC_SMALL;

        //图像被装入后触发

        img.onload=function(){

            //创建图案

            var ptrn = ctx.createPattern(img,&#39;repeat&#39;); 

                        //将图案设置为填充样式

            ctx.fillStyle = ptrn;  

                        //填充画布

            ctx.fillRect(0,0,250,300);  

        }

    }

    

    function ClearPatterns(){

        ///获取画布对象

        ctx = document.getElementById("canvas3").getContext("2d");

        //清空

        ctx.clearRect(0,0,250,300);

    }

</script>
登录后复制

六、字体

HTML5 的没有专门的字体对象,上下文对象中有三个属性用来设置字体,两个方法来绘制字符串,他们是:

font:文字字体,同 CSS font-family 属性
textAlign:文字水平对齐方式。可取属性值: start, end, left, right, center。默认值: start.
textBaseline:文字竖直对齐方式。可取属性值:top, hanging, middle, alphabetic, ideographic, bottom。默认值:alphabetic.

fillTextstrokeText:用填充方式和轮廓方式绘制字符串

下面的代码绘制两个不同设置的 Hello World 字符串

代码



Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->context.fillStyle    = &#39;#00f&#39;;

context.font         = &#39;italic 30px sans-serif&#39;;

context.textBaseline = &#39;top&#39;;
//填充字符串

context.fillText  (&#39;Hello world!&#39;, 0, 0);

context.font         = &#39;bold 30px sans-serif&#39;;
//轮廓字符串

context.strokeText(&#39;Hello world!&#39;, 0, 50);
登录后复制

下图是上面的代码运行效果:

1319.jpg

以上是HTML5边玩边学(五)-图像、图案和字体的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1654
14
CakePHP 教程
1413
52
Laravel 教程
1306
25
PHP教程
1252
29
C# 教程
1225
24
HTML 中的表格边框 HTML 中的表格边框 Sep 04, 2024 pm 04:49 PM

HTML 表格边框指南。在这里,我们以 HTML 中的表格边框为例,讨论定义表格边框的多种方法。

HTML 中的嵌套表 HTML 中的嵌套表 Sep 04, 2024 pm 04:49 PM

这是 HTML 中嵌套表的指南。这里我们讨论如何在表中创建表以及相应的示例。

HTML 左边距 HTML 左边距 Sep 04, 2024 pm 04:48 PM

HTML 左边距指南。在这里,我们讨论 HTML margin-left 的简要概述及其示例及其代码实现。

HTML 表格布局 HTML 表格布局 Sep 04, 2024 pm 04:54 PM

HTML 表格布局指南。在这里,我们详细讨论 HTML 表格布局的值以及示例和输出。

HTML 输入占位符 HTML 输入占位符 Sep 04, 2024 pm 04:54 PM

HTML 输入占位符指南。在这里,我们讨论 HTML 输入占位符的示例以及代码和输出。

HTML 有序列表 HTML 有序列表 Sep 04, 2024 pm 04:43 PM

HTML 有序列表指南。在这里我们还分别讨论了 HTML 有序列表和类型的介绍以及它们的示例

HTML onclick 按钮 HTML onclick 按钮 Sep 04, 2024 pm 04:49 PM

HTML onclick 按钮指南。这里我们分别讨论它们的介绍、工作原理、示例以及各个事件中的onclick事件。

在 HTML 中移动文本 在 HTML 中移动文本 Sep 04, 2024 pm 04:45 PM

HTML 中的文本移动指南。在这里我们讨论一下marquee标签如何使用语法和实现示例。

See all articles