当前位置: 代码网 > it编程>网页制作>html5 > 基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

2025年06月18日 html5 我要评论
一、引言在 web 开发中,经常会遇到需要对图片进行处理并提供下载功能的需求。本文将深入剖析一段基于 html5 canvas 的代码,该代码实现了图片的旋转(90 度和 180 度)以及旋转后图片的

一、引言

在 web 开发中,经常会遇到需要对图片进行处理并提供下载功能的需求。本文将深入剖析一段基于 html5 canvas 的代码,该代码实现了图片的旋转(90 度和 180 度)以及旋转后图片的下载功能。通过对代码的解读,我们可以学习到如何利用 canvas api 进行图像操作,以及如何实现文件的下载功能。

二、html 结构分析

  • 基本结构:这段 html 代码的基本结构比较简单,包含了一个<head>部分和一个<body>部分。<head>部分主要用于设置页面的元数据和引入外部样式表,<body>部分则包含了页面的实际内容。
  • canvas 元素:在<body>中,有一个<canvas>元素,其idcanvas。这个元素是 html5 提供的用于绘制图形和图像的容器。如果用户的浏览器不支持 html5 的<canvas>标签,那么在<canvas>标签内的文本 “您的浏览器不支持 html5 canvas 标签。” 将会显示出来。
  • 下载按钮:还有一个<div>元素,类名为download,它作为一个下载按钮,文本内容为 “下载”。用户点击这个按钮时,将触发相应的 javascript 函数来实现图片的下载。

三、css 样式分析

  • 下载按钮样式:通过 css 样式定义了.download类的样式。设置了按钮的宽度为100px,高度为40px,背景颜色为白色(#fff),文字颜色为#276787,边框为1px的实线,颜色为#276787。使用display: flex;align-items: center;justify-content: center;使按钮内的文本居中显示。border-radius: 20px;将按钮的边角设置为圆角,使其看起来更加美观。
  • 交互样式:定义了按钮的交互样式。当鼠标悬停在按钮上时(.download:hover),背景颜色变为#276787,文字颜色变为白色,边框变为透明。当按钮被按下时(.download:active),按钮的透明度变为0.4,提供了视觉反馈。

四、javascript 功能实现

  • 图像加载与 canvas 初始化:首先创建一个<img>元素用于加载原始图像,并获取<canvas>元素及其 2d 绘图上下文ctx。设置原始图像的src属性为一个在线图片的 url,并设置crossorigin属性为anonymous,以处理跨域问题。当图像加载完成后(originimage.onload事件触发),获取图像的原始宽度ow和高度oh
  • 图片旋转
    • 90 度旋转(注释部分):代码中注释掉了 90 度旋转的实现。原本的逻辑是将 canvas 的宽度设置为图像的原始高度oh,高度设置为图像的原始宽度ow。然后使用ctx.rotate(-math.pi / 2)将绘图上下文逆时针旋转 90 度,再通过ctx.drawimage(originimage, -ow, 0)将图像绘制到 canvas 上。最后再使用ctx.rotate(math.pi / 2)将绘图上下文顺时针旋转回原来的角度。
    • 180 度旋转(实际实现):将 canvas 的宽度和高度设置为图像的原始宽度ow和高度oh。使用ctx.rotate(math.pi)将绘图上下文顺时针旋转 180 度,然后通过ctx.drawimage(originimage, -ow, -oh)将图像绘制到 canvas 上,实现了图像的 180 度旋转。
  • 生成 base64 编码:旋转后的图像通过canvas.todataurl("image/jpeg", 0.5)方法生成一个 base64 编码的字符串,这里设置图像格式为 jpeg,质量为 0.5。生成的 base64 编码字符串存储在base64变量中。
  • 下载功能实现
    • 方式一(注释部分):注释掉了一种下载实现方式。原本的逻辑是创建一个<a>元素,将其href属性设置为生成的 base64 编码字符串,download属性设置为 “旋转后的图片.png”,然后模拟点击这个<a>元素来触发下载。
    • 方式二(实际实现):创建一个<a>元素,将其href属性设置为通过window.url.createobjecturl(base64toblob(base64))生成的对象 url,download属性设置为 “旋转后的图片.jpg”。base64toblob函数将 base64 编码字符串转换为 blob 对象,然后通过window.url.createobjecturl创建一个可用于下载的 url。最后模拟点击<a>元素来实现图片的下载。
  • base64 转 blob 函数base64toblob函数用于将 base64 编码字符串转换为 blob 对象。它首先将 base64 字符串分割,提取出 mime 类型,然后使用atob方法将 base64 编码的字符串解码为二进制字符串,再将二进制字符串转换为uint8array,最后创建一个新的 blob 对象并返回。

完整代码展示

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta http-equiv="x-ua-compatible" content="ie=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link rel="stylesheet" href="./assets/global.css">
    <style>
        .download {
            width: 100px;
            height: 40px;
            background-color: #fff;
            color: #276787;
            border: 1px solid #276787;

到此这篇关于基于 html5 canvas 实现图片旋转与下载功能的文章就介绍到这了,更多相关html5 canvas图片旋转内容请搜索代码网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com