我正在用 jquery 创建一个图片库。是否有可能使用 jquery 计算图像是横向还是纵向?
谢谢你的支持。
您可以简单地比较图像的宽度和高度。
var someImg = $("#someId");
if (someImg.width() > someImg.height()){
//it's a landscape
} else if (someImg.width() < someImg.height()){
//it's a portrait
} else {
//image width and height are equal, therefore it is square.
}
这对我有用,使用自然高度/宽度来获取原始属性。
function imageOrientation(src) {
var orientation,
img = new Image();
img.src = src;
if (img.naturalWidth > img.naturalHeight) {
orientation = 'landscape';
} else if (img.naturalWidth < img.naturalHeight) {
orientation = 'portrait';
} else {
orientation = 'even';
}
return orientation;
}
下面的 javascript 函数将返回最适合的方向
function get_orientation(src){
img = new Image();
img.src = src;
var width = img.width;
var height = img.height;
height = height + height // Double the height to get best
//height = height + (height / 2) // Increase height by 50%
if(width > height) {
return "landscape";
} else {
return "portrait";
}
}
如果您动态添加媒体或使用dataUrl
,则在将元素放入 DOM 之前,您无法访问大小。
resolveImage(fileEntry) // implementation detail
.then(src => {
const img = document.importNode(itmp, true) // use a template or `createElement()`
img.src = src // '...'
img.onload = ({target: el}) => (el.height > el.width) ? el.classList.add('portrait') : el.classList.add('landscape')
grid.appendChild(img)
})
视频
resolveVideo(fileEntry)
.then(({src, type}) => {
const vid = document.importNode(vtmp, true)
vid.type = type
vid.src = src
vid.onloadeddata = ({target: el}) => (el.videoHeight > el.videoWidth) ? el.classList.add('portrait') : el.classList.add('landscape')
grid.appendChild(vid)
})