Canvas实例教程:图像移动、大小调整和裁剪

techbrood 发表于 2016-05-18 18:45:14

标签: canvas, html5, 图像, 编辑, 裁剪

- +

本文介绍如何使用JavaScript和HTML5 Canvas元素来移动、调整大小和裁剪图像,这些技术适用于图片编辑器、照片分享等应用场景。

一般而言图像的剪裁会放在服务端进行,但是图片传送会消耗较多的流量。借助HTML5 Canvas绘图功能,可以在浏览器端以比较简单的方式来实现。

代码和在线演示地址:http://wow.techbrood.com/fiddle/2580,可以先操作下,有个整体印象,界面截图如下:

下载.png

构建界面布局和元素

HTML页面由源图片Crop操作按钮裁剪矩形框以及图片容器(含4个角的调整小方块)组成,主体代码如下:

<div class="component">  
    <div class="overlay">  
        <div class="overlay-inner">  
        </div>  
    </div>  
    <img class="resize-image" src="/assets/beauty.jpg" alt="image for resizing">  
    <button class="btn-crop js-crop">Crop<img class="icon-crop" src="/assets/crop.svg">  
    </button>  
</div>

img[class=resize-image] 元素为本服务器图片资源,是要进行调整和裁剪的图片。注意出于安全策略,不能在浏览器中跨域操作图片,否则会出现类似下面的报错信息:

Uncaught SecurityError: Failed to execute 'toDataURL' on 'HTMLCanvasElement': Tainted canvases may not be exported.

button[class=btn-crop] 是SVG矢量图标按钮。

div[class=overlay] 元素是裁剪矩形框。

此外图片容器使用JavaScript动态包装在 img[class=resize-image] 元素外部:

// Wrap the image with the container and add resize handles  
$('.resize-image').wrap('<div class="resize-container"></div>')  
    .before('<span class="resize-handle resize-handle-nw"></span>')  
    .before('<span class="resize-handle resize-handle-ne"></span>')  
    .after('<span class="resize-handle resize-handle-se"></span>')  
    .after('<span class="resize-handle resize-handle-sw"></span>');
实现大小调整的功能

大小调整通过先在Canvas上绘制一个对应大小的图像,接着通过Canvas的toDataURL方法转化为base64编码的字符串形式的图片数据。
最后把该data:URL通过设置为img的src属性,附着到目标图像元素上。

resizeImage = function(width, height){  
    resize_canvas.width = width;  
    resize_canvas.height = height;  
    resize_canvas.getContext('2d').drawImage(orig_src, 0, 0, width, height);     
    $('.resize-image').attr('src', resize_canvas.toDataURL("image/png"));    
};
实现移动功能

通过mouseup事件获取新的位置,然后通过jQuery的offset方法来完成元素偏移。

moving = function(e){  
    var  mouse={};  
    e.preventDefault();  
    e.stopPropagation();  
    mouse.x = (e.clientX || e.pageX) + $(window).scrollLeft();  
    mouse.y = (e.clientY || e.pageY) + $(window).scrollTop();  
    $container.offset({  
        'left': mouse.x - ( event_state.mouse_x - event_state.container_left ),  
        'top': mouse.y - ( event_state.mouse_y - event_state.container_top )   
    });  
};
实现裁剪功能

这个主要是实现一个居中的覆盖矩形(overlay),接着通过计算背景图片和该覆盖矩形的偏移来获取图片裁剪区域的坐标,

然后再通过Canvas的drawImage和toDataURL完成裁剪图的绘制。

crop = function(){  
    var crop_canvas,  
        left = $('.overlay').offset().left - $container.offset().left,  
        top =  $('.overlay').offset().top - $container.offset().top,  
        width = $('.overlay').width(),  
        height = $('.overlay').height();  
           
    crop_canvas = document.createElement('canvas');  
    crop_canvas.width = width;  
    crop_canvas.height = height;  
       
    crop_canvas.getContext('2d').drawImage(image_target, left, top, width, height, 0, 0, width, height);  
    window.open(crop_canvas.toDataURL("image/png"));  
}

最后再加上一些移动功能,如触摸事件(Touch)和手势(Gesture)检测的支持。

参考链接

1. http://madebymike.com.au/

2. http://stackoverflow.com/questions/18922880/html5-canvas-resize-downscale-image-high-quality

