图片(Image)实现技术
重要通知
类目简介
基本概况
JS处理图片机制
- 加载图片
下载图片
export function downloadIamge(imgsrc, name) {
//下载图片地址和图片名
var image = new Image()
// 解决跨域 Canvas 污染问题
image.src = imgsrc
// image.src = imgsrc + '?timestamp=' + new Date().getTime()
// console.log(image)
image.setAttribute('crossorigin', 'anonymous')
image.onload = function () {
var canvas = document.createElement('canvas')
canvas.width = image.width
canvas.height = image.height
var context = canvas.getContext('2d')
context.drawImage(image, 0, 0, image.width, image.height)
var url = canvas.toDataURL('image/png') //得到图片的base64编码数据
var a = document.createElement('a') // 生成一个a元素
var event = new MouseEvent('click') // 创建一个单击事件
a.download = name || 'photo' // 设置图片名称
a.href = url // 将生成的URL设置为a.href属性
a.dispatchEvent(event) // 触发a的单击事件
}
image.onerror = (err) => {
console.log(err)
window.open(imgsrc)
// var img = document.getElementById('girlImg') // 获取要下载的图片
// var url = imgsrc // 获取图片地址
// var a = document.createElement('a') // 创建一个a节点插入的document
// var event = new MouseEvent('click') // 模拟鼠标click点击事件
// a.download = name // 设置a节点的download属性值
// a.href = url // 将图片的src赋值给a节点的href
// a.target = '_blank'
// a.dispatchEvent(event) // 触发鼠标点击事件
}
}
<img>
标签
图像定义 HTML 页面中的图像。
<!--draggable 设置拖动权限-->
<img src="" draggable="false" crossorigin="anonymous" alt="" title="" />
<!--crossorigin属性 | Access-Control-Allow-Credentials
anonymous:如果使用这个值的话就会在请求中的header中的带上Origin属性,但请求不会带上cookie和其他的一些认证信息。
use-credentials:这个就同时会在跨域请求中带上cookie和其他的一些认证信息。
例如阿里云OSS上的图片路径,设置crossorigin后需要加上时间戳,'jsdhfkhdjf?t=' + Date.now()
这里顺带提下img加载相关 属性
onload:表示加载好,换言之,没有加载好不会执行;
onAbort:图片加载的时候,用户通过点击停止加载时出发
onerror:如果图片不存在(网络很不通畅,也可能触发 onerror事件)
complete:图片显示出来以后为true,
-->
srcset属性
是以逗号分隔的图像文件名及其宽度或密度描述符的列表。
<img
src="flower-large.jpg"
srcset="flower-small.jpg 480w, flower-large.jpg 1080w"
sizes="50vw"
/>
sizes属性
表示资源大小的、以逗号隔开的一个或多个字符串。在支持 srcset 的用户代理中,当使用 w 描述符时,src 属性会被忽略。当匹配了媒体条件 (max-width: 600px) 时,将加载 200 像素宽的图像(最匹配的图像),否则将加载另一幅图像。
<img
src="clock-demo-200px.png"
alt="Clock"
srcset="clock-demo-200px.png 200w, clock-demo-400px.png 400w"
sizes="(max-width: 600px) 200px, 50vw" />
loading 属性
loading 属性指定浏览器是应立即加载图像还是延迟加载图像。
----------------------------------------------------------------------------------
值 描述
----------------------------------------------------------------------------------
eager 默认,图像立即加载。
lazy 图像延迟加载,只有鼠标滚动到该图片所在位置才会显示。
----------------------------------------------------------------------------------
- 代码示例
<!--loading属性支持的值
auto: 浏览器默认的延迟加载行为,与不包含属性相同。
lazy:推迟资源的加载,直到它到达与视口的计算距离。
eager:立即加载资源,无论它位于页面上的哪个位置。
-->
<img src="image.png" loading="lazy" alt="…" width="200" height="200">
<!-- 设置延迟加载的图片 -->
<img decoding="async" src="/images/paris.jpeg" alt="Paris" style="width:100%" loading="lazy">
fetchpriority
提供获取图像时要使用的相对的优先级提示。
<img
src="image.png"
fetchpriority="high" 表示其获取优先级相对其他图像要高。
fetchpriority="low" 表示其获取优先级相对其他图像要低。
fetchpriority="auto" 默认值:表示自动确定其相对其他图像的获取优先级。
/>
相关操作方法
// 获取图片路径
let URL = window.URL || window.webkitURL;
let img_src = URL.createObjectURL(url);
// 释放内存
URL.revokeObjectURL(img_src);
const image = new Image();
image.onload = function(e) {
let width = image.naturalWidth;
let height = image.naturalHeight;
if (width > height) {
setw = window.FONT['size']/100*225;
seth = window.FONT['size']/100*169;
} else {
setw = window.FONT['size']/100*169;
seth = window.FONT['size']/100*225;
}
document.body.append(image);
}
image.onerror = function() {
//
}
image.crossOrigin = 'anonymous';
image.src = thumbnail;
const initImageSize = (imageUrl: string) => {
const image = new Image()
return new Promise((resolve) => {
image.onload = function (e) {
const width = image.naturalWidth
const height = image.naturalHeight
resolve({ width, height })
}
image.onerror = function () {
resolve({})
}
image.crossOrigin = 'anonymous'
image.src = imageUrl
})
}
上传图片
const fileEl: HTMLInputElement = document.createElement("input");
if (!fileEl) return;
fileEl.setAttribute("type", "file");
fileEl.setAttribute("accept", "image/gif,image/jpeg,image/png");
fileEl.click();
const getFileData = (fileTarget: HTMLInputElement) => {
return new Promise((resolve) => {
fileTarget.onchange = async function (e) {
// @ts-ignore # 忽视本行代码的小错误
resolve(e.target.files[0]);
};
});
};
const fileData = await getFileData(fileEl);
const formData = new FormData();
// @ts-ignore # 忽视本行代码的小错误
formData.append("file", fileData);
new Image对象
上传图片本地预览
const fileEl: HTMLInputElement = document.createElement("input");
if (!fileEl) return;
fileEl.setAttribute("type", "file");
fileEl.setAttribute("accept", "image/gif,image/jpeg,image/png");
fileEl.click();
const getFileData = (fileTarget: HTMLInputElement) => {
return new Promise((resolve) => {
fileTarget.onchange = async function (e) {
// @ts-ignore # 忽视本行代码的小错误
resolve(e.target.files[0]);
};
});
};
const fileData = await getFileData(fileEl);
const reader = new FileReader();
// 异步
const getData = () => {
const reader = new FileReader();
return new Promise((resolve) => {
reader.onload = function(e) {
console.info(e.atrget.result);
resolve(reader.result);
}
});
}
const imagePath = await getData();
图片实现原理
图像(Image)
图像是位图(Bitmap)
图像增强
前端图像处理图图像增强
改善图像质量、分析图像、图像转换、图像处理
AlloyImage 图像处理库:https://tool.oschina.net/alloyphoto# http://alloyteam.github.io/AlloyPhoto/ 1.图层功能,提供图层的添加,删除,交换图层顺序等功能,且包含与PS相对应的17种图层混合模式 2.图像的基本调节功能,包括亮度、对比度,色相、饱和度、明度调节 3.多种滤镜功能,去色、反相、高斯模糊、锐化、浮雕效果、查找边缘、马赛克、腐蚀等 4.处理后文件的保存,处理完成之后,可以将文件输出为base64形式间接使用和保存 5.高级组合效果,如素描,lomo,复古,素描等复合效果 如一个素描效果的实现
图像滤镜艺术:专业介绍图像处理中各种滤镜的算法实现。
https://www.kancloud.cn/trent/hotoimagefilter/102786 图像滤镜实现万能方法研究:https://trent.blog.csdn.net/article/details/42212459?spm=1001.2101.3001.6650.17&utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7EBlogCommendFromBaidu%7Edefault-18.no_search_link&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7EBlogCommendFromBaidu%7Edefault-18.no_search_link 图像处理的滤镜算法:https://blog.csdn.net/tomy2426214836/article/details/88889298 数字图像处理课题研究:https://blog.csdn.net/trent1985/category_9263763.html 数字图像处理研究:https://blog.csdn.net/trent1985/category_1850555.html 图片滤镜算法原理简单讲解:https://blog.csdn.net/weixin_34152820/article/details/85461116?spm=1001.2101.3001.6650.1&utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7Edefault-1.no_search_link&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7Edefault-1.no_search_link 图像处理的滤镜算法:https://blog.csdn.net/tomy2426214836/article/details/88889298 图像特效及滤镜算法汇总 https://blog.csdn.net/matrix_space/article/details/42743613?utm_medium=distribute.pc_relevant.none-task-blog-2~default~baidujs_title~default-1.essearch_pc_relevant&spm=1001.2101.3001.4242.2
MIME-type
image/gif gif
image/jpeg jpe
image/jpeg jpeg
image/jpeg jpg
image/png png
image/bmp bmp
image/cis-cod cod
image/ief ief
image/pipeg jfif
image/svg+xml svg
image/tiff tif
image/tiff tiff
image/x-cmu-raster ras
image/x-cmx cmx
image/x-icon ico
image/x-portable-anymap pnm
image/x-portable-bitmap pbm
image/x-portable-graymap pgm
image/x-portable-pixmap ppm
image/x-rgb rgb
image/x-xbitmap xbm
image/x-xpixmap xpm
image/x-xwindowdump xwd
常见不同图片格式
- APNG(动态可移植网络图形)——无损动画序列的不错选择(GIF 性能较差)。
- AVIF(AV1 图像文件格式)——静态图像或动画的不错选择,其性能较好。
- GIF(图像互换格式)——简单图像和动画的不错选择。
- JPEG(联合图像专家组)——有损压缩静态图像的不错选择(目前最流行的格式)。
- PNG(便携式网络图形)——对于无损压缩静态图像而言是不错的选择(质量略好于 JPEG)。
- SVG(可缩放矢量图形)——矢量图像格式。用于必须以不同尺寸准确描绘的图像。
- WebP(网络图片格式)——图像和动画的绝佳选择。
APNG
(动态可移植网络图形)——无损动画序列的不错选择(GIF 性能较差)。
AVIF
(AV1 图像文件格式)——静态图像或动画的不错选择,其性能较好。
GIF
(图像互换格式)——简单图像和动画的不错选择。
JPEG
(联合图像专家组)——有损压缩静态图像的不错选择(目前最流行的格式)。
PNG
(便携式网络图形)——对于无损压缩静态图像而言是不错的选择(质量略好于 JPEG)。
SVG
(可缩放矢量图形)——矢量图像格式。用于必须以不同尺寸准确描绘的图像。
WebP
(网络图片格式)——图像和动画的绝佳选择。
WebP
- 检测浏览器是否支持WebP格式图片
window.isSupportWebp = false; // 是否支持
(function() {
var img = new Image();
function getResult(event) {
// 如果进入加载且图片宽度为1(通过图片宽度值判断图片是否可以显示)
window.isSupportWebp = event && event.type === 'load' ? img.width == 1 : false;
}
img.onerror = getResult;
img.onload = getResult;
img.src = ''; // 一像素图片
})();
Gif
https://github.com/jnordberg/gif.js
常见算法列表
FXAA 抗锯齿算法
FXAA 抗锯齿算法的实现:https://jelly.jd.com/article/5efd42154b54be014cf4e646
插件体系
cropperjs插件
官网:https://github.com/fengyuanchen/cropperjs vue-cropperjs:https://github.com/Agontuk/vue-cropperjs
vue-cropperjs裁剪的尺寸变化事件导致滚动失效
图片工具
CanvasKeyFrames
图片序列帧播放工具,用canvas操作图片动画,封装了常用方法。