mirror of
https://github.com/xuthus83/pigallery2.git
synced 2024-11-03 21:04:03 +08:00
Merge remote-tracking branch 'origin/master'
This commit is contained in:
commit
f2538410f6
2
.github/workflows/build.yml
vendored
2
.github/workflows/build.yml
vendored
@ -218,7 +218,7 @@ jobs:
|
|||||||
uses: docker/build-push-action@v2
|
uses: docker/build-push-action@v2
|
||||||
with:
|
with:
|
||||||
context: .
|
context: .
|
||||||
file: docker/debian-stretch/Dockerfile.build
|
file: docker/debian-buster/Dockerfile.build
|
||||||
platforms: linux/amd64,linux/arm64,linux/arm/v7
|
platforms: linux/amd64,linux/arm64,linux/arm/v7
|
||||||
push: true
|
push: true
|
||||||
tags: bpatrik/pigallery2:nightly-buster
|
tags: bpatrik/pigallery2:nightly-buster
|
||||||
|
BIN
demo/images/IMG_6253_exiftool.jpg
Normal file
BIN
demo/images/IMG_6253_exiftool.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 889 KiB |
@ -210,29 +210,45 @@ export class MetadataLoader {
|
|||||||
const faces: FaceRegion[] = [];
|
const faces: FaceRegion[] = [];
|
||||||
if (ret.Regions && ret.Regions.value.RegionList && ret.Regions.value.RegionList.value) {
|
if (ret.Regions && ret.Regions.value.RegionList && ret.Regions.value.RegionList.value) {
|
||||||
for (let i = 0; i < ret.Regions.value.RegionList.value.length; i++) {
|
for (let i = 0; i < ret.Regions.value.RegionList.value.length; i++) {
|
||||||
if (!ret.Regions.value.RegionList.value[i].value ||
|
if (ret.Regions.value.RegionList.value[i].value &&
|
||||||
!ret.Regions.value.RegionList.value[i].value['rdf:Description'] ||
|
ret.Regions.value.RegionList.value[i].value['rdf:Description'] &&
|
||||||
!ret.Regions.value.RegionList.value[i].value['rdf:Description'].value ||
|
ret.Regions.value.RegionList.value[i].value['rdf:Description'].value &&
|
||||||
!ret.Regions.value.RegionList.value[i].value['rdf:Description'].value['mwg-rs:Area']) {
|
ret.Regions.value.RegionList.value[i].value['rdf:Description'].value['mwg-rs:Area']) {
|
||||||
continue;
|
const region = ret.Regions.value.RegionList.value[i].value['rdf:Description'];
|
||||||
|
const regionBox = ret.Regions.value.RegionList.value[i].value['rdf:Description'].value['mwg-rs:Area'].attributes;
|
||||||
|
if (region.attributes['mwg-rs:Type'] !== 'Face' ||
|
||||||
|
!region.attributes['mwg-rs:Name']) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
const name = region.attributes['mwg-rs:Name'];
|
||||||
|
const box = {
|
||||||
|
width: Math.round(parseFloat('' + regionBox['stArea:w']) * metadata.size.width),
|
||||||
|
height: Math.round(parseFloat('' + regionBox['stArea:h']) * metadata.size.height),
|
||||||
|
left: Math.round(parseFloat('' + regionBox['stArea:x']) * metadata.size.width),
|
||||||
|
top: Math.round(parseFloat('' + regionBox['stArea:y']) * metadata.size.height)
|
||||||
|
};
|
||||||
|
// convert center base box to corner based box
|
||||||
|
box.left = Math.max(0, box.left - box.width / 2);
|
||||||
|
box.top = Math.max(0, box.top - box.height / 2);
|
||||||
|
faces.push({name: name, box: box});
|
||||||
|
} else if((ret.Regions.value.RegionList.value[i] as any).Area &&
|
||||||
|
(ret.Regions.value.RegionList.value[i] as any).Name &&
|
||||||
|
(ret.Regions.value.RegionList.value[i] as any).Type) {
|
||||||
|
const regionBox = (ret.Regions.value.RegionList.value[i] as any).Area.value;
|
||||||
|
const name = (ret.Regions.value.RegionList.value[i] as any).Name.value;
|
||||||
|
const type = (ret.Regions.value.RegionList.value[i] as any).Type.value;
|
||||||
|
if (type !== 'Face') continue;
|
||||||
|
const box = {
|
||||||
|
width: Math.round(parseFloat(regionBox.w.value) * metadata.size.width),
|
||||||
|
height: Math.round(parseFloat(regionBox.h.value) * metadata.size.height),
|
||||||
|
left: Math.round(parseFloat(regionBox.x.value) * metadata.size.width),
|
||||||
|
top: Math.round(parseFloat(regionBox.y.value) * metadata.size.height)
|
||||||
|
};
|
||||||
|
// convert center base box to corner based box
|
||||||
|
box.left = Math.max(0, box.left - box.width / 2);
|
||||||
|
box.top = Math.max(0, box.top - box.height / 2);
|
||||||
|
faces.push({name: name, box: box});
|
||||||
}
|
}
|
||||||
const region = ret.Regions.value.RegionList.value[i].value['rdf:Description'];
|
|
||||||
const regionBox = ret.Regions.value.RegionList.value[i].value['rdf:Description'].value['mwg-rs:Area'].attributes;
|
|
||||||
if (region.attributes['mwg-rs:Type'] !== 'Face' ||
|
|
||||||
!region.attributes['mwg-rs:Name']) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
const name = region.attributes['mwg-rs:Name'];
|
|
||||||
const box = {
|
|
||||||
width: Math.round(parseFloat('' + regionBox['stArea:w']) * metadata.size.width),
|
|
||||||
height: Math.round(parseFloat('' + regionBox['stArea:h']) * metadata.size.height),
|
|
||||||
left: Math.round(parseFloat('' + regionBox['stArea:x']) * metadata.size.width),
|
|
||||||
top: Math.round(parseFloat('' + regionBox['stArea:y']) * metadata.size.height)
|
|
||||||
};
|
|
||||||
// convert center base box to corner based box
|
|
||||||
box.left = Math.max(0, box.left - box.width / 2);
|
|
||||||
box.top = Math.max(0, box.top - box.height / 2);
|
|
||||||
faces.push({name: name, box: box});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (Config.Client.Faces.keywordsToPersons && faces.length > 0) {
|
if (Config.Client.Faces.keywordsToPersons && faces.length > 0) {
|
||||||
|
Loading…
Reference in New Issue
Block a user