h5页面保存img_一文彻底解决HTML5页面中长按保存图片功能

本文详细介绍了如何在H5中实现长按保存图片的功能。

长按保存图片是现在一些宣传页H5中很常见的需求,但是js没有这样的能力,所以要么借助android或ios的原生能力,要么用canvas自己画一个(截屏),相比较原生成本太高,且必须依赖于app,相对于流传性很广且跨平台的H5来说不合时宜,所以 canvas 成为我们常用的手段。

下面是详细的步骤:

1. html2canvas截屏

保存的图片节点最好是img标签: 想要截屏的节点最好是img标签的图片,经测试如果是 background-image 会有点模糊,需要特别注意下。

npm i html2canvas --save

import html2canvas from 'html2canvas';

// 想要保存的图片节点

const dom = document.querySelector('img');

// 创建一个新的canvas

const Canvas = document.createElement('canvas');

const width = document.body.offsetWidth; // 可见屏幕的宽

const height = document.body.offsetHeight; // 可见屏幕的高

const scale = window.devicePixelRadio; // 设备的devicePixelRadio

// 将Canvas画布放大scale倍,然后放在小的屏幕里,解决模糊问题

Canvas.width = width * scale;

Canvas.height = height * scale;

Canvas.getContext('2d').scale(scale, scale);

html2canvas(dom, {

canvas: Canvas,

scale,

useCORS: true,

logging: true,

width: width + 'px',

hegiht: height + 'px',

}).then((canvas) => {

const context = canvas.getContext('2d');

// 关闭抗锯齿形

context.mozImageSmoothingEnabled = false;

context.webkitImageSmoothingEnabled = false;

context.msImageSmoothingEnabled = false;

context.imageSmoothingEnabled = false;

// canvas转化为图片

canvas2Image(canvas, canvas.width, canvas.height);

});

2. canvas2Image转化为图片

一般情况下转为jpeg格式就很不错了。

canvas2Image(canvas, canvas.width, canvas.height) {

const retCanvas = document.createElement('canvas');

const retCtx = retCanvas.getContext('2d');

retCanvas.width = width;

retCanvas.height = height;

retCtx.drawImage(canvas, 0, 0, width, height, 0, 0, width, height);

const img = document.createElement('img');

img.src = retCanvas.toDataURL('image/jpeg'); // 可以根据需要更改格式

return img;

}

3. 长按保存图片

先实现一个长按的方法,长按之后把生成的图片append到body,透明浮在屏幕上。

// 封装一个长按方法

longPress(fn) {

let timeout = 0;

const $this = this;

for (let i = 0; i < $this.length; i++) {

$this[i].addEventListener('touchstart', () => {

timeout = setTimeout(fn, 800); // 长按时间超过800ms,则执行传入的方法

}, false);

$this[i].addEventListener('touchend', () => {

clearTimeout(timeout); // 长按时间少于800ms,不会执行传入的方法

}, false);

}

}

// 添加生成的图片到body

const img = canvas2Image(canvas, canvas.width, canvas.height);

document.body.appendChild(img);

img.style.cssText = "width:100%;height:100%;position:absolute;top:0;left:0;right:0;bottom:0;opacity:0;";

4. 完整代码如下

$.fn.longPress = function(fn) {

let timeout = 0;

const $this = this;

for (let i = 0; i < $this.length; i++) {

$this[i].addEventListener('touchstart', () => {

timeout = setTimeout(fn, 800); // 长按时间超过800ms,则执行传入的方法

}, false);

$this[i].addEventListener('touchend', () => {

clearTimeout(timeout); // 长按时间少于800ms,不会执行传入的方法

}, false);

}

};