3. http://www.techbrood.com/ideas?q=Makethumbnails


possitive(6) views21593 comments1

发送私信

最新评论

iefreer 2016-05-18 18:47:22

Read more on canvas basics:
http://techbrood.com/h5b2a?p=html-canvas-overview


请先 登录 再评论.
相关文章
  • CentOS6 Apache2.2多站点HTTPS配置

    可以使用letsencrypt(certbot)免费证书服务。支持多系统、多站点和多目录,支持wildcard(通配符域名),90天生效,可用定时任务自动更新。需要注意一点的是apache2.4以下版本需要在默认的ssl配置中添加如下的指令:NameVirtualHost

  • 2019年开源WebRTC媒体服务器选型比较

    什么是WebRTC服务器?在WebRTC的早期开始,该技术的主要卖点之一是它允许点对点(浏览器到浏览器)通信,几乎没有服务器的干预,服务器通常仅用于信令(比如用于...

  • HTML5 And Canvas 2D Specs Are Now Feature Complete, First HTML 5.1 Working Draft Published

    We’ve been writing about HTML5 for quite a while, but, until today, the actual HTML5 specs and standards were still moving targets. Now, however, the...

  • 谷歌ARCore技术特性简介

    谷歌美国时间2017.8.29号刚发布了ARCore预览版,这是一个类似于苹果ARKit的增强现实SDK,在此之前,谷歌虽然已投资AR平台Tango,但由于需要特定的硬件和传感器,...

  • 使用CSS3 box-decoration-break特性实现多行文本样式

    当文章中的长文本被自动断行为多行文本时,其样式可能会出乎我们的设计。本文介绍如何使用CSS3中的box-decoration-break特性来处理多行元素样式。
    按照规范...

  • 学习使用CSS制作进度条

    进度条是基础的界面控件,可用于多种场合,比如任务完成进度,手机充电状态等。本文介绍一个简单实用的进度条制作方法。预期效果如下图所示:直观上,我们可以把该进度条控件分为2个部分,外部的边界用来表示固定的目标范围,里面的条形部分用来表示当前进度。外部目标范围元素的CSS代码编写如下:.pb-scope

  • WebGL 纹理映射模式以及WRAP_S | WRAP_T参数详解

    我们在纹理滤镜一文中已经说明了2个重要的纹理参数,用来定义对象缩放时纹理的处理方式:GL_TEXTURE_MIN_FILTERGL_TEXTURE_MAG_FILTER本文讲解其余几个纹理参数...

  • Three.js入门教程4 - 创建粒子系统动画

    嗨,又见面了。这么说我们已经开始学习Three.js了,如果你还没有看过之前三篇教程,建议你先读完。如果你已经读完前面的教程了,你可能会想做一些关于粒子的东西。让我们直面这个话题吧,每个人都爱粒子效果。不管你是否知道,你可以很轻易地创建它们。

  • Three.js入门教程2 - 着色器(下)

    这是WebGL着色器教程的后半部分,如果你没看过前一篇,阅读这一篇教程可能会使你感到困惑,建议你翻阅前面的教程。

  • 如何基于Canvas来模拟真实雨景Part2:重力掉落和雨滴融合

  • HTML网页布局:静态、自适应、流式、响应式

    静态布局(Static Layout)即传统Web设计,对于PC设计一个Layout,在屏幕宽高有调整时,使用横向和竖向的滚动条来查阅被遮掩部分;对于移动设备,单独设计一个布...

  • Three.js 开发基础知识 - 绘制3D对象

    Three.js是一个用来简化WebGL开发的JavaScript库,比如绘制一个三维立方体,使用WebGL需要100多行,那Three.js只要10几行就能够完成。本文通过创建一个立方体来...

  • Processing.js和P5.js的功能简介和区别

    什么是ProcessingProcessing是关于数字艺术的编程语言,支持跨平台,语言本身是一个类Java语言,程序文件的后缀为.pde。
    什么是Processing.js为了能让Proce...

  • 如何使用CSS3/SCSS实现逼真的车窗雨滴效果

    在天气预报类的Web移动应用中,常常需要实现屏幕的雨滴效果,表示阴雨天气。感觉上比较神奇,其实想通了,这个效果的实现只需要一点物理知识和CSS3的简单变换。实现一个小雨滴首先雨滴是一个个小的椭圆形元素:.raindrop

  • 更多...