From 65f4ebe723f646ed75dd4a5c689f6ece3263b4b3 Mon Sep 17 00:00:00 2001 From: GuoJiKun Date: Tue, 7 Jan 2025 15:37:44 +0800 Subject: [PATCH 1/2] =?UTF-8?q?fix:=20=E4=BF=AE=E5=A4=8D=E6=A1=8C=E9=9D=A2?= =?UTF-8?q?=E5=BA=93=E5=8F=96=E5=80=BC=E9=94=99=E8=AF=AF?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- package.json | 2 +- src-tauri/Cargo.lock | 2 +- src-tauri/Cargo.toml | 2 +- src-tauri/src/preview.rs | 25 ++++++++++++------------- src-tauri/tauri.conf.json | 2 +- 5 files changed, 16 insertions(+), 17 deletions(-) diff --git a/package.json b/package.json index 53ccfee..8c2ad76 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "quicklook", - "version": "0.8.1", + "version": "0.8.2", "description": "Windows 平台的文件预览工具", "private": true, "type": "module", diff --git a/src-tauri/Cargo.lock b/src-tauri/Cargo.lock index 4d0428e..2105a6f 100644 --- a/src-tauri/Cargo.lock +++ b/src-tauri/Cargo.lock @@ -121,7 +121,7 @@ checksum = "4c95c10ba0b00a02636238b814946408b1322d5ac4760326e6fb8ec956d85775" [[package]] name = "app" -version = "0.8.1" +version = "0.8.2" dependencies = [ "calamine", "chrono", diff --git a/src-tauri/Cargo.toml b/src-tauri/Cargo.toml index 53d0d5e..2477467 100644 --- a/src-tauri/Cargo.toml +++ b/src-tauri/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "app" -version = "0.8.1" +version = "0.8.2" description = "Windows 平台的文件预览工具" authors = ["GuoJikun "] license = "" diff --git a/src-tauri/src/preview.rs b/src-tauri/src/preview.rs index f8a7037..06a3d33 100644 --- a/src-tauri/src/preview.rs +++ b/src-tauri/src/preview.rs @@ -1,6 +1,5 @@ use std::sync::mpsc; use std::thread; -use log::kv::ToValue; use tauri::{ webview::PageLoadEvent, AppHandle, Error as TauriError, Manager, WebviewUrl, WebviewWindowBuilder }; @@ -12,14 +11,14 @@ use windows::{ Com::{ CoCreateInstance, CoInitializeEx, CoUninitialize, IDispatch, IServiceProvider, CLSCTX_INPROC_SERVER, CLSCTX_LOCAL_SERVER, COINIT_APARTMENTTHREADED }, - SystemServices::{SFGAO_BROWSABLE, SFGAO_FILESYSTEM, SFGAO_FOLDER, SFGAO_STORAGE}, + SystemServices::SFGAO_FILESYSTEM, Variant::{self} }, UI::{ Accessibility::{CUIAutomation, IUIAutomation, IUIAutomationSelectionPattern, UIA_NamePropertyId, UIA_SelectionPatternId}, Input::KeyboardAndMouse, Shell::{ - FOLDERID_Documents, FOLDERID_Downloads, FOLDERID_Libraries, FOLDERID_Music, FOLDERID_Pictures, FOLDERID_Videos, IShellBrowser, IShellItem, IShellItemArray, IShellView, IShellWindows, SHCreateItemFromParsingName, SHGetKnownFolderPath, ShellWindows, KF_FLAG_DEFAULT, SIGDN_DESKTOPABSOLUTEPARSING, SIGDN_FILESYSPATH, SIGDN_NORMALDISPLAY, SVGIO_SELECTION, SWC_DESKTOP, SWFO_NEEDDISPATCH + FOLDERID_Desktop, FOLDERID_Documents, FOLDERID_Downloads, FOLDERID_Libraries, FOLDERID_Music, FOLDERID_Pictures, FOLDERID_Videos, IShellBrowser, IShellItem, IShellItemArray, IShellView, IShellWindows, SHCreateItemFromParsingName, SHGetKnownFolderPath, ShellWindows, KF_FLAG_DEFAULT, SIGDN_DESKTOPABSOLUTEPARSING, SIGDN_FILESYSPATH, SVGIO_SELECTION, SWC_DESKTOP, SWFO_NEEDDISPATCH }, WindowsAndMessaging }, @@ -186,8 +185,8 @@ impl Selected { let phwnd = shell_browser.GetWindow().unwrap(); let top = WindowsAndMessaging::GetAncestor(phwnd, WindowsAndMessaging::GA_ROOT); - if hwnd_gfw.0 != top.0 { - log::info!("top hwnd 不相等"); + if !hwnd_gfw.eq(&top) { + log::info!("fwhwnd: {:?}, top: {:?} 不相等", hwnd_gfw, top); return Ok(target_path); } @@ -279,7 +278,7 @@ impl Selected { } let breadcrumb_hwnd = breadcrumb_hwnd.unwrap(); let mut breadcrumb_title = win::get_window_text(breadcrumb_hwnd); - println!("breadcrumb_title: {:?}", breadcrumb_title); + log::info!("弹窗目录: {:?}", breadcrumb_title); let arr = breadcrumb_title.split(": ").map(|item|item.to_string()).collect::>(); if arr.len() > 1 { breadcrumb_title = arr[1].clone(); @@ -287,7 +286,7 @@ impl Selected { if !breadcrumb_title.contains(":\\") { let path = Self::get_library_path(&breadcrumb_title); - println!("path: {:?}", path); + log::error!("path: {:?}", path); if path.is_err() { return Ok(target_path); } @@ -303,12 +302,12 @@ impl Selected { unsafe { // 1. 获取库文件夹路径 let folder_id = match name { - "下载" => &FOLDERID_Downloads, - "音乐" => &FOLDERID_Music, - "图片" => &FOLDERID_Pictures, - "文档" => &FOLDERID_Documents, - "视频" => &FOLDERID_Videos, - "桌面" => &FOLDERID_Libraries, + "下载" | "Downloads" => &FOLDERID_Downloads, + "音乐" | "Music" => &FOLDERID_Music, + "图片" | "Pictures" => &FOLDERID_Pictures, + "文档" | "Documents" => &FOLDERID_Documents, + "视频" | "Videos" => &FOLDERID_Videos, + "桌面" | "Desktop" => &FOLDERID_Desktop, _ => { // 如果是自定义库,尝试从Libraries文件夹读取 let libraries_path = SHGetKnownFolderPath( diff --git a/src-tauri/tauri.conf.json b/src-tauri/tauri.conf.json index 60859e9..c81ce56 100644 --- a/src-tauri/tauri.conf.json +++ b/src-tauri/tauri.conf.json @@ -1,7 +1,7 @@ { "$schema": "../node_modules/@tauri-apps/cli/config.schema.json", "productName": "quicklook", - "version": "0.8.1", + "version": "0.8.2", "identifier": "dev.jikun.quicklook", "build": { "frontendDist": "../dist", From 02549915beea5773fa781438f44536e0325d67d2 Mon Sep 17 00:00:00 2001 From: GuoJiKun Date: Wed, 8 Jan 2025 09:39:15 +0800 Subject: [PATCH 2/2] =?UTF-8?q?fix:=20=E4=BF=AE=E5=A4=8D=E5=9C=A8=20win10?= =?UTF-8?q?=20=E6=A1=8C=E9=9D=A2=E6=97=A0=E6=B3=95=E9=A2=84=E8=A7=88?= =?UTF-8?q?=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src-tauri/src/preview.rs | 10 ---------- 1 file changed, 10 deletions(-) diff --git a/src-tauri/src/preview.rs b/src-tauri/src/preview.rs index 06a3d33..40d3395 100644 --- a/src-tauri/src/preview.rs +++ b/src-tauri/src/preview.rs @@ -69,8 +69,6 @@ impl Selected { } else { Err(WError::from_win32()) } - - } fn get_focused_type() -> Option { let mut type_str: Option = None; @@ -182,14 +180,6 @@ impl Selected { let shell_browser = shell_browser.unwrap(); - let phwnd = shell_browser.GetWindow().unwrap(); - let top = WindowsAndMessaging::GetAncestor(phwnd, WindowsAndMessaging::GA_ROOT); - - if !hwnd_gfw.eq(&top) { - log::info!("fwhwnd: {:?}, top: {:?} 不相等", hwnd_gfw, top); - return Ok(target_path); - } - let shell_view = shell_browser.QueryActiveShellView()?; target_path = Self::get_selected_file_path_from_shellview(shell_view);