$('img').longPress(() => {

saveImg();

});saveImg() {

// 想要保存的图片节点

const dom = document.querySelector('img');

// 创建一个新的canvas

const Canvas = document.createElement('canvas');

const width = document.body.offsetWidth; // 可见屏幕的宽

const height = document.body.offsetHeight; // 可见屏幕的高

const scale = window.devicePixelRatio; // 设备的devicePixelRatio

// 将Canvas画布放大scale倍,然后放在小的屏幕里,解决模糊问题

Canvas.width = width * scale;

Canvas.height = height * scale;

Canvas.getContext('2d').scale(scale, scale);

html2canvas(dom, {

canvas: Canvas,

scale,

useCORS: true,

logging: true,

width: width + 'px',

hegiht: height + 'px',

}).then((canvas) => {

const context = canvas.getContext('2d');

// 关闭抗锯齿形

context.mozImageSmoothingEnabled = false;

context.webkitImageSmoothingEnabled = false;

context.msImageSmoothingEnabled = false;

context.imageSmoothingEnabled = false;

// canvas转化为图片

const img = canvas2Image(canvas, canvas.width, canvas.height);

document.body.appendChild(img);

img.style.cssText = "width:100%;height:100%;position:absolute;top:0;left:0;right:0;bottom:0;opacity:0;";

}

}

canvas2Image(canvas, width, height) {

const retCanvas = document.createElement('canvas');

const retCtx = retCanvas.getContext('2d');

retCanvas.width = width;

retCanvas.height = height;

retCtx.drawImage(canvas, 0, 0, width, height, 0, 0, width, height);

const img = document.createElement('img');

img.src = retCanvas.toDataURL('image/jpeg'); // 可以根据需要更改格式

return img;

}

刚开始做的时候也是网上一堆文章乱看,不断的试错,最后愉快的实现了长按保存图片的功能,做完才发现也很简单哈,这篇文章完整的介绍了整个流程,拿走不谢!

总结

以上所述是小编给大家介绍的一文彻底解决HTML5页面中长按保存图片功能,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/356272.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

c语言float m1 m2什么意思,m1和m2的区别,一文带你秒懂这两者的关联

摩路由M1作为Moto旗下首款路由器&#xff0c;自去年发布以来&#xff0c;备受瞩目。几个月下来&#xff0c;借着强大的信号覆盖和穿墙能力&#xff0c;赢得了不少用户的认可&#xff0c;甚至推崇。不久前发布的摩路由M2&#xff0c;在M1的基础上进行了升级&#xff0c;功能和配…

在fedora下面安装ftp服务器

Fedora版本&#xff1a;Fedora 12 1. 安装vsftp [java] view plaincopy #yum install vsftpd 一路yes&#xff0c;最后提示安装成功。 2. 配置vsftpd.conf。 [java] view plaincopy #vi /etc/vsftpd/vsftpd.conf 将vsftpd.conf文件中的主要设置如下&#xff1a; [java] view …

jenkin swindows启动_windows启动过程

展开全部认真看完这个也许你会有收获的&#xff1a;Windows启动e68a84e8a2ad62616964757a686964616f31333231626165过程介绍相信不少人碰到过装了个什么东西之后&#xff0c;重启Windows就发现起不来了。所以&#xff0c;想把Windows启动过程中作了些什么事情&#xff0c;分哪些…

c语言让电脑发出滴滴声代码,centos命令行控制电脑发出滴滴声——使用beep把警告变为music...

需要先安装beep命令&#xff0c;在ubuntu中可使用apt-get install beep进行安装&#xff0c;在centos中需要先安装repoforge源&#xff0c;然后才使用yum install -y beep进行安装。repoforge源安装后便可进行beep的安装&#xff1a;[rootlocalhost ~]# modprobe pcspkr[rootlo…

如何让代码更易于维护_易于使用的单位和集成代码

如何让代码更易于维护此示例说明如何使用Maven和Sonar为单元和集成测试生成覆盖率。 它使用非常简单的技术&#xff0c;只需10-15分钟即可在任何现有的Maven构建中运行。 它可以用于单元&#xff0c;集成&#xff0c;ATDD或任何其他类型的测试套件。 覆盖率结果显示在声纳中。 …

cascade sqlite 数据库_ON DELETE CASCADE无法正常工作在ios中的sqlite3中

通过启用pragma foreignkeys ON,我以编程方式在ios中创建了一个.sqlite文件NSFileManager *theFileManager [NSFileManager defaultManager];if ([theFileManager fileExistsAtPath:[self getDatabasePath]] NO){char *theError;const char *databasePath [[self getDatabas…

调试 ASP 程序脚本

调试 ASP 脚本 无论您的计划多么精密、经验多么丰富&#xff0c;脚本错误 (bug) 可能在最初就使您的 ASP 服务器端的脚本无法正确运行。也就是说调试&#xff0c;即查找和纠正脚本错误&#xff0c;对开发一个成功的和强健的 ASP 程序是非常重要的。 Microsoft 脚本调试工具 Mic…

C语言用循环写出新年祝福语图案,非常漂亮的新年祝福!C语言实现漂亮的烟花效果...

本文实例为大家分享了C语言实现漂亮的烟花效果展示的具体代码&#xff0c;供大家参考&#xff0c;具体内容如下程序名称&#xff1a;祝福烟花&#xff0c;祝福朋友编译环境&#xff1a;VC6.0 && easyx(立冬版)#include #include #include #include #include #include #…

用Java和Python模仿Kotlin构建器

介绍 Kotlin可能现在是我最喜欢的语言&#xff0c;并且它可能提供的最酷的功能之一是基于几个功能构建的类型安全的生成器&#xff08;稍后解释&#xff09;。 我发现自己真的很想在其他两种主要语言&#xff08;Java和Python&#xff09;中使用此功能。 本文解释了我认为与使用…

python刷阅读_通过python+selenium3实现浏览器刷简书文章阅读量

准备工作下载python&#xff0c;本文以python3.6为例。python3.6下载地址&#xff1a;python3下载地址&#xff0c;选择合适的版本安装。安装成功后&#xff0c;打开命令提示符&#xff0c;在其中输入python&#xff0c;显示如下信息&#xff0c;则说明安装成功。C:\Users\Ubun…

【原】移动web资源整理

2013年初接触移动端&#xff0c;简单做下总结&#xff0c;首先了解下移动web带来的问题 设备更新换代快——低端机遗留下问题、高端机带来新挑战浏览器厂商不统一——兼容问题多网络更复杂——弱网络&#xff0c;页面打开慢低端机性能差——页面操作卡顿HTML5新技术多——学习成…

android的md动画,Android-notes/动画体系详解.md at master · drs0214/Android-notes · GitHub

Android 动画详解&#xff1a;属性动画、View 动画和帧动画在 Android 中&#xff0c;基本的动画共有三种类型&#xff1a;View 动画&#xff1a;也叫视图动画或者补间动画&#xff0c;主要是指 android.view.animation 包下面的一些类&#xff0c;只能被用来设置给 View&#…

蓝桥杯省赛考点_【蓝桥杯单片机01】从历年决赛真题中寻找单片机常见的考点...

【蓝桥杯单片机01】从历年决赛真题中寻找单片机常见的考点广东职业技术学院 欧浩源【第三届&#xff1a;门禁系统】1、功能简述“门禁系统”主要有两种工作模式&#xff1a;模式1&#xff1a;7&#xff1a;00&#xff5e;22&#xff1a;00为自动门状态&#xff0c;该状态下门的…

android 5.0 新功能,Android 5.0新特性有哪些?安卓5.0新功能汇总

Android 5.0新特性有哪些&#xff1f;经过一段时间曝光与测试后&#xff0c;期待已久的Android L系统正式发布了&#xff0c;新一代安卓系统正式名称为Android 5.0 Lollipop(棒棒糖)。Android 5.0新特性有哪些呢&#xff1f;下面&#xff0c;由百事网小编盘大家盘点一下安卓5.0…

cks子,间谍,局部Mo子和短管

本文是我们名为“ 用Mockito进行测试 ”的学院课程的一部分。 在本课程中&#xff0c;您将深入了解Mockito的魔力。 您将了解有关“模拟”&#xff0c;“间谍”和“部分模拟”的信息&#xff0c;以及它们相应的Stubbing行为。 您还将看到使用测试双打和对象匹配器进行验证的过…

[Android] websocket客户端开发

为了能够在H5和APP都保持同一套长连接接口&#xff0c;因为采用websocket协议作为开发 使用的第三方库是&#xff1a;https://github.com/TakahikoKawasaki/nv-websocket-client 一开始在本地开发的时候&#xff0c;就遇到问题了&#xff0c;总是连接不上 WebSocketFactory fac…

8数据提供什么掩膜产品_工业轨式1-8路RS485数据(MODBUS RTU协议)厂家产品说明...

产品描述工业级数点对点光猫提供1-8路RS485&#xff08;MODBUS RTU协议&#xff09;&#xff1b;在光纤中传输&#xff0c;该产品突破了传统串行接口通讯距离与通讯速率的矛盾&#xff0c;同时&#xff0c;也解决了电磁干扰、地环干扰和雷电破坏的难题&#xff0c;大大提高了数…

BZOJ 4568 倍增维护线性基

在树的路径上选取一些点 使得这些点权xor后的结果最大 思路&#xff1a; 时限60s 59696ms卡过去了哈哈哈 //By SiriusRen #include <cstdio> #include <cstring> #include <algorithm> using namespace std; typedef long long ll; const int N20005; ll T…

eureka 集群失败的原因_eureka集群中的疑问?

题主的问题描述太绕了&#xff0c;我们先把集群中的角色定义下&#xff1a;Eureka架构比较细节的架构图如下所示&#xff1a;在配置多个EurekaServer的Service Provider&#xff0c;每次Service Provider启动的时候会选择一个Eureka Server&#xff0c;之后如果这个Eureka Serv…

代码android点击效果,GitHub - likaiyuan559/TouchEffects: Android View点击特效TouchEffects,几行代码为所有控件添加点击效果...

Android 点击特效TouchEffectsTouchEffects能够帮助你更快速方便的增加点击时候的效果&#xff0c;TouchEffects的目标是打造一个稳定、全面、且能更方便的自定义及个性化的一款点击效果框架。功能特点&#xff1a;只需要几行代码便能为全局的View加上点击效果支持多种点击效果…