更多HTML 5文章请查阅HTML 6在线网站http://www.html5online.com.cn

本文概述

本文介绍如何在一个Web应用程序中利用HTML 5中的Canvas API创建、编辑、打开与输出图像。

检测浏览器是否支持Canvas API
    首先,我们需要检测用户浏览器是否对HTML 5中的Canvas API提供支持。一个简单的方法是利用Modernizr工具来进行检测,方法如下所示。
if (Modernizr.canvas) {
    //浏览器支持Canvas API

else {
    //浏览器不支持Canvas API,使用诸如Flash、静态图片等其他技术
}
    通过URL地址或Data URI指定canvas元素中的图像来源
    在使用Canvas API的时候,我们首先需要在页面上放置一个canvas元素。然后,我们可以在JavaScript脚本代码中将一幅图像绘制在该canvas元素中,代码如下所示。
var ctx = document.getElementById('canvas').getContext('2d');
var img = new Image();
img.src = "images/sl.jpg";
img.onload = function () {
    ctx.drawImage(img,0,0);
}
    在这段代码中,我们首先获取页面上canvas元素的图形上下文对象,通过该对象来使用Canvas API中所定义的所有可用于绘图的方法。接下来,我们创建一个Image对象并且将该对象的src属性值定义为canvas元素中所需要绘制图像的URL地址,这将使得所需要绘制的图像将被装载在该Image对象中。当该图像装载完毕后,我们使用canvas元素的图形上下文对象的drawImage方法将该图像绘制在canvas元素中。
    可以将该Image对象的src属性值指定为一个形式为dataURI地址,代码如下所示:
  img.src=""
    你也许会问:"为什么需要使用dataURI地址?",这是因为dataURI地址有一些自身的优势,例如接下来我们马上要介绍的如何将canvas元素中的图形或图像导出为一个data URI地址。
    将canvas元素中的图像导出为dataURI地址
    canvas元素有一个toDataURL方法,该方法将导出图像的MIME类型作为唯一参数,代码如下所示。
window.open(document.getElementById('canvas').toDataURL("image/jpeg"));
    上面这行代码将canvas元素中的图像导出为一个JPEG格式的图像并且在新的浏览器窗口中打开该图像。浏览器地址栏中显示由canvas元素中的图像生成的data URI地址,浏览器将根据该data URI地址渲染窗口中的图像。但是,对于用户来说就好像在新的浏览器窗口中打开了该图像。
    另外请注意上面这行代码必须被运行在一个Web服务器中。从本地文件系统中直接运行该代码时浏览器将抛出错误。
将canvas元素中的图像存储在客户端本地
    通过HTML 5中提供的各种将数据存储在客户端本地的技术,我们可以很轻松地将canvas元素中的图像存储在客户端本地。
    例如通过如下所示的代码,我们可以将canvas元素中的图像存储在WebStorage中。
localStorage.setItem('canvas', canvas.toDataURL("image/jpeg"));
    通过如下所示的代码,我们可以从WebStorage中取出被保存的图像。
localStorageImage = new Image();
canvas=document.getElementById('canvas');
ctx=canvas.getContext('2d');
localStorageImage.onload = function () 
{
    ctx.drawImage(image,0,0); 
}   
localStorageImage.src = localStorage.getItem('canvas');
    将canvas元素中的图像上传到服务器端
    有时,你可能想将canvas元素中的图像上传到服务器端。这时,我们可以首先利用canvas元素的toDataURL方法将canvas元素中的图像输出为一个data URI地址,然后将该地址上传到服务器端。该地址分为两部分,中间用逗号分割,其中第一部分为“data:”+导出图像的MIME类型+“;base64”,第二部分为一个经过base64编码的字符串,在服务器端将其解码后即得到该图像的原始二进制数据,可以将其保存为图像文件,代码如下所示:
var data=canvas.toDataURL("image/jpeg");
var xhr = new XMLHttpRequest();
xhr.open("POST", "uploadImage.php");
xhr.send(data);
    服务器端保存图像文件的代码如下所示:
<?php
$data= $GLOBALS['HTTP_RAW_POST_DATA'];
$contents_split = explode(',',$data);
$encoded = $contents_split[count($contents_split)-1];
$decoded = "";
for ($i=0; $i < ceil(strlen($encoded)/256); $i++) {
    $decoded = $decoded . base64_decode(substr($encoded,$i*256,256));
}
$file=fopen("test.jpg","w");
fwrite($file,$decoded);
fclose($file);
?>

在Web应用程序中使用Canvas API相关推荐

  1. DotNetCore Web应用程序中的Cookie管理

    原文来自互联网,由长沙DotNET技术社区编译.如译文侵犯您的署名权或版权,请联系小编,小编将在24小时内删除.限于译者的能力有限,个别语句翻译略显生硬,还请见谅. 作者简介:Jon(Jonathan ...

  2. 如何使用recaptcha_在Spring MVC Web应用程序中使用reCaptcha

    如何使用recaptcha CAPTCHA是一个程序,可以生成人类可以通过但计算机程序" 不能 "通过的测试并对其进行评分. 所采取的策略之一是向用户显示具有扭曲文本的图像,并且用 ...

  3. threadlocal线程_线程故事:Web应用程序中的ThreadLocal

    threadlocal线程 本周,我花了一些合理的时间来消除Web应用程序中的所有ThreadLocal变量. 原因是他们造成了类加载器泄漏,我们不能再适当地取消部署我们的应用程序. 取消部署应用程序 ...

  4. 在Spring MVC Web应用程序中添加社交登录:集成测试

    我已经写了关于为使用Spring Social 1.1.0的应用程序编写单元测试的挑战,并为此提供了一种解决方案 . 尽管单元测试很有价值,但是它并不能真正告诉我们我们的应用程序是否正常运行. 这就是 ...

  5. 在Spring MVC Web应用程序中添加社交登录:单元测试

    Spring Social 1.0具有spring-social-test模块,该模块为测试Connect实现和API绑定提供支持. 该模块已从Spring Social 1.1.0中删除,并由 Sp ...

  6. Web应用程序中的Spring JDBC入门

    在上一篇文章中,我已经向您展示了如何设置基本的Spring 3 MVC Web应用程序 . 重复使用该项目设置作为模板,我将向您展示如何增强它以与JDBC一起使用. 有了它,您可以存储和检索数据库中的 ...

  7. 在Spring MVC Web应用程序中使用reCaptcha

    CAPTCHA是一种程序,可以生成人类可以通过的测试并对其进行评分,而计算机程序" 不能 "通过. 所采取的策略之一是向用户显示具有扭曲文本的图像,并且用户应在输入区域中书写文本. ...

  8. 线程故事:Web应用程序中的ThreadLocal

    本周,我花了一些合理的时间来消除Web应用程序中的所有ThreadLocal变量. 原因是他们造成了类加载器泄漏,我们不能再适当地取消部署我们的应用程序. 取消部署应用程序后,当GC根目录继续引用应用 ...

  9. 百家与g对比oogle_如何在Java Web应用程序中集成G​​oogle reCAPTCHA

    百家与g对比oogle I never liked Captchas because the burden was always on end user to understand the lette ...

最新文章

  1. C++虚继承(六) --- 虚继承浅析
  2. SQL Server聚集索引的选择
  3. Lecture 20 Parallel Algorithms I
  4. 2014/5/25 多校
  5. 【Python学习】 - 使用PIL, cv2, keras.preprocessing, scipy.imageio, matplotlib.image, skimage读取和保存图像的方法
  6. java 监控 配置 文件怎么打开_java实现文件变化监控的方法(推荐)
  7. IOS – OpenGL ES 调节图像色度 GPUImageHueFilter
  8. Python sorted() 函数
  9. linux中tomcat安装
  10. IDEA 导入Weka的Maven依赖jar包
  11. Django+Scrapy结合使用并爬取数据入库
  12. C#在foreach中重用变量是否有原因?
  13. 十、MySQL的应用大全
  14. Keil自动格式化代码
  15. android 暗黑模式项目适配过程
  16. 【ES实战】ES-Hadoop中的配置项说明
  17. list之按照中文拼音首字母排序
  18. 套利进阶——简单易行的分级基金套利
  19. 人工智能:第十一章 自然语言理解
  20. 机器人中的DIY,成就满满!

热门文章

  1. i春秋ctf训练营writeup-手贱的A君
  2. 皮卡丘的梦想2(线段树+二进制状态压缩)
  3. 手把手教你python实现量价形态选股知乎_【手把手教你】Python量化股票市场情绪指标ARBR...
  4. PHP伪原创同义词替代代码示意
  5. 未能加载文件或程序集“System.EnterpriseServices.Wrapper.dll”
  6. python http接口调用
  7. 【OpenCV】双目测距(双目标定、双目校正和立体匹配)
  8. 攻防世界Crypto新手练习
  9. 混迹网赚江湖十年的我也被无情的套路了
  10. Webots学习笔记(一)---初识软件+建立简单模型