Skip to content

Commit

Permalink
[feat]: 将目录的读取方式改成异步
Browse files Browse the repository at this point in the history
  • Loading branch information
youyeke committed Jul 6, 2024
1 parent c78624d commit 67d265e
Show file tree
Hide file tree
Showing 9 changed files with 128 additions and 12 deletions.
7 changes: 5 additions & 2 deletions .vscode/settings.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"editor.bracketPairColorization.enabled": true,
"editor.guides.bracketPairs": true,
"editor.formatOnSave": true,
"editor.formatOnSave": false,
"editor.defaultFormatter": "esbenp.prettier-vscode",
"editor.codeActionsOnSave": ["source.fixAll.eslint"],
"eslint.validate": ["javascript", "javascriptreact", "typescript", "vue"],
Expand All @@ -15,5 +15,8 @@
"pswp",
"todos",
"viewerjs"
]
],
"[vue]": {
"editor.defaultFormatter": "vscode.typescript-language-features"
}
}
80 changes: 80 additions & 0 deletions src-electron/AsyncReadFilePath.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
import fs from 'fs-extra'
import path from 'path'
import imageSize from 'image-size'
import { promisify } from 'util'
import type { WImage } from './traverseFolder'
import { mainWindow } from './electron-main'

const sizeOf = promisify(imageSize)

