หากฉันเปลี่ยนภาพพื้นหลังในรีจิสทรีด้วยตนเองฉันจะบังคับให้รีเฟรชโดยไม่ต้องออกจากระบบได้อย่างไร
ฉันรู้ว่าbginfoทำเช่นนั้น แต่ฉันต้องการให้สิ่งต่าง ๆ เรียบง่ายและไม่ใช้ซอฟต์แวร์ใด ๆ
หากฉันเปลี่ยนภาพพื้นหลังในรีจิสทรีด้วยตนเองฉันจะบังคับให้รีเฟรชโดยไม่ต้องออกจากระบบได้อย่างไร
ฉันรู้ว่าbginfoทำเช่นนั้น แต่ฉันต้องการให้สิ่งต่าง ๆ เรียบง่ายและไม่ใช้ซอฟต์แวร์ใด ๆ
คำตอบ:
RUNDLL32.EXE USER32.DLL,UpdatePerUserSystemParameters 1, True
RUNDLL32.EXE USER32.DLL,UpdatePerUserSystemParameters 1, True
ดูเหมือนว่าจะทำงานบนเครื่องของฉัน (สังเกตเครื่องหมายจุลภาคที่ขาดหายไปหลัง UpdatePerUserSystemParameters)
ฉันพยายามทำสิ่งที่คล้ายกัน - อัปเดตการตั้งค่ารีจิสทรีสำหรับเมนูเริ่มจากนั้นเมนูเริ่มต้นจะแสดงการเปลี่ยนแปลงทันที
การแก้ปัญหาจากคำถาม MSDN นี้ทำงานได้อย่างสมบูรณ์แบบสำหรับฉัน
คุณสามารถลองส่ง
WM_SETTINGCHANGE
ข้อความได้ ตัวอย่างเช่น:
class Program
{
[DllImport("user32.dll", SetLastError = true)]
private static extern IntPtr SendMessageTimeout(IntPtr hWnd, int Msg, IntPtr wParam, string lParam, uint fuFlags, uint uTimeout, IntPtr lpdwResult);
private static readonly IntPtr HWND_BROADCAST = new IntPtr(0xffff);
private const int WM_SETTINGCHANGE = 0x1a;
private const int SMTO_ABORTIFHUNG = 0x0002;
static void Main(string[] args)
{
SendMessageTimeout(HWND_BROADCAST, WM_SETTINGCHANGE, IntPtr.Zero, null, SMTO_ABORTIFHUNG, 100, IntPtr.Zero);
}
}
เปลี่ยนความละเอียดของหน้าจอจากนั้นเลือกตัวเลือกเปลี่ยนกลับ ความละเอียดของคุณจะยังคงเหมือนเดิมและพื้นหลังจะเปลี่ยนไป
หรือยกเลิกการเชื่อมต่อและต่อสายเคเบิลจอแสดงผลอีกครั้ง
# first in powershell, second both. cmd.exe + powershell.exe
# Refresh Desktop Ability
$definition = @'
[System.Runtime.InteropServices.DllImport("Shell32.dll")]
private static extern int SHChangeNotify(int eventId, int flags, IntPtr item1, IntPtr item2);
public static void Refresh() {
SHChangeNotify(0x8000000, 0x1000, IntPtr.Zero, IntPtr.Zero);
}
'@
Add-Type -MemberDefinition $definition -Namespace WinAPI -Name Explorer
# Set Safe within deleted days and get physical drive letters
$ignoreDeletedWithinDays = 2
$drives = (gwmi -Class Win32_LogicalDisk | ? {$_.drivetype -eq 3}).deviceid
# Process discovered drives
$drives | % {$drive = $_
gci -Path ($drive+'\$Recycle.Bin\*\$I*') -Recurse -Force | ? {($_.LastWriteTime -lt [datetime]::Now.AddDays(-$ignoreDeletedWithinDays)) -and ($_.name -like "`$*.*")} | % {
# Just a few calcs
$infoFile = $_
$originalFile = gi ($drive+"\`$Recycle.Bin\*\`$R$($infoFile.Name.Substring(2))") -Force
$originalLocation = [regex]::match([string](gc $infoFile.FullName -Force -Encoding Unicode),($drive+'[^<>:"/|?*]+\.[\w\-_\+]+')).Value
$deletedDate = $infoFile.LastWriteTime
$sid = $infoFile.FullName.split('\') | ? {$_ -like "S-1-5*"}
$user = try{(gpv "HKLM:\Software\Microsoft\Windows NT\CurrentVersion\ProfileList\$($sid)" -Name ProfileImagePath).replace("$(gpv 'HKLM:\Software\Microsoft\Windows NT\CurrentVersion\ProfileList' -Name ProfilesDirectory)\",'')}catch{$Sid}
#' Various info
$originalLocation
$deletedDate
$user
$sid
$infoFile.Fullname
((gi $infoFile -force).length / 1mb).ToString('0.00MB')
$originalFile.fullname
((gi $originalFile -force).length / 1mb).ToString('0.00MB')
""
# Blow it all Away
#ri $InfoFile -Recurse -Force -Confirm:$false -WhatIf
#ri $OriginalFile -Recurse -Force -Confirm:$false- WhatIf
# remove comment before two lines above and the '-WhatIf' statement to delete files
}
}
# Refresh desktop icons
[WinAPI.Explorer]::Refresh()
or
ie4uinit.exe -ClearIconCache
end scripting enjoy.
#end
บรรทัดจากคำตอบที่ยอมรับนั้นใช้ได้ผลกับฉันเป็นระยะ ๆ ฉันลงเอยด้วยการเขียนลูปเพื่อเรียกใช้โค้ดในโหมดเบื้องหลัง 25 ครั้ง หวังว่านี่จะช่วยได้
รหัสจากคำตอบที่ยอมรับได้:
RUNDLL32.EXE USER32.DLL,UpdatePerUserSystemParameters 1, True
รหัสจากส่วนบนของสคริปต์ทุบตีของฉัน:
desktop () {
i=0
# Tell the desktop to refresh 25 times.
while [ $i -le 25 ]
do
echo "RUNDLL32.EXE USER32.DLL,UpdatePerUserSystemParameters, 1 True"| "C:/Windows/System32/WindowsPowerShell/v1.0/powershell"
((i++))
done
}
# This runs the function silently as a background process
desktop &>/dev/null &