optimized image list interface

This commit is contained in:
2025-02-17 11:21:57 +08:00
parent d5fd626242
commit 5c0009f0b4
12 changed files with 482 additions and 32 deletions

View File

@@ -14,7 +14,7 @@
创建相册
</AButton>
</div>
<image-toolbar :selected="selected" />
<image-toolbar :selected="selected"/>
<div class="photo-list">
<ATabs size="small" :tabBarGutter="50" type="line" tabPosition="top" :tabBarStyle="{position:'unset'}"
style="width: 99%;">
@@ -37,11 +37,14 @@
:iconSize="20"
:showSelectedEffect="true"
:value="item.id">
<AImage :src="item.url"
<AImage :src="item.thumbnail"
:alt="item.file_name"
:key="index"
style="height: 200px"
:height="200"
:previewMask="false"
:preview="{
src: item.url,
}"
loading="lazy"/>
</CheckCard>
</template>
@@ -73,7 +76,7 @@ import Vue3JustifiedLayout from "vue3-justified-layout";
import 'vue3-justified-layout/dist/style.css';
import ImageUpload from "@/views/Photograph/ImageUpload/ImageUpload.vue";
import useStore from "@/store";
import {queryAllImagesApi} from "@/api/storage";
import {getSingleImageApi, queryAllImagesApi} from "@/api/storage";
import ImageToolbar from "@/views/Photograph/ImageToolbar/ImageToolbar.vue";
@@ -87,7 +90,9 @@ const options = reactive({
const images = ref<any[]>([]);
/**
* 获取所有图片
*/
async function getAllImages() {
const res: any = await queryAllImagesApi("image", false, "ali", "schisandra-album");
if (res && res.code === 200) {
@@ -95,6 +100,30 @@ async function getAllImages() {
}
}
// const previewUrl = ref<string>("");
//
// /**
// * 获取单张图片
// * @param id
// */
// async function getSingleImage(id: number) {
// previewUrl.value = "";
// const res: any = await getSingleImageApi(id);
// if (res && res.code === 200) {
// previewUrl.value = res.data;
// setVisible(true);
// return;
// }
// previewUrl.value = "";
// setVisible(true);
// }
//
// const visible = ref<boolean>(false);
//
// const setVisible = (value): void => {
// visible.value = value;
// };
onMounted(() => {
getAllImages();

View File

@@ -62,6 +62,7 @@ import imageCompression from "browser-image-compression";
import exifr from 'exifr';
import isScreenshot from "@/utils/imageUtils/isScreenshot.ts";
import {getCategoryByLabel} from "@/constant/coco_ssd_label_category.ts";
import {generateThumbnail} from "@/utils/imageUtils/generateThumb.ts";
const predicting = ref<boolean>(false);
const progressPercent = ref<number>(0);
@@ -145,7 +146,7 @@ async function beforeUpload(file: File, fileList: File[]) {
}
// 提取 EXIF 数据
const gpsData = await extractGPSExifData(file);
const gpsData: any = await extractGPSExifData(file);
if (gpsData) {
upload.predictResult.longitude = gpsData.longitude;
upload.predictResult.latitude = gpsData.latitude;
@@ -210,12 +211,21 @@ const {uploading, send: submitFile, abort} = useRequest(uploadFile, {
* @param file
*/
async function customUploadRequest(file: any) {
const compressedFile = await imageCompression(file.file, options);
// 生成缩略图
const {binaryData, width, height, size} = await generateThumbnail(compressedFile);
upload.predictResult.thumb_w = width;
upload.predictResult.thumb_h = height;
upload.predictResult.thumb_size = size;
const formData = new FormData();
formData.append("file", file.file);
if (binaryData) {
formData.append("thumbnail", binaryData);
}
formData.append("data", JSON.stringify({
provider: 'ali',
bucket: 'schisandra',
bucket: 'schisandra-album',
fileType: file.file.type,
...upload.predictResult,
}));
@@ -276,14 +286,24 @@ async function extractGPSExifData(file) {
if (!supportedFormats.includes(file.type)) {
return null;
}
const options: any = {
ifd0: false,
exif: false,
gps: ['GPSLatitudeRef', 'GPSLatitude', 0x0003, 0x0004],
interop: false,
ifd1: false // thumbnail
};
// 提取GPS EXIF 数据
let {latitude, longitude} = await exifr.gps(file);
if (latitude && longitude) {
return {latitude, longitude};
} else {
const gpsData = await exifr.parse(file, options);
if (!gpsData) {
return null;
}
const {latitude, longitude} = gpsData;
if (latitude && longitude) {
return {latitude, longitude};
}
return null;
}
</script>