export default class AsyncReadFilePath {
picLinks = [] as WImage[]
/** 有效的图片格式 */
picFormats = [] as string[]
/** 任务名称 */
taskName
/** 每页分割的大小 */
pageSize = 20

constructor(taskName: string, picFormats: string[], pageSize: number) {
this.taskName = taskName
this.picFormats = picFormats
this.pageSize = pageSize || 20
}

async readDirectory(dir: string) {
const stack = [dir]
const pageStack = [] as WImage[]

while (stack.length) {
// 深度优先
const currentPath = stack.pop()
if (!currentPath) {
continue
}
const files = await fs.readdir(currentPath, { withFileTypes: true })
files.sort((a, b) => b.name.localeCompare(a.name, undefined, { sensitivity: 'base' }))

const result = [] as WImage[]
for (const file of files) {
const fullPath = path.join(currentPath, file.name)
if (file.isDirectory()) {
stack.push(fullPath)
} else if (file.isFile()) {
const extname = path.extname(fullPath).toLowerCase()
if (this.picFormats.includes(extname)) {
await sizeOf(fullPath).then(dimensions => {
result.push({
source: fullPath,
src: 'atom://' + fullPath,
srcThumb: 'atom://' + fullPath,
width: dimensions?.width,
height: dimensions?.height,
})

}).catch(err => {
console.log('sizeOf error', err)
})
}
}
}
pageStack.push(...result.reverse())
if (pageStack.length >= this.pageSize) {
this.picLinks.push(...pageStack.splice(0, this.pageSize))
this.taskReport()
}
}

if (pageStack.length) {
this.picLinks.push(...pageStack.splice(0, pageStack.length - 1))
this.taskReport()
}

}

taskReport() {
if (mainWindow && this.picLinks.length) {
mainWindow.webContents.send('async:imageLinks-append', this.taskName, this.picLinks)
}
}
}
6 changes: 5 additions & 1 deletion src-electron/IPC-main.ts
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ function isFileSync (path) {
let store = new Store();
// 重构判断是否为空并

import { imageRetrieval } from './traverseFolder';
import { imageRetrieval, imageRetrievalAsync } from './traverseFolder';

export function data_init () {
if (!store.get('itemNum')) store = new Store({ schema });
Expand Down Expand Up @@ -62,6 +62,10 @@ export function ipcMains (value: void): any {
return imageRetrieval(path, pFormats);
});

ipcMain.handle('tool-traverseFolder-async', (event, path, pFormats, pPageNum) => {
return imageRetrievalAsync(path, pFormats, pPageNum);
});

ipcMain.handle('tool-openLink', (event, link) => {
console.log(link);
return shell.openExternal(link);
Expand Down
2 changes: 1 addition & 1 deletion src-electron/electron-main.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ initialize();
// needed in case process is undefined under Linux
const platform = process.platform || os.platform();

let mainWindow: BrowserWindow | undefined;
export let mainWindow: BrowserWindow | undefined;

function createWindow () {
/**
Expand Down
10 changes: 10 additions & 0 deletions src-electron/electron-preload.ts
Original file line number Diff line number Diff line change
Expand Up @@ -51,21 +51,28 @@ export type myWindowAPI = {

export type myToolAPI = {
traverseFolder: (path: string, pFormats: any) => any;
traverseFolderAsync: (path: string, pFormats: string[], perPageNum: number) => any;
openLink: (link: string) => any;
delPic: (src: string) => any;
openPath: (src: string) => any;
showItemInFolder: (src: string) => any;
onAsyncImageLinksAppend: (handle: (event: IpcRendererEvent, taskName: string, paths: WImage[]) => void) => void;
};

import { contextBridge, ipcRenderer } from 'electron';
import type { IpcRendererEvent } from 'electron';
import { BrowserWindow, app, shell } from '@electron/remote';
import type { WImage } from './traverseFolder';

// eslint-disable-next-line @typescript-eslint/no-explicit-any

const myToolAPIs: myToolAPI = {
async traverseFolder (path, pFormats) {
return await ipcRenderer.invoke('tool-traverseFolder', path, pFormats);
},
async traverseFolderAsync (path, pFormats, perPageNum) {
return await ipcRenderer.invoke('tool-traverseFolder-async', path, pFormats, perPageNum);
},
async openLink (link) {
return await ipcRenderer.invoke('tool-openLink', link);
},
Expand All @@ -77,6 +84,9 @@ const myToolAPIs: myToolAPI = {
},
async showItemInFolder (src) {
shell.showItemInFolder(src);
},
onAsyncImageLinksAppend(handle) {
ipcRenderer.on('async:imageLinks-append', handle);
}
};

Expand Down
9 changes: 8 additions & 1 deletion src-electron/traverseFolder.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
// import remote from '@electron/remote'
import fs from 'fs-extra';
import * as path from 'path';
import AsyncReadFilePath from './AsyncReadFilePath';

// import { promisify } from 'util';
const sizeOf = require('image-size');
Expand All @@ -27,7 +28,7 @@ let picFormats: any[] = [
'.jfif'
];

interface WImage {
export interface WImage {
source: string;
src: string;
srcThumb: string;
Expand Down Expand Up @@ -121,6 +122,12 @@ export function imageRetrieval (thepath, pFormats) {
console.log('Finish traverseFolderObjects!');
return picLinks;
}

export function imageRetrievalAsync(thepath, pFormats, pageSize) {
if (pFormats) picFormats = pFormats;
const asyncReadFilePath = new AsyncReadFilePath(thepath, picFormats, pageSize)
asyncReadFilePath.readDirectory(thepath)
}
// // 开始遍历
// traverseFolder(rootPath);

Expand Down
3 changes: 3 additions & 0 deletions src/components/WaterFall.vue
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,9 @@ const props = defineProps({
})

let oImgs = ref(props.imgs) // 啥玩意《
watch(() => props.imgs.length, (newImgs) => {
oImgs.value = props.imgs
})
const inputPageValue = ref(1)
// import { LazyImg, Waterfall } from 'vue-waterfall-plugin-next'
// import 'vue-waterfall-plugin-next/dist/style.css'
Expand Down
20 changes: 14 additions & 6 deletions src/pages/IndexPage.vue
Original file line number Diff line number Diff line change
Expand Up @@ -65,10 +65,11 @@ import type { UploadInst } from 'naive-ui'

import WaterFall from 'components/WaterFall.vue'
import SetComponent from 'components/SetComponent.vue'
import type { WImage } from 'app/src-electron/traverseFolder'

const upload = ref<UploadInst | null>()
const ifImgPreOK = ref<boolean>(false)
const imgs = ref([])
const imgs = ref<WImage[]>([])

import { useSettingStore } from 'stores/viewerSet-store';
const setStore = useSettingStore()
Expand Down Expand Up @@ -101,11 +102,18 @@ async function querydb() {

async function picInfoInit(fpath) {
console.log('picInfoInit')
let aa = JSON.parse(JSON.stringify(setStore.getPFormat))
console.log(aa)
imgs.value = await window.myToolAPI.traverseFolder(fpath, aa)
// console.log(imgs.value)
ifImgPreOK.value = true
const pFormat = JSON.parse(JSON.stringify(setStore.getPFormat))
const perPageNum = JSON.parse(JSON.stringify(setStore.getPerPageNum))

// imgs.value = await window.myToolAPI.traverseFolder(fpath, pFormat)

window.myToolAPI.traverseFolderAsync(fpath, pFormat, perPageNum)
window.myToolAPI.onAsyncImageLinksAppend((event, taskName, paths) => {
if (taskName === fpath) {
imgs.value = paths
ifImgPreOK.value = true
}
})
}

import { normalizePath } from './normalize-path'
Expand Down
3 changes: 2 additions & 1 deletion src/stores/viewerSet-store.ts
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,8 @@ export const useSettingStore = defineStore('setting', {
}),
getters: {
// doubleCount: state => state.counter * 2
getPFormat: state => state.imageFormat
getPFormat: state => state.imageFormat,
getPerPageNum: state => state.perPageNum,
},
actions: {
increment () {
Expand Down

0 comments on commit 67d265e

Please sign in to comment.